2 * Wireless Host Controller (WHC) data structures.
4 * Copyright (C) 2007 Cambridge Silicon Radio Ltd.
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.
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.
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
20 #ifndef _WHCI_WHCI_HC_H
21 #define _WHCI_WHCI_HC_H
23 #include <linux/list.h>
26 * WHCI_PAGE_SIZE - page size use by WHCI
28 * WHCI assumes that host system uses pages of 4096 octets.
30 #define WHCI_PAGE_SIZE 4096
34 * QTD_MAX_TXFER_SIZE - max number of bytes to transfer with a single
39 #define QTD_MAX_XFER_SIZE 1048575
43 * struct whc_qtd - Queue Element Transfer Descriptors (qTD)
45 * This describes the data for a bulk, control or interrupt transfer.
47 * [WHCI] section 3.2.4
50 __le32 status
; /*< remaining transfer len and transfer status */
52 __le64 page_list_ptr
; /*< physical pointer to data buffer page list*/
53 __u8 setup
[8]; /*< setup data for control transfers */
54 } __attribute__((packed
));
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)
68 #define QTD_OPT_IOC (1 << 1) /* page_list_ptr points to buffer directly */
69 #define QTD_OPT_SMALL (1 << 0) /* interrupt on complete */
72 * struct whc_itd - Isochronous Queue Element Transfer Descriptors (iTD)
74 * This describes the data and other parameters for an isochronous
77 * [WHCI] section 3.2.5
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
));
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 */
93 #define ITD_OPT_IOC (1 << 1) /* interrupt on complete */
94 #define ITD_OPT_SMALL (1 << 0) /* page_list_ptr points to buffer directly */
99 * A TD's page list must contain sufficient page list entries for the
100 * total data length in the TD.
102 * [WHCI] section 3.2.4.3
104 struct whc_page_list_entry
{
105 __le64 buf_ptr
; /*< physical pointer to buffer */
106 } __attribute__((packed
));
109 * struct whc_seg_list_entry - Segment list entry.
111 * Describes a portion of the data buffer described in the containing
114 * seg_ptr = qtd->page_list_ptr[qtd->seg_list_ptr[seg].idx].buf_ptr
115 * + qtd->seg_list_ptr[seg].offset;
117 * Segments can't cross page boundries.
119 * [WHCI] section 3.2.5.5
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
));
129 * struct whc_qhead - endpoint and status information for a qset.
131 * [WHCI] section 3.2.6
134 __le64 link
; /*< next qset in list */
139 __le16 err_count
; /*< transaction error count */
141 __le32 scratch
[3]; /*< h/w scratch area */
146 } __attribute__((packed
));
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 */
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 */
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) */
175 #define QH_INFO3_TX_RATE_53_3 (0 << 24)
176 #define QH_INFO3_TX_RATE_80 (1 << 24)
177 #define QH_INFO3_TX_RATE_106_7 (2 << 24)
178 #define QH_INFO3_TX_RATE_160 (3 << 24)
179 #define QH_INFO3_TX_RATE_200 (4 << 24)
180 #define QH_INFO3_TX_RATE_320 (5 << 24)
181 #define QH_INFO3_TX_RATE_400 (6 << 24)
182 #define QH_INFO3_TX_RATE_480 (7 << 24)
183 #define QH_INFO3_TX_PWR(p) ((p) << 29) /* transmit power (see [WUSB] section 5.2.1.2) */
185 #define QH_STATUS_FLOW_CTRL (1 << 15)
186 #define QH_STATUS_ICUR(i) ((i) << 5)
187 #define QH_STATUS_TO_ICUR(s) (((s) >> 5) & 0x7)
188 #define QH_STATUS_SEQ_MASK 0x1f
191 * usb_pipe_to_qh_type - USB core pipe type to QH transfer type
193 * Returns the QH type field for a USB core pipe type.
195 static inline unsigned usb_pipe_to_qh_type(unsigned pipe
)
197 static const unsigned type
[] = {
198 [PIPE_ISOCHRONOUS
] = QH_INFO1_TR_TYPE_ISOC
,
199 [PIPE_INTERRUPT
] = QH_INFO1_TR_TYPE_INT
,
200 [PIPE_CONTROL
] = QH_INFO1_TR_TYPE_CTRL
,
201 [PIPE_BULK
] = QH_INFO1_TR_TYPE_BULK
,
203 return type
[usb_pipetype(pipe
)];
207 * Maxiumum number of TDs in a qset.
209 #define WHCI_QSET_TD_MAX 8
212 * struct whc_qset - WUSB data transfers to a specific endpoint
213 * @qh: the QHead of this qset
214 * @qtd: up to 8 qTDs (for qsets for control, bulk and interrupt
216 * @itd: up to 8 iTDs (for qsets for isochronous transfers)
217 * @qset_dma: DMA address for this qset
218 * @whc: WHCI HC this qset is for
220 * @stds: list of sTDs queued to this qset
221 * @ntds: number of qTDs queued (not necessarily the same as nTDs
223 * @td_start: index of the first qTD in the list
224 * @td_end: index of next free qTD in the list (provided
225 * ntds < WHCI_QSET_TD_MAX)
227 * Queue Sets (qsets) are added to the asynchronous schedule list
228 * (ASL) or the periodic zone list (PZL).
230 * qsets may contain up to 8 TDs (either qTDs or iTDs as appropriate).
231 * Each TD may refer to at most 1 MiB of data. If a single transfer
232 * has > 8MiB of data, TDs can be reused as they are completed since
233 * the TD list is used as a circular buffer. Similarly, several
234 * (smaller) transfers may be queued in a qset.
236 * WHCI controllers may cache portions of the qsets in the ASL and
237 * PZL, requiring the WHCD to inform the WHC that the lists have been
238 * updated (fields changed or qsets inserted or removed). For safe
239 * insertion and removal of qsets from the lists the schedule must be
240 * stopped to avoid races in updating the QH link pointers.
242 * Since the HC is free to execute qsets in any order, all transfers
243 * to an endpoint should use the same qset to ensure transfers are
244 * executed in the order they're submitted.
246 * [WHCI] section 3.2.3
251 struct whc_qtd qtd
[WHCI_QSET_TD_MAX
];
252 struct whc_itd itd
[WHCI_QSET_TD_MAX
];
255 /* private data for WHCD */
258 struct usb_host_endpoint
*ep
;
259 struct list_head stds
;
263 struct list_head list_node
;
264 unsigned in_sw_list
:1;
265 unsigned in_hw_list
:1;
268 struct urb
*pause_after_urb
;
269 struct completion remove_complete
;
274 static inline void whc_qset_set_link_ptr(u64
*ptr
, u64 target
)
277 *ptr
= (*ptr
& ~(QH_LINK_PTR_MASK
| QH_LINK_T
)) | QH_LINK_PTR(target
);
283 * struct di_buf_entry - Device Information (DI) buffer entry.
285 * There's one of these per connected device.
287 struct di_buf_entry
{
288 __le32 availability_info
[8]; /*< MAS availability information, one MAS per bit */
289 __le32 addr_sec_info
; /*< addressing and security info */
291 } __attribute__((packed
));
293 #define WHC_DI_SECURE (1 << 31)
294 #define WHC_DI_DISABLE (1 << 30)
295 #define WHC_DI_KEY_IDX(k) ((k) << 8)
296 #define WHC_DI_KEY_IDX_MASK 0x0000ff00
297 #define WHC_DI_DEV_ADDR(a) ((a) << 0)
298 #define WHC_DI_DEV_ADDR_MASK 0x000000ff
301 * struct dn_buf_entry - Device Notification (DN) buffer entry.
303 * [WHCI] section 3.2.8
305 struct dn_buf_entry
{
306 __u8 msg_size
; /*< number of octets of valid DN data */
308 __u8 src_addr
; /*< source address */
309 __u8 status
; /*< buffer entry status */
310 __le32 tkid
; /*< TKID for source device, valid if secure bit is set */
311 __u8 dn_data
[56]; /*< up to 56 octets of DN data */
312 } __attribute__((packed
));
314 #define WHC_DN_STATUS_VALID (1 << 7) /* buffer entry is valid */
315 #define WHC_DN_STATUS_SECURE (1 << 6) /* notification received using secure frame */
317 #define WHC_N_DN_ENTRIES (4096 / sizeof(struct dn_buf_entry))
319 /* The Add MMC IE WUSB Generic Command may take up to 256 bytes of
320 data. [WHCI] section 2.4.7. */
321 #define WHC_GEN_CMD_DATA_LEN 256
329 #define WHCIVERSION 0x00
331 #define WHCSPARAMS 0x04
332 # define WHCSPARAMS_TO_N_MMC_IES(p) (((p) >> 16) & 0xff)
333 # define WHCSPARAMS_TO_N_KEYS(p) (((p) >> 8) & 0xff)
334 # define WHCSPARAMS_TO_N_DEVICES(p) (((p) >> 0) & 0x7f)
337 # define WUSBCMD_BCID(b) ((b) << 16)
338 # define WUSBCMD_BCID_MASK (0xff << 16)
339 # define WUSBCMD_ASYNC_QSET_RM (1 << 12)
340 # define WUSBCMD_PERIODIC_QSET_RM (1 << 11)
341 # define WUSBCMD_WUSBSI(s) ((s) << 8)
342 # define WUSBCMD_WUSBSI_MASK (0x7 << 8)
343 # define WUSBCMD_ASYNC_SYNCED_DB (1 << 7)
344 # define WUSBCMD_PERIODIC_SYNCED_DB (1 << 6)
345 # define WUSBCMD_ASYNC_UPDATED (1 << 5)
346 # define WUSBCMD_PERIODIC_UPDATED (1 << 4)
347 # define WUSBCMD_ASYNC_EN (1 << 3)
348 # define WUSBCMD_PERIODIC_EN (1 << 2)
349 # define WUSBCMD_WHCRESET (1 << 1)
350 # define WUSBCMD_RUN (1 << 0)
353 # define WUSBSTS_ASYNC_SCHED (1 << 15)
354 # define WUSBSTS_PERIODIC_SCHED (1 << 14)
355 # define WUSBSTS_DNTS_SCHED (1 << 13)
356 # define WUSBSTS_HCHALTED (1 << 12)
357 # define WUSBSTS_GEN_CMD_DONE (1 << 9)
358 # define WUSBSTS_CHAN_TIME_ROLLOVER (1 << 8)
359 # define WUSBSTS_DNTS_OVERFLOW (1 << 7)
360 # define WUSBSTS_BPST_ADJUSTMENT_CHANGED (1 << 6)
361 # define WUSBSTS_HOST_ERR (1 << 5)
362 # define WUSBSTS_ASYNC_SCHED_SYNCED (1 << 4)
363 # define WUSBSTS_PERIODIC_SCHED_SYNCED (1 << 3)
364 # define WUSBSTS_DNTS_INT (1 << 2)
365 # define WUSBSTS_ERR_INT (1 << 1)
366 # define WUSBSTS_INT (1 << 0)
367 # define WUSBSTS_INT_MASK 0x3ff
369 #define WUSBINTR 0x10
370 # define WUSBINTR_GEN_CMD_DONE (1 << 9)
371 # define WUSBINTR_CHAN_TIME_ROLLOVER (1 << 8)
372 # define WUSBINTR_DNTS_OVERFLOW (1 << 7)
373 # define WUSBINTR_BPST_ADJUSTMENT_CHANGED (1 << 6)
374 # define WUSBINTR_HOST_ERR (1 << 5)
375 # define WUSBINTR_ASYNC_SCHED_SYNCED (1 << 4)
376 # define WUSBINTR_PERIODIC_SCHED_SYNCED (1 << 3)
377 # define WUSBINTR_DNTS_INT (1 << 2)
378 # define WUSBINTR_ERR_INT (1 << 1)
379 # define WUSBINTR_INT (1 << 0)
380 # define WUSBINTR_ALL 0x3ff
382 #define WUSBGENCMDSTS 0x14
383 # define WUSBGENCMDSTS_ACTIVE (1 << 31)
384 # define WUSBGENCMDSTS_ERROR (1 << 24)
385 # define WUSBGENCMDSTS_IOC (1 << 23)
386 # define WUSBGENCMDSTS_MMCIE_ADD 0x01
387 # define WUSBGENCMDSTS_MMCIE_RM 0x02
388 # define WUSBGENCMDSTS_SET_MAS 0x03
389 # define WUSBGENCMDSTS_CHAN_STOP 0x04
390 # define WUSBGENCMDSTS_RWP_EN 0x05
392 #define WUSBGENCMDPARAMS 0x18
393 #define WUSBGENADDR 0x20
394 #define WUSBASYNCLISTADDR 0x28
395 #define WUSBDNTSBUFADDR 0x30
396 #define WUSBDEVICEINFOADDR 0x38
398 #define WUSBSETSECKEYCMD 0x40
399 # define WUSBSETSECKEYCMD_SET (1 << 31)
400 # define WUSBSETSECKEYCMD_ERASE (1 << 30)
401 # define WUSBSETSECKEYCMD_GTK (1 << 8)
402 # define WUSBSETSECKEYCMD_IDX(i) ((i) << 0)
404 #define WUSBTKID 0x44
405 #define WUSBSECKEY 0x48
406 #define WUSBPERIODICLISTBASE 0x58
407 #define WUSBMASINDEX 0x60
409 #define WUSBDNTSCTRL 0x64
410 # define WUSBDNTSCTRL_ACTIVE (1 << 31)
411 # define WUSBDNTSCTRL_INTERVAL(i) ((i) << 8)
412 # define WUSBDNTSCTRL_SLOTS(s) ((s) << 0)
414 #define WUSBTIME 0x68
415 # define WUSBTIME_CHANNEL_TIME_MASK 0x00ffffff
417 #define WUSBBPST 0x6c
418 #define WUSBDIBUPDATED 0x70
420 #endif /* #ifndef _WHCI_WHCI_HC_H */