| David Vrabel | 7e6133a | 2008-09-17 16:34:28 +0100 | [diff] [blame] | 1 | /* | 
|  | 2 | * Wireless Host Controller (WHC) data structures. | 
|  | 3 | * | 
|  | 4 | * Copyright (C) 2007 Cambridge Silicon Radio Ltd. | 
|  | 5 | * | 
|  | 6 | * This program is free software; you can redistribute it and/or | 
|  | 7 | * modify it under the terms of the GNU General Public License version | 
|  | 8 | * 2 as published by the Free Software Foundation. | 
|  | 9 | * | 
|  | 10 | * This program is distributed in the hope that it will be useful, | 
|  | 11 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
|  | 12 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
|  | 13 | * GNU General Public License for more details. | 
|  | 14 | * | 
|  | 15 | * You should have received a copy of the GNU General Public License | 
|  | 16 | * along with this program; if not, write to the Free Software | 
|  | 17 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA | 
|  | 18 | * 02110-1301, USA. | 
|  | 19 | */ | 
|  | 20 | #ifndef _WHCI_WHCI_HC_H | 
|  | 21 | #define _WHCI_WHCI_HC_H | 
|  | 22 |  | 
|  | 23 | #include <linux/list.h> | 
|  | 24 |  | 
|  | 25 | /** | 
|  | 26 | * WHCI_PAGE_SIZE - page size use by WHCI | 
|  | 27 | * | 
|  | 28 | * WHCI assumes that host system uses pages of 4096 octets. | 
|  | 29 | */ | 
|  | 30 | #define WHCI_PAGE_SIZE 4096 | 
|  | 31 |  | 
|  | 32 |  | 
|  | 33 | /** | 
|  | 34 | * QTD_MAX_TXFER_SIZE - max number of bytes to transfer with a single | 
|  | 35 | * qtd. | 
|  | 36 | * | 
|  | 37 | * This is 2^20 - 1. | 
|  | 38 | */ | 
|  | 39 | #define QTD_MAX_XFER_SIZE 1048575 | 
|  | 40 |  | 
|  | 41 |  | 
|  | 42 | /** | 
|  | 43 | * struct whc_qtd - Queue Element Transfer Descriptors (qTD) | 
|  | 44 | * | 
|  | 45 | * This describes the data for a bulk, control or interrupt transfer. | 
|  | 46 | * | 
|  | 47 | * [WHCI] section 3.2.4 | 
|  | 48 | */ | 
|  | 49 | struct whc_qtd { | 
|  | 50 | __le32 status; /*< remaining transfer len and transfer status */ | 
|  | 51 | __le32 options; | 
|  | 52 | __le64 page_list_ptr; /*< physical pointer to data buffer page list*/ | 
|  | 53 | __u8   setup[8];      /*< setup data for control transfers */ | 
|  | 54 | } __attribute__((packed)); | 
|  | 55 |  | 
|  | 56 | #define QTD_STS_ACTIVE     (1 << 31)  /* enable execution of transaction */ | 
|  | 57 | #define QTD_STS_HALTED     (1 << 30)  /* transfer halted */ | 
|  | 58 | #define QTD_STS_DBE        (1 << 29)  /* data buffer error */ | 
|  | 59 | #define QTD_STS_BABBLE     (1 << 28)  /* babble detected */ | 
|  | 60 | #define QTD_STS_RCE        (1 << 27)  /* retry count exceeded */ | 
|  | 61 | #define QTD_STS_LAST_PKT   (1 << 26)  /* set Last Packet Flag in WUSB header */ | 
|  | 62 | #define QTD_STS_INACTIVE   (1 << 25)  /* queue set is marked inactive */ | 
|  | 63 | #define QTD_STS_IALT_VALID (1 << 23)                          /* iAlt field is valid */ | 
|  | 64 | #define QTD_STS_IALT(i)    (QTD_STS_IALT_VALID | ((i) << 20)) /* iAlt field */ | 
|  | 65 | #define QTD_STS_LEN(l)     ((l) << 0) /* transfer length */ | 
|  | 66 | #define QTD_STS_TO_LEN(s)  ((s) & 0x000fffff) | 
|  | 67 |  | 
|  | 68 | #define QTD_OPT_IOC      (1 << 1) /* page_list_ptr points to buffer directly */ | 
|  | 69 | #define QTD_OPT_SMALL    (1 << 0) /* interrupt on complete */ | 
|  | 70 |  | 
|  | 71 | /** | 
|  | 72 | * struct whc_itd - Isochronous Queue Element Transfer Descriptors (iTD) | 
|  | 73 | * | 
|  | 74 | * This describes the data and other parameters for an isochronous | 
|  | 75 | * transfer. | 
|  | 76 | * | 
|  | 77 | * [WHCI] section 3.2.5 | 
|  | 78 | */ | 
|  | 79 | struct whc_itd { | 
|  | 80 | __le16 presentation_time;    /*< presentation time for OUT transfers */ | 
|  | 81 | __u8   num_segments;         /*< number of data segments in segment list */ | 
|  | 82 | __u8   status;               /*< command execution status */ | 
|  | 83 | __le32 options;              /*< misc transfer options */ | 
|  | 84 | __le64 page_list_ptr;        /*< physical pointer to data buffer page list */ | 
|  | 85 | __le64 seg_list_ptr;         /*< physical pointer to segment list */ | 
|  | 86 | } __attribute__((packed)); | 
|  | 87 |  | 
|  | 88 | #define ITD_STS_ACTIVE   (1 << 7) /* enable execution of transaction */ | 
|  | 89 | #define ITD_STS_DBE      (1 << 5) /* data buffer error */ | 
|  | 90 | #define ITD_STS_BABBLE   (1 << 4) /* babble detected */ | 
|  | 91 | #define ITD_STS_INACTIVE (1 << 1) /* queue set is marked inactive */ | 
|  | 92 |  | 
|  | 93 | #define ITD_OPT_IOC      (1 << 1) /* interrupt on complete */ | 
|  | 94 | #define ITD_OPT_SMALL    (1 << 0) /* page_list_ptr points to buffer directly */ | 
|  | 95 |  | 
|  | 96 | /** | 
|  | 97 | * Page list entry. | 
|  | 98 | * | 
|  | 99 | * A TD's page list must contain sufficient page list entries for the | 
|  | 100 | * total data length in the TD. | 
|  | 101 | * | 
|  | 102 | * [WHCI] section 3.2.4.3 | 
|  | 103 | */ | 
|  | 104 | struct whc_page_list_entry { | 
|  | 105 | __le64 buf_ptr; /*< physical pointer to buffer */ | 
|  | 106 | } __attribute__((packed)); | 
|  | 107 |  | 
|  | 108 | /** | 
|  | 109 | * struct whc_seg_list_entry - Segment list entry. | 
|  | 110 | * | 
|  | 111 | * Describes a portion of the data buffer described in the containing | 
|  | 112 | * qTD's page list. | 
|  | 113 | * | 
|  | 114 | * seg_ptr = qtd->page_list_ptr[qtd->seg_list_ptr[seg].idx].buf_ptr | 
|  | 115 | *           + qtd->seg_list_ptr[seg].offset; | 
|  | 116 | * | 
|  | 117 | * Segments can't cross page boundries. | 
|  | 118 | * | 
|  | 119 | * [WHCI] section 3.2.5.5 | 
|  | 120 | */ | 
|  | 121 | struct whc_seg_list_entry { | 
|  | 122 | __le16 len;    /*< segment length */ | 
|  | 123 | __u8   idx;    /*< index into page list */ | 
|  | 124 | __u8   status; /*< segment status */ | 
|  | 125 | __le16 offset; /*< 12 bit offset into page */ | 
|  | 126 | } __attribute__((packed)); | 
|  | 127 |  | 
|  | 128 | /** | 
|  | 129 | * struct whc_qhead - endpoint and status information for a qset. | 
|  | 130 | * | 
|  | 131 | * [WHCI] section 3.2.6 | 
|  | 132 | */ | 
|  | 133 | struct whc_qhead { | 
|  | 134 | __le64 link; /*< next qset in list */ | 
|  | 135 | __le32 info1; | 
|  | 136 | __le32 info2; | 
|  | 137 | __le32 info3; | 
|  | 138 | __le16 status; | 
|  | 139 | __le16 err_count;  /*< transaction error count */ | 
|  | 140 | __le32 cur_window; | 
|  | 141 | __le32 scratch[3]; /*< h/w scratch area */ | 
|  | 142 | union { | 
|  | 143 | struct whc_qtd qtd; | 
|  | 144 | struct whc_itd itd; | 
|  | 145 | } overlay; | 
|  | 146 | } __attribute__((packed)); | 
|  | 147 |  | 
|  | 148 | #define QH_LINK_PTR_MASK (~0x03Full) | 
|  | 149 | #define QH_LINK_PTR(ptr) ((ptr) & QH_LINK_PTR_MASK) | 
|  | 150 | #define QH_LINK_IQS      (1 << 4) /* isochronous queue set */ | 
|  | 151 | #define QH_LINK_NTDS(n)  (((n) - 1) << 1) /* number of TDs in queue set */ | 
|  | 152 | #define QH_LINK_T        (1 << 0) /* last queue set in periodic schedule list */ | 
|  | 153 |  | 
|  | 154 | #define QH_INFO1_EP(e)           ((e) << 0)  /* endpoint number */ | 
|  | 155 | #define QH_INFO1_DIR_IN          (1 << 4)    /* IN transfer */ | 
|  | 156 | #define QH_INFO1_DIR_OUT         (0 << 4)    /* OUT transfer */ | 
|  | 157 | #define QH_INFO1_TR_TYPE_CTRL    (0x0 << 5)  /* control transfer */ | 
|  | 158 | #define QH_INFO1_TR_TYPE_ISOC    (0x1 << 5)  /* isochronous transfer */ | 
|  | 159 | #define QH_INFO1_TR_TYPE_BULK    (0x2 << 5)  /* bulk transfer */ | 
|  | 160 | #define QH_INFO1_TR_TYPE_INT     (0x3 << 5)  /* interrupt */ | 
|  | 161 | #define QH_INFO1_TR_TYPE_LP_INT  (0x7 << 5)  /* low power interrupt */ | 
|  | 162 | #define QH_INFO1_DEV_INFO_IDX(i) ((i) << 8)  /* index into device info buffer */ | 
|  | 163 | #define QH_INFO1_SET_INACTIVE    (1 << 15)   /* set inactive after transfer */ | 
|  | 164 | #define QH_INFO1_MAX_PKT_LEN(l)  ((l) << 16) /* maximum packet length */ | 
|  | 165 |  | 
|  | 166 | #define QH_INFO2_BURST(b)        ((b) << 0)  /* maximum burst length */ | 
|  | 167 | #define QH_INFO2_DBP(p)          ((p) << 5)  /* data burst policy (see [WUSB] table 5-7) */ | 
|  | 168 | #define QH_INFO2_MAX_COUNT(c)    ((c) << 8)  /* max isoc/int pkts per zone */ | 
|  | 169 | #define QH_INFO2_RQS             (1 << 15)   /* reactivate queue set */ | 
|  | 170 | #define QH_INFO2_MAX_RETRY(r)    ((r) << 16) /* maximum transaction retries */ | 
|  | 171 | #define QH_INFO2_MAX_SEQ(s)      ((s) << 20) /* maximum sequence number */ | 
|  | 172 | #define QH_INFO3_MAX_DELAY(d)    ((d) << 0)  /* maximum stream delay in 125 us units (isoc only) */ | 
|  | 173 | #define QH_INFO3_INTERVAL(i)     ((i) << 16) /* segment interval in 125 us units (isoc only) */ | 
|  | 174 |  | 
| David Vrabel | c3f22d9 | 2009-10-12 15:45:18 +0000 | [diff] [blame] | 175 | #define QH_INFO3_TX_RATE(r)      ((r) << 24) /* PHY rate (see [ECMA-368] section 10.3.1.1) */ | 
| David Vrabel | 7e6133a | 2008-09-17 16:34:28 +0100 | [diff] [blame] | 176 | #define QH_INFO3_TX_PWR(p)       ((p) << 29) /* transmit power (see [WUSB] section 5.2.1.2) */ | 
|  | 177 |  | 
|  | 178 | #define QH_STATUS_FLOW_CTRL      (1 << 15) | 
|  | 179 | #define QH_STATUS_ICUR(i)        ((i) << 5) | 
|  | 180 | #define QH_STATUS_TO_ICUR(s)     (((s) >> 5) & 0x7) | 
| David Vrabel | 7f0406d | 2009-04-08 17:36:29 +0000 | [diff] [blame] | 181 | #define QH_STATUS_SEQ_MASK       0x1f | 
| David Vrabel | 7e6133a | 2008-09-17 16:34:28 +0100 | [diff] [blame] | 182 |  | 
|  | 183 | /** | 
|  | 184 | * usb_pipe_to_qh_type - USB core pipe type to QH transfer type | 
|  | 185 | * | 
|  | 186 | * Returns the QH type field for a USB core pipe type. | 
|  | 187 | */ | 
|  | 188 | static inline unsigned usb_pipe_to_qh_type(unsigned pipe) | 
|  | 189 | { | 
|  | 190 | static const unsigned type[] = { | 
|  | 191 | [PIPE_ISOCHRONOUS] = QH_INFO1_TR_TYPE_ISOC, | 
|  | 192 | [PIPE_INTERRUPT]   = QH_INFO1_TR_TYPE_INT, | 
|  | 193 | [PIPE_CONTROL]     = QH_INFO1_TR_TYPE_CTRL, | 
|  | 194 | [PIPE_BULK]        = QH_INFO1_TR_TYPE_BULK, | 
|  | 195 | }; | 
|  | 196 | return type[usb_pipetype(pipe)]; | 
|  | 197 | } | 
|  | 198 |  | 
|  | 199 | /** | 
|  | 200 | * Maxiumum number of TDs in a qset. | 
|  | 201 | */ | 
|  | 202 | #define WHCI_QSET_TD_MAX 8 | 
|  | 203 |  | 
|  | 204 | /** | 
|  | 205 | * struct whc_qset - WUSB data transfers to a specific endpoint | 
|  | 206 | * @qh: the QHead of this qset | 
|  | 207 | * @qtd: up to 8 qTDs (for qsets for control, bulk and interrupt | 
|  | 208 | * transfers) | 
|  | 209 | * @itd: up to 8 iTDs (for qsets for isochronous transfers) | 
|  | 210 | * @qset_dma: DMA address for this qset | 
|  | 211 | * @whc: WHCI HC this qset is for | 
|  | 212 | * @ep: endpoint | 
|  | 213 | * @stds: list of sTDs queued to this qset | 
|  | 214 | * @ntds: number of qTDs queued (not necessarily the same as nTDs | 
|  | 215 | * field in the QH) | 
|  | 216 | * @td_start: index of the first qTD in the list | 
|  | 217 | * @td_end: index of next free qTD in the list (provided | 
|  | 218 | *          ntds < WHCI_QSET_TD_MAX) | 
|  | 219 | * | 
|  | 220 | * Queue Sets (qsets) are added to the asynchronous schedule list | 
|  | 221 | * (ASL) or the periodic zone list (PZL). | 
|  | 222 | * | 
|  | 223 | * qsets may contain up to 8 TDs (either qTDs or iTDs as appropriate). | 
|  | 224 | * Each TD may refer to at most 1 MiB of data. If a single transfer | 
|  | 225 | * has > 8MiB of data, TDs can be reused as they are completed since | 
|  | 226 | * the TD list is used as a circular buffer.  Similarly, several | 
|  | 227 | * (smaller) transfers may be queued in a qset. | 
|  | 228 | * | 
|  | 229 | * WHCI controllers may cache portions of the qsets in the ASL and | 
|  | 230 | * PZL, requiring the WHCD to inform the WHC that the lists have been | 
|  | 231 | * updated (fields changed or qsets inserted or removed).  For safe | 
|  | 232 | * insertion and removal of qsets from the lists the schedule must be | 
|  | 233 | * stopped to avoid races in updating the QH link pointers. | 
|  | 234 | * | 
|  | 235 | * Since the HC is free to execute qsets in any order, all transfers | 
|  | 236 | * to an endpoint should use the same qset to ensure transfers are | 
|  | 237 | * executed in the order they're submitted. | 
|  | 238 | * | 
|  | 239 | * [WHCI] section 3.2.3 | 
|  | 240 | */ | 
|  | 241 | struct whc_qset { | 
|  | 242 | struct whc_qhead qh; | 
|  | 243 | union { | 
|  | 244 | struct whc_qtd qtd[WHCI_QSET_TD_MAX]; | 
|  | 245 | struct whc_itd itd[WHCI_QSET_TD_MAX]; | 
|  | 246 | }; | 
|  | 247 |  | 
|  | 248 | /* private data for WHCD */ | 
|  | 249 | dma_addr_t qset_dma; | 
|  | 250 | struct whc *whc; | 
|  | 251 | struct usb_host_endpoint *ep; | 
|  | 252 | struct list_head stds; | 
|  | 253 | int ntds; | 
|  | 254 | int td_start; | 
|  | 255 | int td_end; | 
|  | 256 | struct list_head list_node; | 
|  | 257 | unsigned in_sw_list:1; | 
|  | 258 | unsigned in_hw_list:1; | 
|  | 259 | unsigned remove:1; | 
| David Vrabel | 831baa4 | 2009-06-24 18:26:40 +0100 | [diff] [blame] | 260 | unsigned reset:1; | 
| David Vrabel | 7e6133a | 2008-09-17 16:34:28 +0100 | [diff] [blame] | 261 | struct urb *pause_after_urb; | 
|  | 262 | struct completion remove_complete; | 
| David Vrabel | 294a39e | 2009-08-24 15:02:27 +0100 | [diff] [blame] | 263 | uint16_t max_packet; | 
|  | 264 | uint8_t max_burst; | 
|  | 265 | uint8_t max_seq; | 
| David Vrabel | 7e6133a | 2008-09-17 16:34:28 +0100 | [diff] [blame] | 266 | }; | 
|  | 267 |  | 
|  | 268 | static inline void whc_qset_set_link_ptr(u64 *ptr, u64 target) | 
|  | 269 | { | 
|  | 270 | if (target) | 
|  | 271 | *ptr = (*ptr & ~(QH_LINK_PTR_MASK | QH_LINK_T)) | QH_LINK_PTR(target); | 
|  | 272 | else | 
|  | 273 | *ptr = QH_LINK_T; | 
|  | 274 | } | 
|  | 275 |  | 
|  | 276 | /** | 
|  | 277 | * struct di_buf_entry - Device Information (DI) buffer entry. | 
|  | 278 | * | 
|  | 279 | * There's one of these per connected device. | 
|  | 280 | */ | 
|  | 281 | struct di_buf_entry { | 
|  | 282 | __le32 availability_info[8]; /*< MAS availability information, one MAS per bit */ | 
|  | 283 | __le32 addr_sec_info;        /*< addressing and security info */ | 
|  | 284 | __le32 reserved[7]; | 
|  | 285 | } __attribute__((packed)); | 
|  | 286 |  | 
|  | 287 | #define WHC_DI_SECURE           (1 << 31) | 
|  | 288 | #define WHC_DI_DISABLE          (1 << 30) | 
|  | 289 | #define WHC_DI_KEY_IDX(k)       ((k) << 8) | 
|  | 290 | #define WHC_DI_KEY_IDX_MASK     0x0000ff00 | 
|  | 291 | #define WHC_DI_DEV_ADDR(a)      ((a) << 0) | 
|  | 292 | #define WHC_DI_DEV_ADDR_MASK    0x000000ff | 
|  | 293 |  | 
|  | 294 | /** | 
|  | 295 | * struct dn_buf_entry - Device Notification (DN) buffer entry. | 
|  | 296 | * | 
|  | 297 | * [WHCI] section 3.2.8 | 
|  | 298 | */ | 
|  | 299 | struct dn_buf_entry { | 
|  | 300 | __u8   msg_size;    /*< number of octets of valid DN data */ | 
|  | 301 | __u8   reserved1; | 
|  | 302 | __u8   src_addr;    /*< source address */ | 
|  | 303 | __u8   status;      /*< buffer entry status */ | 
|  | 304 | __le32 tkid;        /*< TKID for source device, valid if secure bit is set */ | 
|  | 305 | __u8   dn_data[56]; /*< up to 56 octets of DN data */ | 
|  | 306 | } __attribute__((packed)); | 
|  | 307 |  | 
|  | 308 | #define WHC_DN_STATUS_VALID  (1 << 7) /* buffer entry is valid */ | 
|  | 309 | #define WHC_DN_STATUS_SECURE (1 << 6) /* notification received using secure frame */ | 
|  | 310 |  | 
|  | 311 | #define WHC_N_DN_ENTRIES (4096 / sizeof(struct dn_buf_entry)) | 
|  | 312 |  | 
|  | 313 | /* The Add MMC IE WUSB Generic Command may take up to 256 bytes of | 
|  | 314 | data. [WHCI] section 2.4.7. */ | 
|  | 315 | #define WHC_GEN_CMD_DATA_LEN 256 | 
|  | 316 |  | 
|  | 317 | /* | 
|  | 318 | * HC registers. | 
|  | 319 | * | 
|  | 320 | * [WHCI] section 2.4 | 
|  | 321 | */ | 
|  | 322 |  | 
|  | 323 | #define WHCIVERSION          0x00 | 
|  | 324 |  | 
|  | 325 | #define WHCSPARAMS           0x04 | 
|  | 326 | #  define WHCSPARAMS_TO_N_MMC_IES(p) (((p) >> 16) & 0xff) | 
|  | 327 | #  define WHCSPARAMS_TO_N_KEYS(p)    (((p) >> 8) & 0xff) | 
|  | 328 | #  define WHCSPARAMS_TO_N_DEVICES(p) (((p) >> 0) & 0x7f) | 
|  | 329 |  | 
|  | 330 | #define WUSBCMD              0x08 | 
|  | 331 | #  define WUSBCMD_BCID(b)            ((b) << 16) | 
|  | 332 | #  define WUSBCMD_BCID_MASK          (0xff << 16) | 
|  | 333 | #  define WUSBCMD_ASYNC_QSET_RM      (1 << 12) | 
|  | 334 | #  define WUSBCMD_PERIODIC_QSET_RM   (1 << 11) | 
|  | 335 | #  define WUSBCMD_WUSBSI(s)          ((s) << 8) | 
|  | 336 | #  define WUSBCMD_WUSBSI_MASK        (0x7 << 8) | 
|  | 337 | #  define WUSBCMD_ASYNC_SYNCED_DB    (1 << 7) | 
|  | 338 | #  define WUSBCMD_PERIODIC_SYNCED_DB (1 << 6) | 
|  | 339 | #  define WUSBCMD_ASYNC_UPDATED      (1 << 5) | 
|  | 340 | #  define WUSBCMD_PERIODIC_UPDATED   (1 << 4) | 
|  | 341 | #  define WUSBCMD_ASYNC_EN           (1 << 3) | 
|  | 342 | #  define WUSBCMD_PERIODIC_EN        (1 << 2) | 
|  | 343 | #  define WUSBCMD_WHCRESET           (1 << 1) | 
|  | 344 | #  define WUSBCMD_RUN                (1 << 0) | 
|  | 345 |  | 
|  | 346 | #define WUSBSTS              0x0c | 
|  | 347 | #  define WUSBSTS_ASYNC_SCHED             (1 << 15) | 
|  | 348 | #  define WUSBSTS_PERIODIC_SCHED          (1 << 14) | 
|  | 349 | #  define WUSBSTS_DNTS_SCHED              (1 << 13) | 
|  | 350 | #  define WUSBSTS_HCHALTED                (1 << 12) | 
|  | 351 | #  define WUSBSTS_GEN_CMD_DONE            (1 << 9) | 
|  | 352 | #  define WUSBSTS_CHAN_TIME_ROLLOVER      (1 << 8) | 
|  | 353 | #  define WUSBSTS_DNTS_OVERFLOW           (1 << 7) | 
|  | 354 | #  define WUSBSTS_BPST_ADJUSTMENT_CHANGED (1 << 6) | 
|  | 355 | #  define WUSBSTS_HOST_ERR                (1 << 5) | 
|  | 356 | #  define WUSBSTS_ASYNC_SCHED_SYNCED      (1 << 4) | 
|  | 357 | #  define WUSBSTS_PERIODIC_SCHED_SYNCED   (1 << 3) | 
|  | 358 | #  define WUSBSTS_DNTS_INT                (1 << 2) | 
|  | 359 | #  define WUSBSTS_ERR_INT                 (1 << 1) | 
|  | 360 | #  define WUSBSTS_INT                     (1 << 0) | 
|  | 361 | #  define WUSBSTS_INT_MASK                0x3ff | 
|  | 362 |  | 
|  | 363 | #define WUSBINTR             0x10 | 
|  | 364 | #  define WUSBINTR_GEN_CMD_DONE             (1 << 9) | 
|  | 365 | #  define WUSBINTR_CHAN_TIME_ROLLOVER       (1 << 8) | 
|  | 366 | #  define WUSBINTR_DNTS_OVERFLOW            (1 << 7) | 
|  | 367 | #  define WUSBINTR_BPST_ADJUSTMENT_CHANGED  (1 << 6) | 
|  | 368 | #  define WUSBINTR_HOST_ERR                 (1 << 5) | 
|  | 369 | #  define WUSBINTR_ASYNC_SCHED_SYNCED       (1 << 4) | 
|  | 370 | #  define WUSBINTR_PERIODIC_SCHED_SYNCED    (1 << 3) | 
|  | 371 | #  define WUSBINTR_DNTS_INT                 (1 << 2) | 
|  | 372 | #  define WUSBINTR_ERR_INT                  (1 << 1) | 
|  | 373 | #  define WUSBINTR_INT                      (1 << 0) | 
|  | 374 | #  define WUSBINTR_ALL 0x3ff | 
|  | 375 |  | 
|  | 376 | #define WUSBGENCMDSTS        0x14 | 
|  | 377 | #  define WUSBGENCMDSTS_ACTIVE (1 << 31) | 
|  | 378 | #  define WUSBGENCMDSTS_ERROR  (1 << 24) | 
|  | 379 | #  define WUSBGENCMDSTS_IOC    (1 << 23) | 
|  | 380 | #  define WUSBGENCMDSTS_MMCIE_ADD 0x01 | 
|  | 381 | #  define WUSBGENCMDSTS_MMCIE_RM  0x02 | 
|  | 382 | #  define WUSBGENCMDSTS_SET_MAS   0x03 | 
|  | 383 | #  define WUSBGENCMDSTS_CHAN_STOP 0x04 | 
|  | 384 | #  define WUSBGENCMDSTS_RWP_EN    0x05 | 
|  | 385 |  | 
|  | 386 | #define WUSBGENCMDPARAMS     0x18 | 
|  | 387 | #define WUSBGENADDR          0x20 | 
|  | 388 | #define WUSBASYNCLISTADDR    0x28 | 
|  | 389 | #define WUSBDNTSBUFADDR      0x30 | 
|  | 390 | #define WUSBDEVICEINFOADDR   0x38 | 
|  | 391 |  | 
|  | 392 | #define WUSBSETSECKEYCMD     0x40 | 
|  | 393 | #  define WUSBSETSECKEYCMD_SET    (1 << 31) | 
|  | 394 | #  define WUSBSETSECKEYCMD_ERASE  (1 << 30) | 
|  | 395 | #  define WUSBSETSECKEYCMD_GTK    (1 << 8) | 
|  | 396 | #  define WUSBSETSECKEYCMD_IDX(i) ((i) << 0) | 
|  | 397 |  | 
|  | 398 | #define WUSBTKID             0x44 | 
|  | 399 | #define WUSBSECKEY           0x48 | 
|  | 400 | #define WUSBPERIODICLISTBASE 0x58 | 
|  | 401 | #define WUSBMASINDEX         0x60 | 
|  | 402 |  | 
|  | 403 | #define WUSBDNTSCTRL         0x64 | 
|  | 404 | #  define WUSBDNTSCTRL_ACTIVE      (1 << 31) | 
|  | 405 | #  define WUSBDNTSCTRL_INTERVAL(i) ((i) << 8) | 
|  | 406 | #  define WUSBDNTSCTRL_SLOTS(s)    ((s) << 0) | 
|  | 407 |  | 
|  | 408 | #define WUSBTIME             0x68 | 
| David Vrabel | 4d2bea4 | 2008-10-27 15:42:31 +0000 | [diff] [blame] | 409 | #  define WUSBTIME_CHANNEL_TIME_MASK 0x00ffffff | 
|  | 410 |  | 
| David Vrabel | 7e6133a | 2008-09-17 16:34:28 +0100 | [diff] [blame] | 411 | #define WUSBBPST             0x6c | 
|  | 412 | #define WUSBDIBUPDATED       0x70 | 
|  | 413 |  | 
|  | 414 | #endif /* #ifndef _WHCI_WHCI_HC_H */ |