2 * bdc.h - header for the BRCM BDC USB3.0 device controller
4 * Copyright (C) 2014 Broadcom Corporation
6 * Author: Ashwini Pahuja
8 * This program is free software; you can redistribute it and/or modify it
9 * under the terms of the GNU General Public License as published by the
10 * Free Software Foundation; either version 2 of the License, or (at your
11 * option) any later version.
15 #ifndef __LINUX_BDC_H__
16 #define __LINUX_BDC_H__
18 #include <linux/kernel.h>
19 #include <linux/usb.h>
20 #include <linux/device.h>
21 #include <linux/spinlock.h>
22 #include <linux/list.h>
23 #include <linux/dma-mapping.h>
25 #include <linux/debugfs.h>
26 #include <linux/usb/ch9.h>
27 #include <linux/usb/gadget.h>
28 #include <asm/unaligned.h>
30 #define BRCM_BDC_NAME "bdc_usb3"
31 #define BRCM_BDC_DESC "BDC device controller driver"
33 #define DMA_ADDR_INVALID (~(dma_addr_t)0)
35 /* BDC command operation timeout in usec*/
36 #define BDC_CMD_TIMEOUT 1000
37 /* BDC controller operation timeout in usec*/
38 #define BDC_COP_TIMEOUT 500
41 * Maximum size of ep0 response buffer for ch9 requests,
42 * the set_sel request uses 6 so far, the max.
44 #define EP0_RESPONSE_BUFF 6
45 /* Start with SS as default */
46 #define EP0_MAX_PKT_SIZE 512
48 /* 64 entries in a SRR */
49 #define NUM_SR_ENTRIES 64
51 /* Num of bds per table */
52 #define NUM_BDS_PER_TABLE 32
54 /* Num of tables in bd list for control,bulk and Int ep */
57 /* Num of tables in bd list for Isoch ep */
58 #define NUM_TABLES_ISOCH 6
60 /* U1 Timeout default: 248usec */
61 #define U1_TIMEOUT 0xf8
63 /* Interrupt coalescence in usec */
66 /* Register offsets */
67 /* Configuration and Capability registers */
68 #define BDC_BDCCFG0 0x00
69 #define BDC_BDCCFG1 0x04
70 #define BDC_BDCCAP0 0x08
71 #define BDC_BDCCAP1 0x0c
72 #define BDC_CMDPAR0 0x10
73 #define BDC_CMDPAR1 0x14
74 #define BDC_CMDPAR2 0x18
75 #define BDC_CMDSC 0x1c
77 #define BDC_USPPMS 0x28
78 #define BDC_USPPM2 0x2c
79 #define BDC_SPBBAL 0x38
80 #define BDC_SPBBAH 0x3c
81 #define BDC_BDCSC 0x40
82 #define BDC_XSFNTF 0x4c
84 #define BDC_DVCSA 0x50
85 #define BDC_DVCSB 0x54
86 #define BDC_EPSTS0(n) (0x60 + (n * 0x10))
87 #define BDC_EPSTS1(n) (0x64 + (n * 0x10))
88 #define BDC_EPSTS2(n) (0x68 + (n * 0x10))
89 #define BDC_EPSTS3(n) (0x6c + (n * 0x10))
90 #define BDC_EPSTS4(n) (0x70 + (n * 0x10))
91 #define BDC_EPSTS5(n) (0x74 + (n * 0x10))
92 #define BDC_EPSTS6(n) (0x78 + (n * 0x10))
93 #define BDC_EPSTS7(n) (0x7c + (n * 0x10))
94 #define BDC_SRRBAL(n) (0x200 + (n * 0x10))
95 #define BDC_SRRBAH(n) (0x204 + (n * 0x10))
96 #define BDC_SRRINT(n) (0x208 + (n * 0x10))
97 #define BDC_INTCTLS(n) (0x20c + (n * 0x10))
99 /* Extended capability regs */
100 #define BDC_FSCNOC 0xcd4
101 #define BDC_FSCNIC 0xce4
102 #define NUM_NCS(p) (p >> 28)
104 /* Register bit fields and Masks */
105 /* BDC Configuration 0 */
106 #define BDC_PGS(p) (((p) & (0x7 << 8)) >> 8)
107 #define BDC_SPB(p) (p & 0x7)
109 /* BDC Capability1 */
110 #define BDC_P64 (1 << 0)
112 /* BDC Command register */
113 #define BDC_CMD_FH 0xe
114 #define BDC_CMD_DNC 0x6
115 #define BDC_CMD_EPO 0x4
116 #define BDC_CMD_BLA 0x3
117 #define BDC_CMD_EPC 0x2
118 #define BDC_CMD_DVC 0x1
119 #define BDC_CMD_CWS (0x1 << 5)
120 #define BDC_CMD_CST(p) (((p) & (0xf << 6))>>6)
121 #define BDC_CMD_EPN(p) ((p & 0x1f) << 10)
122 #define BDC_SUB_CMD_ADD (0x1 << 17)
123 #define BDC_SUB_CMD_FWK (0x4 << 17)
124 /* Reset sequence number */
125 #define BDC_CMD_EPO_RST_SN (0x1 << 16)
126 #define BDC_CMD_EP0_XSD (0x1 << 16)
127 #define BDC_SUB_CMD_ADD_EP (0x1 << 17)
128 #define BDC_SUB_CMD_DRP_EP (0x2 << 17)
129 #define BDC_SUB_CMD_EP_STP (0x2 << 17)
130 #define BDC_SUB_CMD_EP_STL (0x4 << 17)
131 #define BDC_SUB_CMD_EP_RST (0x1 << 17)
132 #define BDC_CMD_SRD (1 << 27)
134 /* CMD completion status */
135 #define BDC_CMDS_SUCC 0x1
136 #define BDC_CMDS_PARA 0x3
137 #define BDC_CMDS_STAT 0x4
138 #define BDC_CMDS_FAIL 0x5
139 #define BDC_CMDS_INTL 0x6
140 #define BDC_CMDS_BUSY 0xf
142 /* CMDSC Param 2 shifts */
149 #define BDC_VBC (1 << 31)
150 #define BDC_PRC (1 << 30)
151 #define BDC_PCE (1 << 29)
152 #define BDC_CFC (1 << 28)
153 #define BDC_PCC (1 << 27)
154 #define BDC_PSC (1 << 26)
155 #define BDC_VBS (1 << 25)
156 #define BDC_PRS (1 << 24)
157 #define BDC_PCS (1 << 23)
158 #define BDC_PSP(p) (((p) & (0x7 << 20))>>20)
159 #define BDC_SCN (1 << 8)
160 #define BDC_SDC (1 << 7)
161 #define BDC_SWS (1 << 4)
163 #define BDC_USPSC_RW (BDC_SCN|BDC_SDC|BDC_SWS|0xf)
164 #define BDC_PSP(p) (((p) & (0x7 << 20))>>20)
166 #define BDC_SPEED_FS 0x1
167 #define BDC_SPEED_LS 0x2
168 #define BDC_SPEED_HS 0x3
169 #define BDC_SPEED_SS 0x4
171 #define BDC_PST(p) (p & 0xf)
172 #define BDC_PST_MASK 0xf
175 #define BDC_U2E (0x1 << 31)
176 #define BDC_U1E (0x1 << 30)
177 #define BDC_U2A (0x1 << 29)
178 #define BDC_PORT_W1S (0x1 << 17)
179 #define BDC_U1T(p) ((p) & 0xff)
180 #define BDC_U2T(p) (((p) & 0xff) << 8)
181 #define BDC_U1T_MASK 0xff
184 /* Hardware LPM Enable */
185 #define BDC_HLE (1 << 16)
187 /* BDC Status and Control */
188 #define BDC_COP_RST (1 << 29)
189 #define BDC_COP_RUN (2 << 29)
190 #define BDC_COP_STP (4 << 29)
192 #define BDC_COP_MASK (BDC_COP_RST|BDC_COP_RUN|BDC_COP_STP)
194 #define BDC_COS (1 << 28)
195 #define BDC_CSTS(p) (((p) & (0x7 << 20)) >> 20)
196 #define BDC_MASK_MCW (1 << 7)
197 #define BDC_GIE (1 << 1)
198 #define BDC_GIP (1 << 0)
204 /* Buffer descriptor and Status report bit fields and masks */
205 #define BD_TYPE_BITMASK (0xf)
208 #define BD_TFS_SHIFT 4
209 #define BD_SOT (1 << 26)
210 #define BD_EOT (1 << 27)
211 #define BD_ISP (1 << 29)
212 #define BD_IOC (1 << 30)
213 #define BD_SBF (1 << 31)
215 #define BD_INTR_TARGET(p) (((p) & 0x1f) << 27)
217 #define BDC_SRR_RWS (1 << 4)
218 #define BDC_SRR_RST (1 << 3)
219 #define BDC_SRR_ISR (1 << 2)
220 #define BDC_SRR_IE (1 << 1)
221 #define BDC_SRR_IP (1 << 0)
222 #define BDC_SRR_EPI(p) (((p) & (0xff << 24)) >> 24)
223 #define BDC_SRR_DPI(p) (((p) & (0xff << 16)) >> 16)
224 #define BDC_SRR_DPI_MASK 0x00ff0000
226 #define MARK_CHAIN_BD (BD_CHAIN|BD_EOT|BD_SOT)
228 /* Control transfer BD specific fields */
229 #define BD_DIR_IN (1 << 25)
231 #define BDC_PTC_MASK 0xf0000000
233 /* status report defines */
236 #define SR_BD_LEN(p) (p & 0xffffff)
239 #define XSF_SHORT 0x3
241 #define XSF_SETUP_RECV 0x6
242 #define XSF_DATA_START 0x7
243 #define XSF_STATUS_START 0x8
245 #define XSF_STS(p) (((p) >> 28) & 0xf)
247 /* Transfer BD fields */
248 #define BD_LEN(p) ((p) & 0x1ffff)
249 #define BD_LTF (1 << 25)
250 #define BD_TYPE_DS 0x1
251 #define BD_TYPE_SS 0x2
253 #define BDC_EP_ENABLED (1 << 0)
254 #define BDC_EP_STALL (1 << 1)
255 #define BDC_EP_STOP (1 << 2)
257 /* One BD can transfer max 65536 bytes */
258 #define BD_MAX_BUFF_SIZE (1 << 16)
259 /* Maximum bytes in one XFR, Refer to BDC spec */
260 #define MAX_XFR_LEN 16777215
262 /* defines for Force Header command */
263 #define DEV_NOTF_TYPE 6
264 #define FWK_SUBTYPE 1
267 #define to_bdc_ep(e) container_of(e, struct bdc_ep, usb_ep)
268 #define to_bdc_req(r) container_of(r, struct bdc_req, usb_req)
269 #define gadget_to_bdc(g) container_of(g, struct bdc, gadget)
271 /* FUNCTION WAKE DEV NOTIFICATION interval, USB3 spec table 8.13 */
272 #define BDC_TNOTIFY 2500 /*in ms*/
273 /* Devstatus bitfields */
274 #define REMOTE_WAKEUP_ISSUED (1 << 16)
275 #define DEVICE_SUSPENDED (1 << 17)
276 #define FUNC_WAKE_ISSUED (1 << 18)
277 #define REMOTE_WAKE_ENABLE (1 << USB_DEVICE_REMOTE_WAKEUP)
279 /* On disconnect, preserve these bits and clear rest */
280 #define DEVSTATUS_CLEAR (1 << USB_DEVICE_SELF_POWERED)
281 /* Hardware and software Data structures */
283 /* Endpoint bd: buffer descriptor */
288 /* Status report in Status report ring(srr) */
293 /* bd_table: contigous bd's in a table */
295 struct bdc_bd
*start_bd
;
296 /* dma address of start bd of table*/
301 * Each endpoint has a bdl(buffer descriptor list), bdl consists of 1 or more bd
302 * table's chained to each other through a chain bd, every table has equal
303 * number of bds. the software uses bdi(bd index) to refer to particular bd in
307 /* Array of bd table pointers*/
308 struct bd_table
**bd_table_array
;
309 /* How many tables chained to each other */
311 /* Max_bdi = num_tabs * num_bds_table - 1 */
313 /* current enq bdi from sw point of view */
315 /* current deq bdi from sw point of view */
317 /* numbers of bds per table */
323 /* Representation of a transfer, one transfer can have multiple bd's */
328 /* this will be the next hw dqp when this transfer completes */
330 /* number of bds in this transfer */
335 * Representation of a gadget request, every gadget request is contained
339 struct usb_request usb_req
;
340 struct list_head queue
;
342 /* only one Transfer per request */
343 struct bd_transfer bd_xfr
;
347 /* scratchpad buffer needed by bdc hardware */
348 struct bdc_scratchpad
{
354 /* endpoint representation */
356 struct usb_ep usb_ep
;
357 struct list_head queue
;
362 const struct usb_ss_ep_comp_descriptor
*comp_desc
;
363 const struct usb_endpoint_descriptor
*desc
;
366 /* endpoint bd list*/
367 struct bd_list bd_list
;
369 * HW generates extra event for multi bd tranfers, this flag helps in
370 * ignoring the extra event
375 /* bdc cmmand parameter structure */
376 struct bdc_cmd_params
{
382 /* status report ring(srr), currently one srr is supported for entire system */
384 struct bdc_sr
*sr_bds
;
395 WAIT_FOR_STATUS_START
,
396 WAIT_FOR_STATUS_XMIT
,
401 enum bdc_link_state
{
402 BDC_LINK_STATE_U0
= 0x00,
403 BDC_LINK_STATE_U3
= 0x03,
404 BDC_LINK_STATE_RX_DET
= 0x05,
405 BDC_LINK_STATE_RESUME
= 0x0f
408 /* representation of bdc */
410 struct usb_gadget gadget
;
411 struct usb_gadget_driver
*gadget_driver
;
416 /* num of endpoints for a particular instantiation of IP */
417 unsigned int num_eps
;
419 * Array of ep's, it uses the same index covention as bdc hw i.e.
420 * 1 for ep0, 2 for 1out,3 for 1in ....
422 struct bdc_ep
**bdc_ep_array
;
424 struct bdc_scratchpad scratchpad
;
426 /* current driver supports 1 status ring */
428 /* Last received setup packet */
429 struct usb_ctrlrequest setup_pkt
;
430 struct bdc_req ep0_req
;
431 struct bdc_req status_req
;
432 enum bdc_ep0_state ep0_state
;
437 /* Bits 0-15 are standard and 16-31 for proprietary information */
443 struct dma_pool
*bd_table_pool
;
445 /* array of callbacks for various status report handlers */
446 void (*sr_handler
[2])(struct bdc
*, struct bdc_sr
*);
447 /* ep0 callback handlers */
448 void (*sr_xsf_ep0
[3])(struct bdc
*, struct bdc_sr
*);
449 /* ep0 response buffer for ch9 requests like GET_STATUS and SET_SEL */
450 unsigned char ep0_response_buff
[EP0_RESPONSE_BUFF
];
452 * Timer to check if host resumed transfer after bdc sent Func wake
453 * notification packet after a remote wakeup. if not, then resend the
454 * Func Wake packet every 2.5 secs. Refer to USB3 spec section 8.5.6.4
456 struct delayed_work func_wake_notify
;
459 static inline u32
bdc_readl(void __iomem
*base
, u32 offset
)
461 return readl(base
+ offset
);
464 static inline void bdc_writel(void __iomem
*base
, u32 offset
, u32 value
)
466 writel(value
, base
+ offset
);
469 /* Buffer descriptor list operations */
470 void bdc_notify_xfr(struct bdc
*, u32
);
471 void bdc_softconn(struct bdc
*);
472 void bdc_softdisconn(struct bdc
*);
473 int bdc_run(struct bdc
*);
474 int bdc_stop(struct bdc
*);
475 int bdc_reset(struct bdc
*);
476 int bdc_udc_init(struct bdc
*);
477 void bdc_udc_exit(struct bdc
*);
478 int bdc_reinit(struct bdc
*);
480 /* Status report handlers */
481 /* Upstream port status change sr */
482 void bdc_sr_uspc(struct bdc
*, struct bdc_sr
*);
484 void bdc_sr_xsf(struct bdc
*, struct bdc_sr
*);
485 /* EP0 XSF handlers */
486 void bdc_xsf_ep0_setup_recv(struct bdc
*, struct bdc_sr
*);
487 void bdc_xsf_ep0_data_start(struct bdc
*, struct bdc_sr
*);
488 void bdc_xsf_ep0_status_start(struct bdc
*, struct bdc_sr
*);
490 #endif /* __LINUX_BDC_H__ */