1550a7375SFelipe Balbi# 2550a7375SFelipe Balbi# USB Dual Role (OTG-ready) Controller Drivers 3550a7375SFelipe Balbi# for silicon based on Mentor Graphics INVENTRA designs 4550a7375SFelipe Balbi# 5550a7375SFelipe Balbi 6550a7375SFelipe Balbicomment "Enable Host or Gadget support to see Inventra options" 7550a7375SFelipe Balbi depends on !USB && USB_GADGET=n 8550a7375SFelipe Balbi 9550a7375SFelipe Balbi# (M)HDRC = (Multipoint) Highspeed Dual-Role Controller 10550a7375SFelipe Balbiconfig USB_MUSB_HDRC 11550a7375SFelipe Balbi depends on (USB || USB_GADGET) && HAVE_CLK 1209fa14aaSAndrew Morton depends on !SUPERH 13550a7375SFelipe Balbi select TWL4030_USB if MACH_OMAP_3430SDP 14*37daa925SDavid Brownell select USB_OTG_UTILS 15085ad406SBryan Wu tristate 'Inventra Highspeed Dual Role Controller (TI, ADI, ...)' 16550a7375SFelipe Balbi help 17550a7375SFelipe Balbi Say Y here if your system has a dual role high speed USB 18550a7375SFelipe Balbi controller based on the Mentor Graphics silicon IP. Then 19550a7375SFelipe Balbi configure options to match your silicon and the board 20550a7375SFelipe Balbi it's being used with, including the USB peripheral role, 21550a7375SFelipe Balbi or the USB host role, or both. 22550a7375SFelipe Balbi 23550a7375SFelipe Balbi Texas Instruments parts using this IP include DaVinci 644x, 24550a7375SFelipe Balbi OMAP 243x, OMAP 343x, and TUSB 6010. 25550a7375SFelipe Balbi 26085ad406SBryan Wu Analog Devices parts using this IP include Blackfin BF54x, 27085ad406SBryan Wu BF525 and BF527. 28085ad406SBryan Wu 29550a7375SFelipe Balbi If you do not know what this is, please say N. 30550a7375SFelipe Balbi 31550a7375SFelipe Balbi To compile this driver as a module, choose M here; the 32550a7375SFelipe Balbi module will be called "musb_hdrc". 33550a7375SFelipe Balbi 34550a7375SFelipe Balbiconfig USB_MUSB_SOC 35550a7375SFelipe Balbi boolean 36550a7375SFelipe Balbi depends on USB_MUSB_HDRC 37550a7375SFelipe Balbi default y if ARCH_DAVINCI 38550a7375SFelipe Balbi default y if ARCH_OMAP2430 39550a7375SFelipe Balbi default y if ARCH_OMAP34XX 40085ad406SBryan Wu default y if (BF54x && !BF544) 41085ad406SBryan Wu default y if (BF52x && !BF522 && !BF523) 42550a7375SFelipe Balbi 43550a7375SFelipe Balbicomment "DaVinci 644x USB support" 44550a7375SFelipe Balbi depends on USB_MUSB_HDRC && ARCH_DAVINCI 45550a7375SFelipe Balbi 46550a7375SFelipe Balbicomment "OMAP 243x high speed USB support" 47550a7375SFelipe Balbi depends on USB_MUSB_HDRC && ARCH_OMAP2430 48550a7375SFelipe Balbi 49550a7375SFelipe Balbicomment "OMAP 343x high speed USB support" 50550a7375SFelipe Balbi depends on USB_MUSB_HDRC && ARCH_OMAP34XX 51550a7375SFelipe Balbi 52085ad406SBryan Wucomment "Blackfin high speed USB Support" 53085ad406SBryan Wu depends on USB_MUSB_HDRC && (BF54x && !BF544) || (BF52x && !BF522 && !BF523) 54085ad406SBryan Wu 55550a7375SFelipe Balbiconfig USB_TUSB6010 56550a7375SFelipe Balbi boolean "TUSB 6010 support" 57550a7375SFelipe Balbi depends on USB_MUSB_HDRC && !USB_MUSB_SOC 58550a7375SFelipe Balbi default y 59550a7375SFelipe Balbi help 60550a7375SFelipe Balbi The TUSB 6010 chip, from Texas Instruments, connects a discrete 61550a7375SFelipe Balbi HDRC core using a 16-bit parallel bus (NOR flash style) or VLYNQ 62550a7375SFelipe Balbi (a high speed serial link). It can use system-specific external 63550a7375SFelipe Balbi DMA controllers. 64550a7375SFelipe Balbi 65550a7375SFelipe Balbichoice 66550a7375SFelipe Balbi prompt "Driver Mode" 67550a7375SFelipe Balbi depends on USB_MUSB_HDRC 68550a7375SFelipe Balbi help 69550a7375SFelipe Balbi Dual-Role devices can support both host and peripheral roles, 70550a7375SFelipe Balbi as well as a the special "OTG Device" role which can switch 71550a7375SFelipe Balbi between both roles as needed. 72550a7375SFelipe Balbi 73550a7375SFelipe Balbi# use USB_MUSB_HDRC_HCD not USB_MUSB_HOST to #ifdef host side support; 74550a7375SFelipe Balbi# OTG needs both roles, not just USB_MUSB_HOST. 75550a7375SFelipe Balbiconfig USB_MUSB_HOST 76550a7375SFelipe Balbi depends on USB 77550a7375SFelipe Balbi bool "USB Host" 78550a7375SFelipe Balbi help 79550a7375SFelipe Balbi Say Y here if your system supports the USB host role. 80550a7375SFelipe Balbi If it has a USB "A" (rectangular), "Mini-A" (uncommon), 81550a7375SFelipe Balbi or "Mini-AB" connector, it supports the host role. 82550a7375SFelipe Balbi (With a "Mini-AB" connector, you should enable USB OTG.) 83550a7375SFelipe Balbi 84550a7375SFelipe Balbi# use USB_GADGET_MUSB_HDRC not USB_MUSB_PERIPHERAL to #ifdef peripheral 85550a7375SFelipe Balbi# side support ... OTG needs both roles 86550a7375SFelipe Balbiconfig USB_MUSB_PERIPHERAL 87550a7375SFelipe Balbi depends on USB_GADGET 88550a7375SFelipe Balbi bool "USB Peripheral (gadget stack)" 89550a7375SFelipe Balbi select USB_GADGET_MUSB_HDRC 90550a7375SFelipe Balbi help 91550a7375SFelipe Balbi Say Y here if your system supports the USB peripheral role. 92550a7375SFelipe Balbi If it has a USB "B" (squarish), "Mini-B", or "Mini-AB" 93550a7375SFelipe Balbi connector, it supports the peripheral role. 94550a7375SFelipe Balbi (With a "Mini-AB" connector, you should enable USB OTG.) 95550a7375SFelipe Balbi 96550a7375SFelipe Balbiconfig USB_MUSB_OTG 97550a7375SFelipe Balbi depends on USB && USB_GADGET && PM && EXPERIMENTAL 98550a7375SFelipe Balbi bool "Both host and peripheral: USB OTG (On The Go) Device" 99550a7375SFelipe Balbi select USB_GADGET_MUSB_HDRC 100550a7375SFelipe Balbi select USB_OTG 101550a7375SFelipe Balbi help 102550a7375SFelipe Balbi The most notable feature of USB OTG is support for a 103550a7375SFelipe Balbi "Dual-Role" device, which can act as either a device 104550a7375SFelipe Balbi or a host. The initial role choice can be changed 105550a7375SFelipe Balbi later, when two dual-role devices talk to each other. 106550a7375SFelipe Balbi 107550a7375SFelipe Balbi At this writing, the OTG support in this driver is incomplete, 108550a7375SFelipe Balbi omitting the mandatory HNP or SRP protocols. However, some 109550a7375SFelipe Balbi of the cable based role switching works. (That is, grounding 110550a7375SFelipe Balbi the ID pin switches the controller to host mode, while leaving 111550a7375SFelipe Balbi it floating leaves it in peripheral mode.) 112550a7375SFelipe Balbi 113550a7375SFelipe Balbi Select this if your system has a Mini-AB connector, or 114550a7375SFelipe Balbi to simplify certain kinds of configuration. 115550a7375SFelipe Balbi 116550a7375SFelipe Balbi To implement your OTG Targeted Peripherals List (TPL), enable 117550a7375SFelipe Balbi USB_OTG_WHITELIST and update "drivers/usb/core/otg_whitelist.h" 118550a7375SFelipe Balbi to match your requirements. 119550a7375SFelipe Balbi 120550a7375SFelipe Balbiendchoice 121550a7375SFelipe Balbi 122550a7375SFelipe Balbi# enable peripheral support (including with OTG) 123550a7375SFelipe Balbiconfig USB_GADGET_MUSB_HDRC 124550a7375SFelipe Balbi bool 125550a7375SFelipe Balbi depends on USB_MUSB_HDRC && (USB_MUSB_PERIPHERAL || USB_MUSB_OTG) 126550a7375SFelipe Balbi# default y 127550a7375SFelipe Balbi# select USB_GADGET_DUALSPEED 128550a7375SFelipe Balbi# select USB_GADGET_SELECTED 129550a7375SFelipe Balbi 130550a7375SFelipe Balbi# enables host support (including with OTG) 131550a7375SFelipe Balbiconfig USB_MUSB_HDRC_HCD 132550a7375SFelipe Balbi bool 133550a7375SFelipe Balbi depends on USB_MUSB_HDRC && (USB_MUSB_HOST || USB_MUSB_OTG) 134550a7375SFelipe Balbi select USB_OTG if USB_GADGET_MUSB_HDRC 135550a7375SFelipe Balbi default y 136550a7375SFelipe Balbi 137550a7375SFelipe Balbi 138550a7375SFelipe Balbiconfig MUSB_PIO_ONLY 139550a7375SFelipe Balbi bool 'Disable DMA (always use PIO)' 140550a7375SFelipe Balbi depends on USB_MUSB_HDRC 141550a7375SFelipe Balbi default y if USB_TUSB6010 142550a7375SFelipe Balbi help 143550a7375SFelipe Balbi All data is copied between memory and FIFO by the CPU. 144550a7375SFelipe Balbi DMA controllers are ignored. 145550a7375SFelipe Balbi 146550a7375SFelipe Balbi Do not select 'n' here unless DMA support for your SOC or board 147550a7375SFelipe Balbi is unavailable (or unstable). When DMA is enabled at compile time, 148550a7375SFelipe Balbi you can still disable it at run time using the "use_dma=n" module 149550a7375SFelipe Balbi parameter. 150550a7375SFelipe Balbi 151550a7375SFelipe Balbiconfig USB_INVENTRA_DMA 152550a7375SFelipe Balbi bool 153550a7375SFelipe Balbi depends on USB_MUSB_HDRC && !MUSB_PIO_ONLY 154085ad406SBryan Wu default ARCH_OMAP2430 || ARCH_OMAP34XX || BLACKFIN 155550a7375SFelipe Balbi help 156550a7375SFelipe Balbi Enable DMA transfers using Mentor's engine. 157550a7375SFelipe Balbi 158550a7375SFelipe Balbiconfig USB_TI_CPPI_DMA 159550a7375SFelipe Balbi bool 160550a7375SFelipe Balbi depends on USB_MUSB_HDRC && !MUSB_PIO_ONLY 161550a7375SFelipe Balbi default ARCH_DAVINCI 162550a7375SFelipe Balbi help 163550a7375SFelipe Balbi Enable DMA transfers when TI CPPI DMA is available. 164550a7375SFelipe Balbi 165550a7375SFelipe Balbiconfig USB_TUSB_OMAP_DMA 166550a7375SFelipe Balbi bool 167550a7375SFelipe Balbi depends on USB_MUSB_HDRC && !MUSB_PIO_ONLY 168550a7375SFelipe Balbi depends on USB_TUSB6010 169550a7375SFelipe Balbi depends on ARCH_OMAP 170550a7375SFelipe Balbi default y 171550a7375SFelipe Balbi help 172550a7375SFelipe Balbi Enable DMA transfers on TUSB 6010 when OMAP DMA is available. 173550a7375SFelipe Balbi 174e8164f64SFelipe Balbiconfig USB_MUSB_DEBUG 175550a7375SFelipe Balbi depends on USB_MUSB_HDRC 176e8164f64SFelipe Balbi bool "Enable debugging messages" 177e8164f64SFelipe Balbi default n 178550a7375SFelipe Balbi help 179e8164f64SFelipe Balbi This enables musb debugging. To set the logging level use the debug 180e8164f64SFelipe Balbi module parameter. Starting at level 3, per-transfer (urb, usb_request, 181e8164f64SFelipe Balbi packet, or dma transfer) tracing may kick in. 182