diff options
author | Sarah Sharp <sarah.a.sharp@linux.intel.com> | 2009-04-27 22:57:38 -0400 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@suse.de> | 2009-06-16 00:44:49 -0400 |
commit | 3ffbba9511b4148cbe1f6b6238686adaeaca8feb (patch) | |
tree | f69e42d07d596039e049fe2b14b720ddc6be2694 /drivers/usb/host/xhci.h | |
parent | c6515272b858742962c1de0f3bf497a048b9abd7 (diff) |
USB: xhci: Allocate and address USB devices
xHCI needs to get a "Slot ID" from the host controller and allocate other
data structures for every USB device. Make usb_alloc_dev() and
usb_release_dev() allocate and free these device structures. After
setting up the xHC device structures, usb_alloc_dev() must wait for the
hardware to respond to an Enable Slot command. usb_alloc_dev() fires off
a Disable Slot command and does not wait for it to complete.
When the USB core wants to choose an address for the device, the xHCI
driver must issue a Set Address command and wait for an event for that
command.
Signed-off-by: Sarah Sharp <sarah.a.sharp@linux.intel.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
Diffstat (limited to 'drivers/usb/host/xhci.h')
-rw-r--r-- | drivers/usb/host/xhci.h | 94 |
1 files changed, 74 insertions, 20 deletions
diff --git a/drivers/usb/host/xhci.h b/drivers/usb/host/xhci.h index 059c659d3f39..4ef6b9e88504 100644 --- a/drivers/usb/host/xhci.h +++ b/drivers/usb/host/xhci.h | |||
@@ -285,12 +285,21 @@ struct xhci_op_regs { | |||
285 | * 4 - super speed | 285 | * 4 - super speed |
286 | * 5-15 reserved | 286 | * 5-15 reserved |
287 | */ | 287 | */ |
288 | #define DEV_SPEED_MASK (0xf<<10) | 288 | #define DEV_SPEED_MASK (0xf << 10) |
289 | #define XDEV_FS (0x1 << 10) | ||
290 | #define XDEV_LS (0x2 << 10) | ||
291 | #define XDEV_HS (0x3 << 10) | ||
292 | #define XDEV_SS (0x4 << 10) | ||
289 | #define DEV_UNDEFSPEED(p) (((p) & DEV_SPEED_MASK) == (0x0<<10)) | 293 | #define DEV_UNDEFSPEED(p) (((p) & DEV_SPEED_MASK) == (0x0<<10)) |
290 | #define DEV_FULLSPEED(p) (((p) & DEV_SPEED_MASK) == (0x1<<10)) | 294 | #define DEV_FULLSPEED(p) (((p) & DEV_SPEED_MASK) == XDEV_FS) |
291 | #define DEV_LOWSPEED(p) (((p) & DEV_SPEED_MASK) == (0x2<<10)) | 295 | #define DEV_LOWSPEED(p) (((p) & DEV_SPEED_MASK) == XDEV_LS) |
292 | #define DEV_HIGHSPEED(p) (((p) & DEV_SPEED_MASK) == (0x3<<10)) | 296 | #define DEV_HIGHSPEED(p) (((p) & DEV_SPEED_MASK) == XDEV_HS) |
293 | #define DEV_SUPERSPEED(p) (((p) & DEV_SPEED_MASK) == (0x4<<10)) | 297 | #define DEV_SUPERSPEED(p) (((p) & DEV_SPEED_MASK) == XDEV_SS) |
298 | /* Bits 20:23 in the Slot Context are the speed for the device */ | ||
299 | #define SLOT_SPEED_FS (XDEV_FS << 10) | ||
300 | #define SLOT_SPEED_LS (XDEV_LS << 10) | ||
301 | #define SLOT_SPEED_HS (XDEV_HS << 10) | ||
302 | #define SLOT_SPEED_SS (XDEV_SS << 10) | ||
294 | /* Port Indicator Control */ | 303 | /* Port Indicator Control */ |
295 | #define PORT_LED_OFF (0 << 14) | 304 | #define PORT_LED_OFF (0 << 14) |
296 | #define PORT_LED_AMBER (1 << 14) | 305 | #define PORT_LED_AMBER (1 << 14) |
@@ -471,14 +480,19 @@ struct xhci_slot_ctx { | |||
471 | /* Set if the device is a hub - bit 26 */ | 480 | /* Set if the device is a hub - bit 26 */ |
472 | #define DEV_HUB (0x1 << 26) | 481 | #define DEV_HUB (0x1 << 26) |
473 | /* Index of the last valid endpoint context in this device context - 27:31 */ | 482 | /* Index of the last valid endpoint context in this device context - 27:31 */ |
474 | #define LAST_EP_MASK (0x1f << 27) | 483 | #define LAST_CTX_MASK (0x1f << 27) |
475 | #define LAST_EP(p) ((p) << 27) | 484 | #define LAST_CTX(p) ((p) << 27) |
485 | #define LAST_CTX_TO_EP_NUM(p) (((p) >> 27) - 1) | ||
486 | /* Plus one for the slot context flag */ | ||
487 | #define EPI_TO_FLAG(p) (1 << ((p) + 1)) | ||
488 | #define SLOT_FLAG (1 << 0) | ||
489 | #define EP0_FLAG (1 << 1) | ||
476 | 490 | ||
477 | /* dev_info2 bitmasks */ | 491 | /* dev_info2 bitmasks */ |
478 | /* Max Exit Latency (ms) - worst case time to wake up all links in dev path */ | 492 | /* Max Exit Latency (ms) - worst case time to wake up all links in dev path */ |
479 | #define MAX_EXIT (0xffff) | 493 | #define MAX_EXIT (0xffff) |
480 | /* Root hub port number that is needed to access the USB device */ | 494 | /* Root hub port number that is needed to access the USB device */ |
481 | #define ROOT_HUB_PORT (0xff << 16) | 495 | #define ROOT_HUB_PORT(p) (((p) & 0xff) << 16) |
482 | 496 | ||
483 | /* tt_info bitmasks */ | 497 | /* tt_info bitmasks */ |
484 | /* | 498 | /* |
@@ -495,7 +509,7 @@ struct xhci_slot_ctx { | |||
495 | 509 | ||
496 | /* dev_state bitmasks */ | 510 | /* dev_state bitmasks */ |
497 | /* USB device address - assigned by the HC */ | 511 | /* USB device address - assigned by the HC */ |
498 | #define DEV_ADDR (0xff) | 512 | #define DEV_ADDR_MASK (0xff) |
499 | /* bits 8:26 reserved */ | 513 | /* bits 8:26 reserved */ |
500 | /* Slot state */ | 514 | /* Slot state */ |
501 | #define SLOT_STATE (0x1f << 27) | 515 | #define SLOT_STATE (0x1f << 27) |
@@ -507,12 +521,13 @@ struct xhci_slot_ctx { | |||
507 | * @ep_info2: information on endpoint type, max packet size, max burst size, | 521 | * @ep_info2: information on endpoint type, max packet size, max burst size, |
508 | * error count, and whether the HC will force an event for all | 522 | * error count, and whether the HC will force an event for all |
509 | * transactions. | 523 | * transactions. |
510 | * @ep_ring: 64-bit ring address. If the endpoint only defines one flow, | 524 | * @deq: 64-bit ring dequeue pointer address. If the endpoint only |
511 | * this points to the endpoint transfer ring. Otherwise, it points | 525 | * defines one stream, this points to the endpoint transfer ring. |
512 | * to a flow context array, which has a ring pointer for each flow. | 526 | * Otherwise, it points to a stream context array, which has a |
513 | * @intr_target: | 527 | * ring pointer for each flow. |
514 | * 64-bit address of the Interrupter Target that will receive | 528 | * @tx_info: |
515 | * events from this endpoint. | 529 | * Average TRB lengths for the endpoint ring and |
530 | * max payload within an Endpoint Service Interval Time (ESIT). | ||
516 | * | 531 | * |
517 | * Endpoint Context - section 6.2.1.2. This assumes the HC uses 32-byte context | 532 | * Endpoint Context - section 6.2.1.2. This assumes the HC uses 32-byte context |
518 | * structures. If the HC uses 64-byte contexts, there is an additional 32 bytes | 533 | * structures. If the HC uses 64-byte contexts, there is an additional 32 bytes |
@@ -521,12 +536,10 @@ struct xhci_slot_ctx { | |||
521 | struct xhci_ep_ctx { | 536 | struct xhci_ep_ctx { |
522 | u32 ep_info; | 537 | u32 ep_info; |
523 | u32 ep_info2; | 538 | u32 ep_info2; |
524 | /* 64-bit endpoint ring address */ | 539 | u32 deq[2]; |
525 | u32 ep_ring[2]; | 540 | u32 tx_info; |
526 | /* 64-bit address of the interrupter target */ | ||
527 | u32 intr_target[2]; | ||
528 | /* offset 0x14 - 0x1f reserved for HC internal use */ | 541 | /* offset 0x14 - 0x1f reserved for HC internal use */ |
529 | u32 reserved[2]; | 542 | u32 reserved[3]; |
530 | } __attribute__ ((packed)); | 543 | } __attribute__ ((packed)); |
531 | 544 | ||
532 | /* ep_info bitmasks */ | 545 | /* ep_info bitmasks */ |
@@ -589,6 +602,28 @@ struct xhci_device_control { | |||
589 | #define ADD_EP(x) (0x1 << x) | 602 | #define ADD_EP(x) (0x1 << x) |
590 | 603 | ||
591 | 604 | ||
605 | struct xhci_virt_device { | ||
606 | /* | ||
607 | * Commands to the hardware are passed an "input context" that | ||
608 | * tells the hardware what to change in its data structures. | ||
609 | * The hardware will return changes in an "output context" that | ||
610 | * software must allocate for the hardware. We need to keep | ||
611 | * track of input and output contexts separately because | ||
612 | * these commands might fail and we don't trust the hardware. | ||
613 | */ | ||
614 | struct xhci_device_control *out_ctx; | ||
615 | dma_addr_t out_ctx_dma; | ||
616 | /* Used for addressing devices and configuration changes */ | ||
617 | struct xhci_device_control *in_ctx; | ||
618 | dma_addr_t in_ctx_dma; | ||
619 | /* FIXME when stream support is added */ | ||
620 | struct xhci_ring *ep_rings[31]; | ||
621 | dma_addr_t ep_dma[31]; | ||
622 | /* Status of the last command issued for this device */ | ||
623 | u32 cmd_status; | ||
624 | }; | ||
625 | |||
626 | |||
592 | /** | 627 | /** |
593 | * struct xhci_device_context_array | 628 | * struct xhci_device_context_array |
594 | * @dev_context_ptr array of 64-bit DMA addresses for device contexts | 629 | * @dev_context_ptr array of 64-bit DMA addresses for device contexts |
@@ -711,6 +746,11 @@ struct xhci_event_cmd { | |||
711 | u32 flags; | 746 | u32 flags; |
712 | } __attribute__ ((packed)); | 747 | } __attribute__ ((packed)); |
713 | 748 | ||
749 | /* flags bitmasks */ | ||
750 | /* bits 16:23 are the virtual function ID */ | ||
751 | /* bits 24:31 are the slot ID */ | ||
752 | #define TRB_TO_SLOT_ID(p) (((p) & (0xff<<24)) >> 24) | ||
753 | #define SLOT_ID_FOR_TRB(p) (((p) & 0xff) << 24) | ||
714 | 754 | ||
715 | /* Port Status Change Event TRB fields */ | 755 | /* Port Status Change Event TRB fields */ |
716 | /* Port ID - bits 31:24 */ | 756 | /* Port ID - bits 31:24 */ |
@@ -931,6 +971,11 @@ struct xhci_hcd { | |||
931 | struct xhci_ring *cmd_ring; | 971 | struct xhci_ring *cmd_ring; |
932 | struct xhci_ring *event_ring; | 972 | struct xhci_ring *event_ring; |
933 | struct xhci_erst erst; | 973 | struct xhci_erst erst; |
974 | /* slot enabling and address device helpers */ | ||
975 | struct completion addr_dev; | ||
976 | int slot_id; | ||
977 | /* Internal mirror of the HW's dcbaa */ | ||
978 | struct xhci_virt_device *devs[MAX_HC_SLOTS]; | ||
934 | 979 | ||
935 | /* DMA pools */ | 980 | /* DMA pools */ |
936 | struct dma_pool *device_pool; | 981 | struct dma_pool *device_pool; |
@@ -1002,10 +1047,14 @@ void xhci_debug_ring(struct xhci_hcd *xhci, struct xhci_ring *ring); | |||
1002 | void xhci_dbg_erst(struct xhci_hcd *xhci, struct xhci_erst *erst); | 1047 | void xhci_dbg_erst(struct xhci_hcd *xhci, struct xhci_erst *erst); |
1003 | void xhci_dbg_cmd_ptrs(struct xhci_hcd *xhci); | 1048 | void xhci_dbg_cmd_ptrs(struct xhci_hcd *xhci); |
1004 | void xhci_dbg_ring_ptrs(struct xhci_hcd *xhci, struct xhci_ring *ring); | 1049 | void xhci_dbg_ring_ptrs(struct xhci_hcd *xhci, struct xhci_ring *ring); |
1050 | void xhci_dbg_ctx(struct xhci_hcd *xhci, struct xhci_device_control *ctx, dma_addr_t dma, unsigned int last_ep); | ||
1005 | 1051 | ||
1006 | /* xHCI memory managment */ | 1052 | /* xHCI memory managment */ |
1007 | void xhci_mem_cleanup(struct xhci_hcd *xhci); | 1053 | void xhci_mem_cleanup(struct xhci_hcd *xhci); |
1008 | int xhci_mem_init(struct xhci_hcd *xhci, gfp_t flags); | 1054 | int xhci_mem_init(struct xhci_hcd *xhci, gfp_t flags); |
1055 | void xhci_free_virt_device(struct xhci_hcd *xhci, int slot_id); | ||
1056 | int xhci_alloc_virt_device(struct xhci_hcd *xhci, int slot_id, struct usb_device *udev, gfp_t flags); | ||
1057 | int xhci_setup_addressable_virt_dev(struct xhci_hcd *xhci, struct usb_device *udev); | ||
1009 | 1058 | ||
1010 | #ifdef CONFIG_PCI | 1059 | #ifdef CONFIG_PCI |
1011 | /* xHCI PCI glue */ | 1060 | /* xHCI PCI glue */ |
@@ -1022,6 +1071,9 @@ void xhci_stop(struct usb_hcd *hcd); | |||
1022 | void xhci_shutdown(struct usb_hcd *hcd); | 1071 | void xhci_shutdown(struct usb_hcd *hcd); |
1023 | int xhci_get_frame(struct usb_hcd *hcd); | 1072 | int xhci_get_frame(struct usb_hcd *hcd); |
1024 | irqreturn_t xhci_irq(struct usb_hcd *hcd); | 1073 | irqreturn_t xhci_irq(struct usb_hcd *hcd); |
1074 | int xhci_alloc_dev(struct usb_hcd *hcd, struct usb_device *udev); | ||
1075 | void xhci_free_dev(struct usb_hcd *hcd, struct usb_device *udev); | ||
1076 | int xhci_address_device(struct usb_hcd *hcd, struct usb_device *udev); | ||
1025 | 1077 | ||
1026 | /* xHCI ring, segment, TRB, and TD functions */ | 1078 | /* xHCI ring, segment, TRB, and TD functions */ |
1027 | dma_addr_t trb_virt_to_dma(struct xhci_segment *seg, union xhci_trb *trb); | 1079 | dma_addr_t trb_virt_to_dma(struct xhci_segment *seg, union xhci_trb *trb); |
@@ -1029,6 +1081,8 @@ void ring_cmd_db(struct xhci_hcd *xhci); | |||
1029 | void *setup_one_noop(struct xhci_hcd *xhci); | 1081 | void *setup_one_noop(struct xhci_hcd *xhci); |
1030 | void handle_event(struct xhci_hcd *xhci); | 1082 | void handle_event(struct xhci_hcd *xhci); |
1031 | void set_hc_event_deq(struct xhci_hcd *xhci); | 1083 | void set_hc_event_deq(struct xhci_hcd *xhci); |
1084 | int queue_slot_control(struct xhci_hcd *xhci, u32 trb_type, u32 slot_id); | ||
1085 | int queue_address_device(struct xhci_hcd *xhci, dma_addr_t in_ctx_ptr, u32 slot_id); | ||
1032 | 1086 | ||
1033 | /* xHCI roothub code */ | 1087 | /* xHCI roothub code */ |
1034 | int xhci_hub_control(struct usb_hcd *hcd, u16 typeReq, u16 wValue, u16 wIndex, | 1088 | int xhci_hub_control(struct usb_hcd *hcd, u16 typeReq, u16 wValue, u16 wIndex, |