bdc.h (12346B)
1/* SPDX-License-Identifier: GPL-2.0+ */ 2/* 3 * bdc.h - header for the BRCM BDC USB3.0 device controller 4 * 5 * Copyright (C) 2014 Broadcom Corporation 6 * 7 * Author: Ashwini Pahuja 8 */ 9 10#ifndef __LINUX_BDC_H__ 11#define __LINUX_BDC_H__ 12 13#include <linux/kernel.h> 14#include <linux/usb.h> 15#include <linux/device.h> 16#include <linux/spinlock.h> 17#include <linux/list.h> 18#include <linux/dma-mapping.h> 19#include <linux/mm.h> 20#include <linux/debugfs.h> 21#include <linux/usb/ch9.h> 22#include <linux/usb/gadget.h> 23#include <asm/unaligned.h> 24 25#define BRCM_BDC_NAME "bdc" 26#define BRCM_BDC_DESC "Broadcom USB Device Controller driver" 27 28#define DMA_ADDR_INVALID (~(dma_addr_t)0) 29 30/* BDC command operation timeout in usec*/ 31#define BDC_CMD_TIMEOUT 1000 32/* BDC controller operation timeout in usec*/ 33#define BDC_COP_TIMEOUT 500 34 35/* 36 * Maximum size of ep0 response buffer for ch9 requests, 37 * the set_sel request uses 6 so far, the max. 38 */ 39#define EP0_RESPONSE_BUFF 6 40/* Start with SS as default */ 41#define EP0_MAX_PKT_SIZE 512 42 43/* 64 entries in a SRR */ 44#define NUM_SR_ENTRIES 64 45 46/* Num of bds per table */ 47#define NUM_BDS_PER_TABLE 64 48 49/* Num of tables in bd list for control,bulk and Int ep */ 50#define NUM_TABLES 2 51 52/* Num of tables in bd list for Isoch ep */ 53#define NUM_TABLES_ISOCH 6 54 55/* U1 Timeout default: 248usec */ 56#define U1_TIMEOUT 0xf8 57 58/* Interrupt coalescence in usec */ 59#define INT_CLS 500 60 61/* Register offsets */ 62/* Configuration and Capability registers */ 63#define BDC_BDCCFG0 0x00 64#define BDC_BDCCFG1 0x04 65#define BDC_BDCCAP0 0x08 66#define BDC_BDCCAP1 0x0c 67#define BDC_CMDPAR0 0x10 68#define BDC_CMDPAR1 0x14 69#define BDC_CMDPAR2 0x18 70#define BDC_CMDSC 0x1c 71#define BDC_USPC 0x20 72#define BDC_USPPMS 0x28 73#define BDC_USPPM2 0x2c 74#define BDC_SPBBAL 0x38 75#define BDC_SPBBAH 0x3c 76#define BDC_BDCSC 0x40 77#define BDC_XSFNTF 0x4c 78 79#define BDC_DVCSA 0x50 80#define BDC_DVCSB 0x54 81#define BDC_EPSTS0 0x60 82#define BDC_EPSTS1 0x64 83#define BDC_EPSTS2 0x68 84#define BDC_EPSTS3 0x6c 85#define BDC_EPSTS4 0x70 86#define BDC_EPSTS5 0x74 87#define BDC_EPSTS6 0x78 88#define BDC_EPSTS7 0x7c 89#define BDC_SRRBAL(n) (0x200 + ((n) * 0x10)) 90#define BDC_SRRBAH(n) (0x204 + ((n) * 0x10)) 91#define BDC_SRRINT(n) (0x208 + ((n) * 0x10)) 92#define BDC_INTCTLS(n) (0x20c + ((n) * 0x10)) 93 94/* Extended capability regs */ 95#define BDC_FSCNOC 0xcd4 96#define BDC_FSCNIC 0xce4 97#define NUM_NCS(p) ((p) >> 28) 98 99/* Register bit fields and Masks */ 100/* BDC Configuration 0 */ 101#define BDC_PGS(p) (((p) & (0x7 << 8)) >> 8) 102#define BDC_SPB(p) ((p) & 0x7) 103 104/* BDC Capability1 */ 105#define BDC_P64 BIT(0) 106 107/* BDC Command register */ 108#define BDC_CMD_FH 0xe 109#define BDC_CMD_DNC 0x6 110#define BDC_CMD_EPO 0x4 111#define BDC_CMD_BLA 0x3 112#define BDC_CMD_EPC 0x2 113#define BDC_CMD_DVC 0x1 114#define BDC_CMD_CWS BIT(5) 115#define BDC_CMD_CST(p) (((p) & (0xf << 6))>>6) 116#define BDC_CMD_EPN(p) (((p) & 0x1f) << 10) 117#define BDC_SUB_CMD_ADD (0x1 << 17) 118#define BDC_SUB_CMD_FWK (0x4 << 17) 119/* Reset sequence number */ 120#define BDC_CMD_EPO_RST_SN (0x1 << 16) 121#define BDC_CMD_EP0_XSD (0x1 << 16) 122#define BDC_SUB_CMD_ADD_EP (0x1 << 17) 123#define BDC_SUB_CMD_DRP_EP (0x2 << 17) 124#define BDC_SUB_CMD_EP_STP (0x2 << 17) 125#define BDC_SUB_CMD_EP_STL (0x4 << 17) 126#define BDC_SUB_CMD_EP_RST (0x1 << 17) 127#define BDC_CMD_SRD BIT(27) 128 129/* CMD completion status */ 130#define BDC_CMDS_SUCC 0x1 131#define BDC_CMDS_PARA 0x3 132#define BDC_CMDS_STAT 0x4 133#define BDC_CMDS_FAIL 0x5 134#define BDC_CMDS_INTL 0x6 135#define BDC_CMDS_BUSY 0xf 136 137/* CMDSC Param 2 shifts */ 138#define EPT_SHIFT 22 139#define MP_SHIFT 10 140#define MB_SHIFT 6 141#define EPM_SHIFT 4 142 143/* BDC USPSC */ 144#define BDC_VBC BIT(31) 145#define BDC_PRC BIT(30) 146#define BDC_PCE BIT(29) 147#define BDC_CFC BIT(28) 148#define BDC_PCC BIT(27) 149#define BDC_PSC BIT(26) 150#define BDC_VBS BIT(25) 151#define BDC_PRS BIT(24) 152#define BDC_PCS BIT(23) 153#define BDC_PSP(p) (((p) & (0x7 << 20))>>20) 154#define BDC_SCN BIT(8) 155#define BDC_SDC BIT(7) 156#define BDC_SWS BIT(4) 157 158#define BDC_USPSC_RW (BDC_SCN|BDC_SDC|BDC_SWS|0xf) 159#define BDC_PSP(p) (((p) & (0x7 << 20))>>20) 160 161#define BDC_SPEED_FS 0x1 162#define BDC_SPEED_LS 0x2 163#define BDC_SPEED_HS 0x3 164#define BDC_SPEED_SS 0x4 165 166#define BDC_PST(p) ((p) & 0xf) 167#define BDC_PST_MASK 0xf 168 169/* USPPMS */ 170#define BDC_U2E BIT(31) 171#define BDC_U1E BIT(30) 172#define BDC_U2A BIT(29) 173#define BDC_PORT_W1S BIT(17) 174#define BDC_U1T(p) ((p) & 0xff) 175#define BDC_U2T(p) (((p) & 0xff) << 8) 176#define BDC_U1T_MASK 0xff 177 178/* USBPM2 */ 179/* Hardware LPM Enable */ 180#define BDC_HLE BIT(16) 181 182/* BDC Status and Control */ 183#define BDC_COP_RST (1 << 29) 184#define BDC_COP_RUN (2 << 29) 185#define BDC_COP_STP (4 << 29) 186 187#define BDC_COP_MASK (BDC_COP_RST|BDC_COP_RUN|BDC_COP_STP) 188 189#define BDC_COS BIT(28) 190#define BDC_CSTS(p) (((p) & (0x7 << 20)) >> 20) 191#define BDC_MASK_MCW BIT(7) 192#define BDC_GIE BIT(1) 193#define BDC_GIP BIT(0) 194 195#define BDC_HLT 1 196#define BDC_NOR 2 197#define BDC_OIP 7 198 199/* Buffer descriptor and Status report bit fields and masks */ 200#define BD_TYPE_BITMASK (0xf) 201#define BD_CHAIN 0xf 202 203#define BD_TFS_SHIFT 4 204#define BD_SOT BIT(26) 205#define BD_EOT BIT(27) 206#define BD_ISP BIT(29) 207#define BD_IOC BIT(30) 208#define BD_SBF BIT(31) 209 210#define BD_INTR_TARGET(p) (((p) & 0x1f) << 27) 211 212#define BDC_SRR_RWS BIT(4) 213#define BDC_SRR_RST BIT(3) 214#define BDC_SRR_ISR BIT(2) 215#define BDC_SRR_IE BIT(1) 216#define BDC_SRR_IP BIT(0) 217#define BDC_SRR_EPI(p) (((p) & (0xff << 24)) >> 24) 218#define BDC_SRR_DPI(p) (((p) & (0xff << 16)) >> 16) 219#define BDC_SRR_DPI_MASK 0x00ff0000 220 221#define MARK_CHAIN_BD (BD_CHAIN|BD_EOT|BD_SOT) 222 223/* Control transfer BD specific fields */ 224#define BD_DIR_IN BIT(25) 225 226#define BDC_PTC_MASK 0xf0000000 227 228/* status report defines */ 229#define SR_XSF 0 230#define SR_USPC 4 231#define SR_BD_LEN(p) ((p) & 0xffffff) 232 233#define XSF_SUCC 0x1 234#define XSF_SHORT 0x3 235#define XSF_BABB 0x4 236#define XSF_SETUP_RECV 0x6 237#define XSF_DATA_START 0x7 238#define XSF_STATUS_START 0x8 239 240#define XSF_STS(p) (((p) >> 28) & 0xf) 241 242/* Transfer BD fields */ 243#define BD_LEN(p) ((p) & 0x1ffff) 244#define BD_LTF BIT(25) 245#define BD_TYPE_DS 0x1 246#define BD_TYPE_SS 0x2 247 248#define BDC_EP_ENABLED BIT(0) 249#define BDC_EP_STALL BIT(1) 250#define BDC_EP_STOP BIT(2) 251 252/* One BD can transfer max 65536 bytes */ 253#define BD_MAX_BUFF_SIZE (1 << 16) 254/* Maximum bytes in one XFR, Refer to BDC spec */ 255#define MAX_XFR_LEN 16777215 256 257/* defines for Force Header command */ 258#define DEV_NOTF_TYPE 6 259#define FWK_SUBTYPE 1 260#define TRA_PACKET 4 261 262#define to_bdc_ep(e) container_of(e, struct bdc_ep, usb_ep) 263#define to_bdc_req(r) container_of(r, struct bdc_req, usb_req) 264#define gadget_to_bdc(g) container_of(g, struct bdc, gadget) 265 266/* FUNCTION WAKE DEV NOTIFICATION interval, USB3 spec table 8.13 */ 267#define BDC_TNOTIFY 2500 /*in ms*/ 268/* Devstatus bitfields */ 269#define REMOTE_WAKEUP_ISSUED BIT(16) 270#define DEVICE_SUSPENDED BIT(17) 271#define FUNC_WAKE_ISSUED BIT(18) 272#define REMOTE_WAKE_ENABLE (1 << USB_DEVICE_REMOTE_WAKEUP) 273 274/* On disconnect, preserve these bits and clear rest */ 275#define DEVSTATUS_CLEAR (1 << USB_DEVICE_SELF_POWERED) 276/* Hardware and software Data structures */ 277 278/* Endpoint bd: buffer descriptor */ 279struct bdc_bd { 280 __le32 offset[4]; 281}; 282 283/* Status report in Status report ring(srr) */ 284struct bdc_sr { 285 __le32 offset[4]; 286}; 287 288/* bd_table: contiguous bd's in a table */ 289struct bd_table { 290 struct bdc_bd *start_bd; 291 /* dma address of start bd of table*/ 292 dma_addr_t dma; 293}; 294 295/* 296 * Each endpoint has a bdl(buffer descriptor list), bdl consists of 1 or more bd 297 * table's chained to each other through a chain bd, every table has equal 298 * number of bds. the software uses bdi(bd index) to refer to particular bd in 299 * the list. 300 */ 301struct bd_list { 302 /* Array of bd table pointers*/ 303 struct bd_table **bd_table_array; 304 /* How many tables chained to each other */ 305 int num_tabs; 306 /* Max_bdi = num_tabs * num_bds_table - 1 */ 307 int max_bdi; 308 /* current enq bdi from sw point of view */ 309 int eqp_bdi; 310 /* current deq bdi from sw point of view */ 311 int hwd_bdi; 312 /* numbers of bds per table */ 313 int num_bds_table; 314}; 315 316struct bdc_req; 317 318/* Representation of a transfer, one transfer can have multiple bd's */ 319struct bd_transfer { 320 struct bdc_req *req; 321 /* start bd index */ 322 int start_bdi; 323 /* this will be the next hw dqp when this transfer completes */ 324 int next_hwd_bdi; 325 /* number of bds in this transfer */ 326 int num_bds; 327}; 328 329/* 330 * Representation of a gadget request, every gadget request is contained 331 * by 1 bd_transfer. 332 */ 333struct bdc_req { 334 struct usb_request usb_req; 335 struct list_head queue; 336 struct bdc_ep *ep; 337 /* only one Transfer per request */ 338 struct bd_transfer bd_xfr; 339 int epnum; 340}; 341 342/* scratchpad buffer needed by bdc hardware */ 343struct bdc_scratchpad { 344 dma_addr_t sp_dma; 345 void *buff; 346 u32 size; 347}; 348 349/* endpoint representation */ 350struct bdc_ep { 351 struct usb_ep usb_ep; 352 struct list_head queue; 353 struct bdc *bdc; 354 u8 ep_type; 355 u8 dir; 356 u8 ep_num; 357 const struct usb_ss_ep_comp_descriptor *comp_desc; 358 const struct usb_endpoint_descriptor *desc; 359 unsigned int flags; 360 char name[20]; 361 /* endpoint bd list*/ 362 struct bd_list bd_list; 363 /* 364 * HW generates extra event for multi bd tranfers, this flag helps in 365 * ignoring the extra event 366 */ 367 bool ignore_next_sr; 368}; 369 370/* bdc cmmand parameter structure */ 371struct bdc_cmd_params { 372 u32 param2; 373 u32 param1; 374 u32 param0; 375}; 376 377/* status report ring(srr), currently one srr is supported for entire system */ 378struct srr { 379 struct bdc_sr *sr_bds; 380 u16 eqp_index; 381 u16 dqp_index; 382 dma_addr_t dma_addr; 383}; 384 385/* EP0 states */ 386enum bdc_ep0_state { 387 WAIT_FOR_SETUP = 0, 388 WAIT_FOR_DATA_START, 389 WAIT_FOR_DATA_XMIT, 390 WAIT_FOR_STATUS_START, 391 WAIT_FOR_STATUS_XMIT, 392 STATUS_PENDING 393}; 394 395/* Link states */ 396enum bdc_link_state { 397 BDC_LINK_STATE_U0 = 0x00, 398 BDC_LINK_STATE_U3 = 0x03, 399 BDC_LINK_STATE_RX_DET = 0x05, 400 BDC_LINK_STATE_RESUME = 0x0f 401}; 402 403/* representation of bdc */ 404struct bdc { 405 struct usb_gadget gadget; 406 struct usb_gadget_driver *gadget_driver; 407 struct device *dev; 408 /* device lock */ 409 spinlock_t lock; 410 411 /* generic phy */ 412 struct phy **phys; 413 int num_phys; 414 /* num of endpoints for a particular instantiation of IP */ 415 unsigned int num_eps; 416 /* 417 * Array of ep's, it uses the same index covention as bdc hw i.e. 418 * 1 for ep0, 2 for 1out,3 for 1in .... 419 */ 420 struct bdc_ep **bdc_ep_array; 421 void __iomem *regs; 422 struct bdc_scratchpad scratchpad; 423 u32 sp_buff_size; 424 /* current driver supports 1 status ring */ 425 struct srr srr; 426 /* Last received setup packet */ 427 struct usb_ctrlrequest setup_pkt; 428 struct bdc_req ep0_req; 429 struct bdc_req status_req; 430 enum bdc_ep0_state ep0_state; 431 bool delayed_status; 432 bool zlp_needed; 433 bool reinit; 434 bool pullup; 435 /* Bits 0-15 are standard and 16-31 for proprietary information */ 436 u32 devstatus; 437 int irq; 438 void *mem; 439 u32 dev_addr; 440 /* DMA pools */ 441 struct dma_pool *bd_table_pool; 442 u8 test_mode; 443 /* array of callbacks for various status report handlers */ 444 void (*sr_handler[2])(struct bdc *, struct bdc_sr *); 445 /* ep0 callback handlers */ 446 void (*sr_xsf_ep0[3])(struct bdc *, struct bdc_sr *); 447 /* ep0 response buffer for ch9 requests like GET_STATUS and SET_SEL */ 448 unsigned char ep0_response_buff[EP0_RESPONSE_BUFF]; 449 /* 450 * Timer to check if host resumed transfer after bdc sent Func wake 451 * notification packet after a remote wakeup. if not, then resend the 452 * Func Wake packet every 2.5 secs. Refer to USB3 spec section 8.5.6.4 453 */ 454 struct delayed_work func_wake_notify; 455 struct clk *clk; 456}; 457 458static inline u32 bdc_readl(void __iomem *base, u32 offset) 459{ 460 return readl(base + offset); 461} 462 463static inline void bdc_writel(void __iomem *base, u32 offset, u32 value) 464{ 465 writel(value, base + offset); 466} 467 468/* Buffer descriptor list operations */ 469void bdc_notify_xfr(struct bdc *bdc, u32 epnum); 470void bdc_softconn(struct bdc *bdc); 471void bdc_softdisconn(struct bdc *bdc); 472int bdc_run(struct bdc *bdc); 473int bdc_stop(struct bdc *bdc); 474int bdc_reset(struct bdc *bdc); 475int bdc_udc_init(struct bdc *bdc); 476void bdc_udc_exit(struct bdc *bdc); 477int bdc_reinit(struct bdc *bdc); 478 479/* Status report handlers */ 480/* Upstream port status change sr */ 481void bdc_sr_uspc(struct bdc *bdc, struct bdc_sr *sreport); 482/* transfer sr */ 483void bdc_sr_xsf(struct bdc *bdc, struct bdc_sr *sreport); 484/* EP0 XSF handlers */ 485void bdc_xsf_ep0_setup_recv(struct bdc *bdc, struct bdc_sr *sreport); 486void bdc_xsf_ep0_data_start(struct bdc *bdc, struct bdc_sr *sreport); 487void bdc_xsf_ep0_status_start(struct bdc *bdc, struct bdc_sr *sreport); 488 489#endif /* __LINUX_BDC_H__ */