mirror of
https://github.com/AsahiLinux/u-boot
synced 2025-01-09 19:58:55 +00:00
faa7db24a4
Start split and complete split tokens need the hub address and the downstream port of the first HS hub (device view). The core of the function was duplicated in both host/ehci_hcd and musb-new/usb-compat.h. Signed-off-by: Stefan Brüns <stefan.bruens@rwth-aachen.de> Reviewed-by: Marek Vasut <marex@denx.de> Reviewed-by: Hans de Goede <hdegoede@redhat.com> Tested-by: Hans de Goede <hdegoede@redhat.com>
106 lines
3 KiB
C
106 lines
3 KiB
C
#ifndef __USB_COMPAT_H__
|
|
#define __USB_COMPAT_H__
|
|
|
|
#include <dm.h>
|
|
#include "usb.h"
|
|
|
|
struct usb_hcd {
|
|
void *hcd_priv;
|
|
};
|
|
|
|
struct usb_host_endpoint {
|
|
struct usb_endpoint_descriptor desc;
|
|
struct list_head urb_list;
|
|
void *hcpriv;
|
|
};
|
|
|
|
/*
|
|
* urb->transfer_flags:
|
|
*
|
|
* Note: URB_DIR_IN/OUT is automatically set in usb_submit_urb().
|
|
*/
|
|
#define URB_SHORT_NOT_OK 0x0001 /* report short reads as errors */
|
|
#define URB_ZERO_PACKET 0x0040 /* Finish bulk OUT with short packet */
|
|
|
|
struct urb;
|
|
|
|
typedef void (*usb_complete_t)(struct urb *);
|
|
|
|
struct urb {
|
|
void *hcpriv; /* private data for host controller */
|
|
struct list_head urb_list; /* list head for use by the urb's
|
|
* current owner */
|
|
struct usb_device *dev; /* (in) pointer to associated device */
|
|
struct usb_host_endpoint *ep; /* (internal) pointer to endpoint */
|
|
unsigned int pipe; /* (in) pipe information */
|
|
int status; /* (return) non-ISO status */
|
|
unsigned int transfer_flags; /* (in) URB_SHORT_NOT_OK | ...*/
|
|
void *transfer_buffer; /* (in) associated data buffer */
|
|
dma_addr_t transfer_dma; /* (in) dma addr for transfer_buffer */
|
|
u32 transfer_buffer_length; /* (in) data buffer length */
|
|
u32 actual_length; /* (return) actual transfer length */
|
|
unsigned char *setup_packet; /* (in) setup packet (control only) */
|
|
int start_frame; /* (modify) start frame (ISO) */
|
|
usb_complete_t complete; /* (in) completion routine */
|
|
};
|
|
|
|
#define usb_hcd_link_urb_to_ep(hcd, urb) ({ \
|
|
int ret = 0; \
|
|
list_add_tail(&urb->urb_list, &urb->ep->urb_list); \
|
|
ret; })
|
|
#define usb_hcd_unlink_urb_from_ep(hcd, urb) list_del_init(&urb->urb_list)
|
|
#define usb_hcd_check_unlink_urb(hdc, urb, status) 0
|
|
|
|
static inline void usb_hcd_giveback_urb(struct usb_hcd *hcd,
|
|
struct urb *urb,
|
|
int status)
|
|
{
|
|
urb->status = status;
|
|
if (urb->complete)
|
|
urb->complete(urb);
|
|
}
|
|
|
|
static inline int usb_hcd_unmap_urb_for_dma(struct usb_hcd *hcd,
|
|
struct urb *urb)
|
|
{
|
|
/* TODO: add cache invalidation here */
|
|
return 0;
|
|
}
|
|
|
|
#ifdef CONFIG_DM_USB
|
|
static inline struct usb_device *usb_dev_get_parent(struct usb_device *udev)
|
|
{
|
|
struct udevice *parent = udev->dev->parent;
|
|
|
|
/*
|
|
* When called from usb-uclass.c: usb_scan_device() udev->dev points
|
|
* to the parent udevice, not the actual udevice belonging to the
|
|
* udev as the device is not instantiated yet.
|
|
*
|
|
* If dev is an usb-bus, then we are called from usb_scan_device() for
|
|
* an usb-device plugged directly into the root port, return NULL.
|
|
*/
|
|
if (device_get_uclass_id(udev->dev) == UCLASS_USB)
|
|
return NULL;
|
|
|
|
/*
|
|
* If these 2 are not the same we are being called from
|
|
* usb_scan_device() and udev itself is the parent.
|
|
*/
|
|
if (dev_get_parent_priv(udev->dev) != udev)
|
|
return udev;
|
|
|
|
/* We are being called normally, use the parent pointer */
|
|
if (device_get_uclass_id(parent) == UCLASS_USB_HUB)
|
|
return dev_get_parent_priv(parent);
|
|
|
|
return NULL;
|
|
}
|
|
#else
|
|
static inline struct usb_device *usb_dev_get_parent(struct usb_device *dev)
|
|
{
|
|
return dev->parent;
|
|
}
|
|
#endif
|
|
|
|
#endif /* __USB_COMPAT_H__ */
|