aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/usb/host/ehci.h
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/usb/host/ehci.h')
-rw-r--r--drivers/usb/host/ehci.h36
1 files changed, 18 insertions, 18 deletions
diff --git a/drivers/usb/host/ehci.h b/drivers/usb/host/ehci.h
index 1385ce2b3f0a..bbc3082a73d7 100644
--- a/drivers/usb/host/ehci.h
+++ b/drivers/usb/host/ehci.h
@@ -1,6 +1,6 @@
1/* 1/*
2 * Copyright (c) 2001-2002 by David Brownell 2 * Copyright (c) 2001-2002 by David Brownell
3 * 3 *
4 * This program is free software; you can redistribute it and/or modify it 4 * This program is free software; you can redistribute it and/or modify it
5 * under the terms of the GNU General Public License as published by the 5 * under the terms of the GNU General Public License as published by the
6 * Free Software Foundation; either version 2 of the License, or (at your 6 * Free Software Foundation; either version 2 of the License, or (at your
@@ -103,7 +103,7 @@ struct ehci_hcd { /* one per controller */
103#endif 103#endif
104}; 104};
105 105
106/* convert between an HCD pointer and the corresponding EHCI_HCD */ 106/* convert between an HCD pointer and the corresponding EHCI_HCD */
107static inline struct ehci_hcd *hcd_to_ehci (struct usb_hcd *hcd) 107static inline struct ehci_hcd *hcd_to_ehci (struct usb_hcd *hcd)
108{ 108{
109 return (struct ehci_hcd *) (hcd->hcd_priv); 109 return (struct ehci_hcd *) (hcd->hcd_priv);
@@ -178,8 +178,8 @@ struct ehci_caps {
178#define HCS_INDICATOR(p) ((p)&(1 << 16)) /* true: has port indicators */ 178#define HCS_INDICATOR(p) ((p)&(1 << 16)) /* true: has port indicators */
179#define HCS_N_CC(p) (((p)>>12)&0xf) /* bits 15:12, #companion HCs */ 179#define HCS_N_CC(p) (((p)>>12)&0xf) /* bits 15:12, #companion HCs */
180#define HCS_N_PCC(p) (((p)>>8)&0xf) /* bits 11:8, ports per CC */ 180#define HCS_N_PCC(p) (((p)>>8)&0xf) /* bits 11:8, ports per CC */
181#define HCS_PORTROUTED(p) ((p)&(1 << 7)) /* true: port routing */ 181#define HCS_PORTROUTED(p) ((p)&(1 << 7)) /* true: port routing */
182#define HCS_PPC(p) ((p)&(1 << 4)) /* true: port power control */ 182#define HCS_PPC(p) ((p)&(1 << 4)) /* true: port power control */
183#define HCS_N_PORTS(p) (((p)>>0)&0xf) /* bits 3:0, ports on HC */ 183#define HCS_N_PORTS(p) (((p)>>0)&0xf) /* bits 3:0, ports on HC */
184 184
185 u32 hcc_params; /* HCCPARAMS - offset 0x8 */ 185 u32 hcc_params; /* HCCPARAMS - offset 0x8 */
@@ -204,7 +204,7 @@ struct ehci_regs {
204#define CMD_LRESET (1<<7) /* partial reset (no ports, etc) */ 204#define CMD_LRESET (1<<7) /* partial reset (no ports, etc) */
205#define CMD_IAAD (1<<6) /* "doorbell" interrupt async advance */ 205#define CMD_IAAD (1<<6) /* "doorbell" interrupt async advance */
206#define CMD_ASE (1<<5) /* async schedule enable */ 206#define CMD_ASE (1<<5) /* async schedule enable */
207#define CMD_PSE (1<<4) /* periodic schedule enable */ 207#define CMD_PSE (1<<4) /* periodic schedule enable */
208/* 3:2 is periodic frame list size */ 208/* 3:2 is periodic frame list size */
209#define CMD_RESET (1<<1) /* reset HC not bus */ 209#define CMD_RESET (1<<1) /* reset HC not bus */
210#define CMD_RUN (1<<0) /* start/stop HC */ 210#define CMD_RUN (1<<0) /* start/stop HC */
@@ -230,9 +230,9 @@ struct ehci_regs {
230 /* FRINDEX: offset 0x0C */ 230 /* FRINDEX: offset 0x0C */
231 u32 frame_index; /* current microframe number */ 231 u32 frame_index; /* current microframe number */
232 /* CTRLDSSEGMENT: offset 0x10 */ 232 /* CTRLDSSEGMENT: offset 0x10 */
233 u32 segment; /* address bits 63:32 if needed */ 233 u32 segment; /* address bits 63:32 if needed */
234 /* PERIODICLISTBASE: offset 0x14 */ 234 /* PERIODICLISTBASE: offset 0x14 */
235 u32 frame_list; /* points to periodic list */ 235 u32 frame_list; /* points to periodic list */
236 /* ASYNCLISTADDR: offset 0x18 */ 236 /* ASYNCLISTADDR: offset 0x18 */
237 u32 async_next; /* address of next async queue head */ 237 u32 async_next; /* address of next async queue head */
238 238
@@ -301,7 +301,7 @@ struct ehci_dbg_port {
301 301
302/* 302/*
303 * EHCI Specification 0.95 Section 3.5 303 * EHCI Specification 0.95 Section 3.5
304 * QTD: describe data transfer components (buffer, direction, ...) 304 * QTD: describe data transfer components (buffer, direction, ...)
305 * See Fig 3-6 "Queue Element Transfer Descriptor Block Diagram". 305 * See Fig 3-6 "Queue Element Transfer Descriptor Block Diagram".
306 * 306 *
307 * These are associated only with "QH" (Queue Head) structures, 307 * These are associated only with "QH" (Queue Head) structures,
@@ -311,7 +311,7 @@ struct ehci_qtd {
311 /* first part defined by EHCI spec */ 311 /* first part defined by EHCI spec */
312 __le32 hw_next; /* see EHCI 3.5.1 */ 312 __le32 hw_next; /* see EHCI 3.5.1 */
313 __le32 hw_alt_next; /* see EHCI 3.5.2 */ 313 __le32 hw_alt_next; /* see EHCI 3.5.2 */
314 __le32 hw_token; /* see EHCI 3.5.3 */ 314 __le32 hw_token; /* see EHCI 3.5.3 */
315#define QTD_TOGGLE (1 << 31) /* data toggle */ 315#define QTD_TOGGLE (1 << 31) /* data toggle */
316#define QTD_LENGTH(tok) (((tok)>>16) & 0x7fff) 316#define QTD_LENGTH(tok) (((tok)>>16) & 0x7fff)
317#define QTD_IOC (1 << 15) /* interrupt on complete */ 317#define QTD_IOC (1 << 15) /* interrupt on complete */
@@ -348,8 +348,8 @@ struct ehci_qtd {
348/* values for that type tag */ 348/* values for that type tag */
349#define Q_TYPE_ITD __constant_cpu_to_le32 (0 << 1) 349#define Q_TYPE_ITD __constant_cpu_to_le32 (0 << 1)
350#define Q_TYPE_QH __constant_cpu_to_le32 (1 << 1) 350#define Q_TYPE_QH __constant_cpu_to_le32 (1 << 1)
351#define Q_TYPE_SITD __constant_cpu_to_le32 (2 << 1) 351#define Q_TYPE_SITD __constant_cpu_to_le32 (2 << 1)
352#define Q_TYPE_FSTN __constant_cpu_to_le32 (3 << 1) 352#define Q_TYPE_FSTN __constant_cpu_to_le32 (3 << 1)
353 353
354/* next async queue entry, or pointer to interrupt/periodic QH */ 354/* next async queue entry, or pointer to interrupt/periodic QH */
355#define QH_NEXT(dma) (cpu_to_le32(((u32)dma)&~0x01f)|Q_TYPE_QH) 355#define QH_NEXT(dma) (cpu_to_le32(((u32)dma)&~0x01f)|Q_TYPE_QH)
@@ -366,7 +366,7 @@ struct ehci_qtd {
366 * For entries in the async schedule, the type tag always says "qh". 366 * For entries in the async schedule, the type tag always says "qh".
367 */ 367 */
368union ehci_shadow { 368union ehci_shadow {
369 struct ehci_qh *qh; /* Q_TYPE_QH */ 369 struct ehci_qh *qh; /* Q_TYPE_QH */
370 struct ehci_itd *itd; /* Q_TYPE_ITD */ 370 struct ehci_itd *itd; /* Q_TYPE_ITD */
371 struct ehci_sitd *sitd; /* Q_TYPE_SITD */ 371 struct ehci_sitd *sitd; /* Q_TYPE_SITD */
372 struct ehci_fstn *fstn; /* Q_TYPE_FSTN */ 372 struct ehci_fstn *fstn; /* Q_TYPE_FSTN */
@@ -396,7 +396,7 @@ struct ehci_qh {
396#define QH_HUBPORT 0x3f800000 396#define QH_HUBPORT 0x3f800000
397#define QH_MULT 0xc0000000 397#define QH_MULT 0xc0000000
398 __le32 hw_current; /* qtd list - see EHCI 3.6.4 */ 398 __le32 hw_current; /* qtd list - see EHCI 3.6.4 */
399 399
400 /* qtd overlay (hardware parts of a struct ehci_qtd) */ 400 /* qtd overlay (hardware parts of a struct ehci_qtd) */
401 __le32 hw_qtd_next; 401 __le32 hw_qtd_next;
402 __le32 hw_alt_next; 402 __le32 hw_alt_next;
@@ -471,7 +471,7 @@ struct ehci_iso_stream {
471 struct list_head td_list; /* queued itds/sitds */ 471 struct list_head td_list; /* queued itds/sitds */
472 struct list_head free_list; /* list of unused itds/sitds */ 472 struct list_head free_list; /* list of unused itds/sitds */
473 struct usb_device *udev; 473 struct usb_device *udev;
474 struct usb_host_endpoint *ep; 474 struct usb_host_endpoint *ep;
475 475
476 /* output of (re)scheduling */ 476 /* output of (re)scheduling */
477 unsigned long start; /* jiffies */ 477 unsigned long start; /* jiffies */
@@ -491,8 +491,8 @@ struct ehci_iso_stream {
491 unsigned bandwidth; 491 unsigned bandwidth;
492 492
493 /* This is used to initialize iTD's hw_bufp fields */ 493 /* This is used to initialize iTD's hw_bufp fields */
494 __le32 buf0; 494 __le32 buf0;
495 __le32 buf1; 495 __le32 buf1;
496 __le32 buf2; 496 __le32 buf2;
497 497
498 /* this is used to initialize sITD's tt info */ 498 /* this is used to initialize sITD's tt info */
@@ -520,7 +520,7 @@ struct ehci_itd {
520 520
521#define ITD_ACTIVE __constant_cpu_to_le32(EHCI_ISOC_ACTIVE) 521#define ITD_ACTIVE __constant_cpu_to_le32(EHCI_ISOC_ACTIVE)
522 522
523 __le32 hw_bufp [7]; /* see EHCI 3.3.3 */ 523 __le32 hw_bufp [7]; /* see EHCI 3.3.3 */
524 __le32 hw_bufp_hi [7]; /* Appendix B */ 524 __le32 hw_bufp_hi [7]; /* Appendix B */
525 525
526 /* the rest is HCD-private */ 526 /* the rest is HCD-private */
@@ -541,7 +541,7 @@ struct ehci_itd {
541/*-------------------------------------------------------------------------*/ 541/*-------------------------------------------------------------------------*/
542 542
543/* 543/*
544 * EHCI Specification 0.95 Section 3.4 544 * EHCI Specification 0.95 Section 3.4
545 * siTD, aka split-transaction isochronous Transfer Descriptor 545 * siTD, aka split-transaction isochronous Transfer Descriptor
546 * ... describe full speed iso xfers through TT in hubs 546 * ... describe full speed iso xfers through TT in hubs
547 * see Figure 3-5 "Split-transaction Isochronous Transaction Descriptor (siTD) 547 * see Figure 3-5 "Split-transaction Isochronous Transaction Descriptor (siTD)