Linux Kernel  3.7.1
 All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Macros Groups Pages
whci-hc.h
Go to the documentation of this file.
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 
30 #define WHCI_PAGE_SIZE 4096
31 
32 
39 #define QTD_MAX_XFER_SIZE 1048575
40 
41 
49 struct whc_qtd {
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));
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 
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 
105  __le64 buf_ptr; /*< physical pointer to buffer */
106 } __attribute__((packed));
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));
133 struct whc_qhead {
134  __le64 link; /*< next qset in list */
139  __le16 err_count; /*< transaction error count */
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));
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 */
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 
175 #define QH_INFO3_TX_RATE(r) ((r) << 24) /* PHY rate (see [ECMA-368] section 10.3.1.1) */
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)
181 #define QH_STATUS_SEQ_MASK 0x1f
182 
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 
202 #define WHCI_QSET_TD_MAX 8
203 
241 struct whc_qset {
242  struct whc_qhead qh;
243  union {
246  };
247 
248  /* private data for WHCD */
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;
257  unsigned in_sw_list:1;
258  unsigned in_hw_list:1;
259  unsigned remove:1;
260  unsigned reset:1;
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 
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 */
285 } __attribute__((packed));
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 
299 struct dn_buf_entry {
300  __u8 msg_size; /*< number of octets of valid DN data */
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));
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))
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
409 # define WUSBTIME_CHANNEL_TIME_MASK 0x00ffffff
410 
411 #define WUSBBPST 0x6c
412 #define WUSBDIBUPDATED 0x70
413 
414 #endif /* #ifndef _WHCI_WHCI_HC_H */