blob: f6e305fe62909d47663ac8c30c8ef77b307fa90a [file] [log] [blame]
Felipe Balbi550a7372008-07-24 12:27:36 +03001#
2# USB Dual Role (OTG-ready) Controller Drivers
3# for silicon based on Mentor Graphics INVENTRA designs
4#
5
Felipe Balbi550a7372008-07-24 12:27:36 +03006# (M)HDRC = (Multipoint) Highspeed Dual-Role Controller
7config USB_MUSB_HDRC
Felipe Contreras54a605f2011-12-20 02:42:22 +02008 tristate 'Inventra Highspeed Dual Role Controller (TI, ADI, ...)'
Felipe Balbi62285962011-06-22 17:28:09 +03009 depends on USB && USB_GADGET
Cliff Cai8ba63a22009-11-16 20:05:03 -050010 select NOP_USB_XCEIV if (ARCH_DAVINCI || MACH_OMAP3EVM || BLACKFIN)
Felipe Balbi550a7372008-07-24 12:27:36 +030011 select TWL4030_USB if MACH_OMAP_3430SDP
Hema HK4c42fbc2010-12-10 18:09:35 +053012 select TWL6030_USB if MACH_OMAP_4430SDP || MACH_OMAP4_PANDA
David Brownell37daa922009-01-24 17:56:25 -080013 select USB_OTG_UTILS
Luciano Coelho0de174b2011-11-02 12:17:59 +020014 select USB_GADGET_DUALSPEED
Felipe Balbi550a7372008-07-24 12:27:36 +030015 help
16 Say Y here if your system has a dual role high speed USB
17 controller based on the Mentor Graphics silicon IP. Then
18 configure options to match your silicon and the board
19 it's being used with, including the USB peripheral role,
20 or the USB host role, or both.
21
David Brownella227fd72009-02-24 15:31:54 -080022 Texas Instruments familiies using this IP include DaVinci
23 (35x, 644x ...), OMAP 243x, OMAP 3, and TUSB 6010.
Felipe Balbi550a7372008-07-24 12:27:36 +030024
Bryan Wu085ad402008-12-02 21:33:49 +020025 Analog Devices parts using this IP include Blackfin BF54x,
26 BF525 and BF527.
27
Felipe Balbi550a7372008-07-24 12:27:36 +030028 If you do not know what this is, please say N.
29
Felipe Balbi1376d922011-05-11 12:47:59 +030030 To compile this driver as a module, choose M here; the
31 module will be called "musb-hdrc".
Felipe Balbi550a7372008-07-24 12:27:36 +030032
Felipe Balbi7c925542010-12-01 14:23:48 +020033choice
34 prompt "Platform Glue Layer"
Felipe Balbi550a7372008-07-24 12:27:36 +030035 depends on USB_MUSB_HDRC
Felipe Balbi550a7372008-07-24 12:27:36 +030036
Felipe Balbi7c925542010-12-01 14:23:48 +020037config USB_MUSB_DAVINCI
Felipe Balbi1376d922011-05-11 12:47:59 +030038 tristate "DaVinci"
Felipe Balbi7c925542010-12-01 14:23:48 +020039 depends on ARCH_DAVINCI_DMx
Felipe Balbi550a7372008-07-24 12:27:36 +030040
Felipe Balbi7c925542010-12-01 14:23:48 +020041config USB_MUSB_DA8XX
Felipe Balbi1376d922011-05-11 12:47:59 +030042 tristate "DA8xx/OMAP-L1x"
Felipe Balbi7c925542010-12-01 14:23:48 +020043 depends on ARCH_DAVINCI_DA8XX
Sergei Shtylyov3ee076d2010-09-24 13:44:03 +030044
Felipe Balbi7c925542010-12-01 14:23:48 +020045config USB_MUSB_TUSB6010
Felipe Balbi1376d922011-05-11 12:47:59 +030046 tristate "TUSB6010"
Felipe Balbi550a7372008-07-24 12:27:36 +030047
Felipe Balbi7c925542010-12-01 14:23:48 +020048config USB_MUSB_OMAP2PLUS
Felipe Balbi1376d922011-05-11 12:47:59 +030049 tristate "OMAP2430 and onwards"
Felipe Balbi7c925542010-12-01 14:23:48 +020050 depends on ARCH_OMAP2PLUS
Bryan Wu085ad402008-12-02 21:33:49 +020051
Ajay Kumar Guptaeb830922010-10-19 10:08:12 +030052config USB_MUSB_AM35X
Felipe Balbi1376d922011-05-11 12:47:59 +030053 tristate "AM35x"
Felipe Balbi7c925542010-12-01 14:23:48 +020054 depends on ARCH_OMAP
Ajay Kumar Guptaeb830922010-10-19 10:08:12 +030055
Felipe Balbi7c925542010-12-01 14:23:48 +020056config USB_MUSB_BLACKFIN
Felipe Balbi1376d922011-05-11 12:47:59 +030057 tristate "Blackfin"
Felipe Balbi7c925542010-12-01 14:23:48 +020058 depends on (BF54x && !BF544) || (BF52x && ! BF522 && !BF523)
59
Mian Yousaf Kaukab4bc36fd2010-12-09 13:05:01 +010060config USB_MUSB_UX500
Felipe Balbi1376d922011-05-11 12:47:59 +030061 tristate "U8500 and U5500"
Mian Yousaf Kaukabd0678592011-11-01 08:37:40 +010062 depends on (ARCH_U8500 && AB8500_USB)
Mian Yousaf Kaukab4bc36fd2010-12-09 13:05:01 +010063
Felipe Balbi7c925542010-12-01 14:23:48 +020064endchoice
Felipe Balbi550a7372008-07-24 12:27:36 +030065
Arnd Bergmann2e7fc3b2011-10-02 16:45:45 +020066choice
67 prompt 'MUSB DMA mode'
68 default USB_UX500_DMA if USB_MUSB_UX500
69 default USB_INVENTRA_DMA if USB_MUSB_OMAP2PLUS || USB_MUSB_BLACKFIN
70 default USB_TI_CPPI_DMA if USB_MUSB_DAVINCI
71 default USB_TUSB_OMAP_DMA if USB_MUSB_TUSB6010
72 default MUSB_PIO_ONLY if USB_MUSB_TUSB6010 || USB_MUSB_DA8XX || USB_MUSB_AM35X
Felipe Balbi550a7372008-07-24 12:27:36 +030073 help
Arnd Bergmann2e7fc3b2011-10-02 16:45:45 +020074 Unfortunately, only one option can be enabled here. Ideally one
75 should be able to build all these drivers into one kernel to
76 allow using DMA on multiplatform kernels.
Felipe Balbi550a7372008-07-24 12:27:36 +030077
Mian Yousaf Kaukabd2389442011-03-22 15:55:59 +010078config USB_UX500_DMA
Arnd Bergmann2e7fc3b2011-10-02 16:45:45 +020079 bool 'ST Ericsson U8500 and U5500'
80 depends on USB_MUSB_HDRC
81 depends on USB_MUSB_UX500
Mian Yousaf Kaukabd2389442011-03-22 15:55:59 +010082 help
83 Enable DMA transfers on UX500 platforms.
84
Felipe Balbi550a7372008-07-24 12:27:36 +030085config USB_INVENTRA_DMA
Arnd Bergmann2e7fc3b2011-10-02 16:45:45 +020086 bool 'Inventra'
87 depends on USB_MUSB_HDRC
88 depends on USB_MUSB_OMAP2PLUS || USB_MUSB_BLACKFIN
Felipe Balbi550a7372008-07-24 12:27:36 +030089 help
90 Enable DMA transfers using Mentor's engine.
91
92config USB_TI_CPPI_DMA
Arnd Bergmann2e7fc3b2011-10-02 16:45:45 +020093 bool 'TI CPPI (Davinci)'
94 depends on USB_MUSB_HDRC
95 depends on USB_MUSB_DAVINCI
Felipe Balbi550a7372008-07-24 12:27:36 +030096 help
97 Enable DMA transfers when TI CPPI DMA is available.
98
99config USB_TUSB_OMAP_DMA
Arnd Bergmann2e7fc3b2011-10-02 16:45:45 +0200100 bool 'TUSB 6010'
101 depends on USB_MUSB_HDRC
Felipe Balbi7c925542010-12-01 14:23:48 +0200102 depends on USB_MUSB_TUSB6010
Felipe Balbi550a7372008-07-24 12:27:36 +0300103 depends on ARCH_OMAP
Felipe Balbi550a7372008-07-24 12:27:36 +0300104 help
105 Enable DMA transfers on TUSB 6010 when OMAP DMA is available.
106
Arnd Bergmann2e7fc3b2011-10-02 16:45:45 +0200107config MUSB_PIO_ONLY
108 bool 'Disable DMA (always use PIO)'
109 depends on USB_MUSB_HDRC
110 help
111 All data is copied between memory and FIFO by the CPU.
112 DMA controllers are ignored.
113
114 Do not choose this unless DMA support for your SOC or board
115 is unavailable (or unstable). When DMA is enabled at compile time,
116 you can still disable it at run time using the "use_dma=n" module
117 parameter.
118
119endchoice