xref: /openbmc/u-boot/drivers/usb/host/Kconfig (revision 103774b7)
16e7e9294SMasahiro Yamada#
26e7e9294SMasahiro Yamada# USB Host Controller Drivers
36e7e9294SMasahiro Yamada#
46e7e9294SMasahiro Yamadacomment "USB Host Controller Drivers"
56e7e9294SMasahiro Yamada
62b58e1b7SMasahiro Yamadaconfig USB_HOST
72b58e1b7SMasahiro Yamada	bool
82b58e1b7SMasahiro Yamada
96e7e9294SMasahiro Yamadaconfig USB_XHCI_HCD
106e7e9294SMasahiro Yamada	bool "xHCI HCD (USB 3.0) support"
112b58e1b7SMasahiro Yamada	select USB_HOST
126e7e9294SMasahiro Yamada	---help---
136e7e9294SMasahiro Yamada	  The eXtensible Host Controller Interface (xHCI) is standard for USB 3.0
146e7e9294SMasahiro Yamada	  "SuperSpeed" host controller hardware.
156e7e9294SMasahiro Yamada
166e7e9294SMasahiro Yamadaif USB_XHCI_HCD
176e7e9294SMasahiro Yamada
1810db7500SMasahiro Yamadaconfig USB_XHCI_DWC3
1910db7500SMasahiro Yamada	bool "DesignWare USB3 DRD Core Support"
2010db7500SMasahiro Yamada	help
2110db7500SMasahiro Yamada	  Say Y or if your system has a Dual Role SuperSpeed
2210db7500SMasahiro Yamada	  USB controller based on the DesignWare USB3 IP Core.
2310db7500SMasahiro Yamada
24ca7fdc8bSNeil Armstrongconfig USB_XHCI_DWC3_OF_SIMPLE
25ca7fdc8bSNeil Armstrong	bool "DesignWare USB3 DRD Generic OF Simple Glue Layer"
26*103774b7SJean-Jacques Hiblot	depends on DM_USB
27ca7fdc8bSNeil Armstrong	help
28ca7fdc8bSNeil Armstrong	  Support USB2/3 functionality in simple SoC integrations with
29ca7fdc8bSNeil Armstrong	  USB controller based on the DesignWare USB3 IP Core.
30ca7fdc8bSNeil Armstrong
3181c1f6f0SStefan Roeseconfig USB_XHCI_MVEBU
3281c1f6f0SStefan Roese	bool "MVEBU USB 3.0 support"
3381c1f6f0SStefan Roese	default y
3481c1f6f0SStefan Roese	depends on ARCH_MVEBU
3581192b79SKonstantin Porotchkin	select DM_REGULATOR
3681c1f6f0SStefan Roese	help
3781c1f6f0SStefan Roese	  Choose this option to add support for USB 3.0 driver on mvebu
3881c1f6f0SStefan Roese	  SoCs, which includes Armada8K, Armada3700 and other Armada
3981c1f6f0SStefan Roese	  family SoCs.
4081c1f6f0SStefan Roese
41d7cde281SBin Mengconfig USB_XHCI_PCI
42d7cde281SBin Meng	bool "Support for PCI-based xHCI USB controller"
43978f6a3bSBin Meng	depends on DM_USB
44d7cde281SBin Meng	default y if X86
45d7cde281SBin Meng	help
46d7cde281SBin Meng	  Enables support for the PCI-based xHCI controller.
47d7cde281SBin Meng
48f7bb27a5SKever Yangconfig USB_XHCI_ROCKCHIP
49f7bb27a5SKever Yang	bool "Support for Rockchip on-chip xHCI USB controller"
50f7bb27a5SKever Yang	depends on ARCH_ROCKCHIP
51e85f00abSMeng Dongyang	depends on DM_REGULATOR
52e85f00abSMeng Dongyang	depends on DM_USB
53f7bb27a5SKever Yang	default y
54f7bb27a5SKever Yang	help
55f7bb27a5SKever Yang	  Enables support for the on-chip xHCI controller on Rockchip SoCs.
56f7bb27a5SKever Yang
57e1cc60c0SMarek Vasutconfig USB_XHCI_RCAR
58e1cc60c0SMarek Vasut	bool "Renesas RCar USB 3.0 support"
59e1cc60c0SMarek Vasut	default y
60e1cc60c0SMarek Vasut	depends on ARCH_RMOBILE
61e1cc60c0SMarek Vasut	help
62e1cc60c0SMarek Vasut	  Choose this option to add support for USB 3.0 driver on Renesas
63e1cc60c0SMarek Vasut	  RCar Gen3 SoCs.
64e1cc60c0SMarek Vasut
6540d1a31eSPatrice Chotardconfig USB_XHCI_STI
6640d1a31eSPatrice Chotard	bool "Support for STMicroelectronics STiH407 family on-chip xHCI USB controller"
6740d1a31eSPatrice Chotard	depends on ARCH_STI
6840d1a31eSPatrice Chotard	default y
6940d1a31eSPatrice Chotard	help
7040d1a31eSPatrice Chotard	  Enables support for the on-chip xHCI controller on STMicroelectronics
7140d1a31eSPatrice Chotard	  STiH407 family SoCs. This is a driver for the dwc3 to provide the glue logic
7240d1a31eSPatrice Chotard	  to configure the controller.
7340d1a31eSPatrice Chotard
7463d74747SMichal Simekconfig USB_XHCI_ZYNQMP
7563d74747SMichal Simek	bool "Support for Xilinx ZynqMP on-chip xHCI USB controller"
7663d74747SMichal Simek	depends on ARCH_ZYNQMP
7763d74747SMichal Simek	help
7863d74747SMichal Simek	  Enables support for the on-chip xHCI controller on Xilinx ZynqMP SoCs.
7963d74747SMichal Simek
80ef3f3b81SUri Mashiachconfig USB_XHCI_DRA7XX_INDEX
81ef3f3b81SUri Mashiach	int "DRA7XX xHCI USB index"
82ef3f3b81SUri Mashiach	range 0 1
83ef3f3b81SUri Mashiach	default 0
84ef3f3b81SUri Mashiach	depends on DRA7XX
85ef3f3b81SUri Mashiach	help
86ef3f3b81SUri Mashiach	  Select the DRA7XX xHCI USB index.
87ef3f3b81SUri Mashiach	  Current supported values: 0, 1.
88ef3f3b81SUri Mashiach
89420b0ebaSRan Wangconfig USB_XHCI_FSL
90420b0ebaSRan Wang	bool "Support for NXP Layerscape on-chip xHCI USB controller"
91420b0ebaSRan Wang	default y if ARCH_LS1021A || FSL_LSCH3 || FSL_LSCH2
92420b0ebaSRan Wang	depends on !SPL_NO_USB
93420b0ebaSRan Wang	help
94420b0ebaSRan Wang	  Enables support for the on-chip xHCI controller on NXP Layerscape SoCs.
9593cb8247SMasahiro Yamadaendif # USB_XHCI_HCD
96fee331f6SAlexey Brodkin
976e7e9294SMasahiro Yamadaconfig USB_EHCI_HCD
986e7e9294SMasahiro Yamada	bool "EHCI HCD (USB 2.0) support"
9964d6ac5bSTom Rini	default y if ARCH_MX5 || ARCH_MX6
1002b58e1b7SMasahiro Yamada	select USB_HOST
1016e7e9294SMasahiro Yamada	---help---
1026e7e9294SMasahiro Yamada	  The Enhanced Host Controller Interface (EHCI) is standard for USB 2.0
1036e7e9294SMasahiro Yamada	  "high speed" (480 Mbit/sec, 60 Mbyte/sec) host controller hardware.
1046e7e9294SMasahiro Yamada	  If your USB host controller supports USB 2.0, you will likely want to
1056e7e9294SMasahiro Yamada	  configure this Host Controller Driver.
1066e7e9294SMasahiro Yamada
1076e7e9294SMasahiro Yamada	  EHCI controllers are packaged with "companion" host controllers (OHCI
1086e7e9294SMasahiro Yamada	  or UHCI) to handle USB 1.1 devices connected to root hub ports.  Ports
1096e7e9294SMasahiro Yamada	  will connect to EHCI if the device is high speed, otherwise they
1106e7e9294SMasahiro Yamada	  connect to a companion controller.  If you configure EHCI, you should
1116e7e9294SMasahiro Yamada	  probably configure the OHCI (for NEC and some other vendors) USB Host
1126e7e9294SMasahiro Yamada	  Controller Driver or UHCI (for Via motherboards) Host Controller
1136e7e9294SMasahiro Yamada	  Driver too.
1146e7e9294SMasahiro Yamada
1156e7e9294SMasahiro Yamada	  You may want to read <file:Documentation/usb/ehci.txt>.
1166e7e9294SMasahiro Yamada
1176e7e9294SMasahiro Yamadaif USB_EHCI_HCD
1186e7e9294SMasahiro Yamada
11917b68b5aSWenyou Yangconfig USB_EHCI_ATMEL
12017b68b5aSWenyou Yang	bool  "Support for Atmel on-chip EHCI USB controller"
12117b68b5aSWenyou Yang	depends on ARCH_AT91
12217b68b5aSWenyou Yang	default y
12317b68b5aSWenyou Yang	---help---
12417b68b5aSWenyou Yang	  Enables support for the on-chip EHCI controller on Atmel chips.
12517b68b5aSWenyou Yang
126cd48225bSStefan Roeseconfig USB_EHCI_MARVELL
12780f1f320STom Rini	bool "Support for Marvell on-chip EHCI USB controller"
12880f1f320STom Rini	depends on ARCH_MVEBU || KIRKWOOD || ORION5X
129cd48225bSStefan Roese	default y
130cd48225bSStefan Roese	---help---
131cd48225bSStefan Roese	  Enables support for the on-chip EHCI controller on MVEBU SoCs.
132cd48225bSStefan Roese
133919e802cSNikita Kiryanovconfig USB_EHCI_MX6
134919e802cSNikita Kiryanov	bool "Support for i.MX6 on-chip EHCI USB controller"
135919e802cSNikita Kiryanov	depends on ARCH_MX6
136919e802cSNikita Kiryanov	default y
137919e802cSNikita Kiryanov	---help---
138919e802cSNikita Kiryanov	  Enables support for the on-chip EHCI controller on i.MX6 SoCs.
139919e802cSNikita Kiryanov
1402deebe24SStefan Agnerconfig USB_EHCI_MX7
1412deebe24SStefan Agner	bool "Support for i.MX7 on-chip EHCI USB controller"
1422deebe24SStefan Agner	depends on ARCH_MX7
1432deebe24SStefan Agner	default y
1442deebe24SStefan Agner	---help---
1452deebe24SStefan Agner	  Enables support for the on-chip EHCI controller on i.MX7 SoCs.
1462deebe24SStefan Agner
1471d1ab61cSTom Riniconfig USB_EHCI_OMAP
1481d1ab61cSTom Rini	bool "Support for OMAP3+ on-chip EHCI USB controller"
1491d1ab61cSTom Rini	depends on ARCH_OMAP2PLUS
1501d1ab61cSTom Rini	default y
1511d1ab61cSTom Rini	---help---
1521d1ab61cSTom Rini	  Enables support for the on-chip EHCI controller on OMAP3 and later
1531d1ab61cSTom Rini	  SoCs.
1541d1ab61cSTom Rini
155c4483093SStefan Agnerif USB_EHCI_MX7
156c4483093SStefan Agner
157c4483093SStefan Agnerconfig MXC_USB_OTG_HACTIVE
158c4483093SStefan Agner	bool "USB Power pin high active"
159c4483093SStefan Agner	---help---
160c4483093SStefan Agner	  Set the USB Power pin polarity to be high active (PWR_POL)
161c4483093SStefan Agner
162c4483093SStefan Agnerendif
163c4483093SStefan Agner
1645a822118SMateusz Kulikowskiconfig USB_EHCI_MSM
1655a822118SMateusz Kulikowski	bool "Support for Qualcomm on-chip EHCI USB controller"
1665a822118SMateusz Kulikowski	depends on DM_USB
1675a822118SMateusz Kulikowski	select USB_ULPI_VIEWPORT
1685a822118SMateusz Kulikowski	default n
1695a822118SMateusz Kulikowski	---help---
1705a822118SMateusz Kulikowski	  Enables support for the on-chip EHCI controller on Qualcomm
1715a822118SMateusz Kulikowski	  Snapdragon SoCs.
1725a822118SMateusz Kulikowski	  This driver supports combination of Chipidea USB controller
1735a822118SMateusz Kulikowski	  and Synapsys USB PHY in host mode only.
1745a822118SMateusz Kulikowski
175a11a5b8aSBin Mengconfig USB_EHCI_PCI
176a11a5b8aSBin Meng	bool "Support for PCI-based EHCI USB controller"
177a11a5b8aSBin Meng	default y if X86
178a11a5b8aSBin Meng	help
179a11a5b8aSBin Meng	  Enables support for the PCI-based EHCI controller.
180a11a5b8aSBin Meng
1812cdc778bSSiva Durga Prasad Paladuguconfig USB_EHCI_ZYNQ
1822cdc778bSSiva Durga Prasad Paladugu	bool "Support for Xilinx Zynq on-chip EHCI USB controller"
1832cdc778bSSiva Durga Prasad Paladugu	depends on ARCH_ZYNQ
1842cdc778bSSiva Durga Prasad Paladugu	default y
1852cdc778bSSiva Durga Prasad Paladugu	---help---
1862cdc778bSSiva Durga Prasad Paladugu	  Enable support for Zynq on-chip EHCI USB controller
1872cdc778bSSiva Durga Prasad Paladugu
18890fbb282SAlexey Brodkinconfig USB_EHCI_GENERIC
18990fbb282SAlexey Brodkin	bool "Support for generic EHCI USB controller"
19090fbb282SAlexey Brodkin	depends on OF_CONTROL
19190fbb282SAlexey Brodkin	depends on DM_USB
19290fbb282SAlexey Brodkin	default n
19390fbb282SAlexey Brodkin	---help---
19490fbb282SAlexey Brodkin	  Enables support for generic EHCI controller.
19590fbb282SAlexey Brodkin
19691f4fb9bSRan Wangconfig USB_EHCI_FSL
19791f4fb9bSRan Wang	bool  "Support for FSL on-chip EHCI USB controller"
19891f4fb9bSRan Wang	default n
19991f4fb9bSRan Wang	select  CONFIG_EHCI_HCD_INIT_AFTER_RESET
20091f4fb9bSRan Wang	---help---
20191f4fb9bSRan Wang	  Enables support for the on-chip EHCI controller on FSL chips.
20293cb8247SMasahiro Yamadaendif # USB_EHCI_HCD
20393cb8247SMasahiro Yamada
20493cb8247SMasahiro Yamadaconfig USB_OHCI_HCD
20593cb8247SMasahiro Yamada	bool "OHCI HCD (USB 1.1) support"
20693cb8247SMasahiro Yamada	---help---
20793cb8247SMasahiro Yamada	  The Open Host Controller Interface (OHCI) is a standard for accessing
20893cb8247SMasahiro Yamada	  USB 1.1 host controller hardware.  It does more in hardware than Intel's
20993cb8247SMasahiro Yamada	  UHCI specification.  If your USB host controller follows the OHCI spec,
21093cb8247SMasahiro Yamada	  say Y.  On most non-x86 systems, and on x86 hardware that's not using a
21193cb8247SMasahiro Yamada	  USB controller from Intel or VIA, this is appropriate.  If your host
21293cb8247SMasahiro Yamada	  controller doesn't use PCI, this is probably appropriate.  For a PCI
21393cb8247SMasahiro Yamada	  based system where you're not sure, the "lspci -v" entry will list the
21493cb8247SMasahiro Yamada	  right "prog-if" for your USB controller(s):  EHCI, OHCI, or UHCI.
21593cb8247SMasahiro Yamada
21693cb8247SMasahiro Yamadaif USB_OHCI_HCD
21793cb8247SMasahiro Yamada
21893cb8247SMasahiro Yamadaconfig USB_OHCI_GENERIC
21993cb8247SMasahiro Yamada	bool "Support for generic OHCI USB controller"
22093cb8247SMasahiro Yamada	depends on OF_CONTROL
22193cb8247SMasahiro Yamada	depends on DM_USB
2222b58e1b7SMasahiro Yamada	select USB_HOST
22393cb8247SMasahiro Yamada	---help---
22493cb8247SMasahiro Yamada	  Enables support for generic OHCI controller.
22593cb8247SMasahiro Yamada
22693cb8247SMasahiro Yamadaendif # USB_OHCI_HCD
22796d8284bSMasahiro Yamada
22896d8284bSMasahiro Yamadaconfig USB_UHCI_HCD
22996d8284bSMasahiro Yamada	bool "UHCI HCD (most Intel and VIA) support"
2302b58e1b7SMasahiro Yamada	select USB_HOST
23196d8284bSMasahiro Yamada	---help---
23296d8284bSMasahiro Yamada	  The Universal Host Controller Interface is a standard by Intel for
23396d8284bSMasahiro Yamada	  accessing the USB hardware in the PC (which is also called the USB
23496d8284bSMasahiro Yamada	  host controller). If your USB host controller conforms to this
23596d8284bSMasahiro Yamada	  standard, you may want to say Y, but see below. All recent boards
23696d8284bSMasahiro Yamada	  with Intel PCI chipsets (like intel 430TX, 440FX, 440LX, 440BX,
23796d8284bSMasahiro Yamada	  i810, i820) conform to this standard. Also all VIA PCI chipsets
23896d8284bSMasahiro Yamada	  (like VIA VP2, VP3, MVP3, Apollo Pro, Apollo Pro II or Apollo Pro
23996d8284bSMasahiro Yamada	  133) and LEON/GRLIB SoCs with the GRUSBHC controller.
24096d8284bSMasahiro Yamada	  If unsure, say Y.
24196d8284bSMasahiro Yamada
24296d8284bSMasahiro Yamadaif USB_UHCI_HCD
24396d8284bSMasahiro Yamada
24496d8284bSMasahiro Yamadaendif # USB_UHCI_HCD
2454ac72f5cSPhilipp Tomsich
2464ac72f5cSPhilipp Tomsichconfig USB_DWC2
2474ac72f5cSPhilipp Tomsich	bool "DesignWare USB2 Core support"
2484ac72f5cSPhilipp Tomsich	select USB_HOST
2494ac72f5cSPhilipp Tomsich	---help---
2504ac72f5cSPhilipp Tomsich	  The DesignWare USB 2.0 controller is compliant with the
2514ac72f5cSPhilipp Tomsich	  USB-Implementers Forum (USB-IF) USB 2.0 specifications.
2524ac72f5cSPhilipp Tomsich	  Hi-Speed (480 Mbps), Full-Speed (12 Mbps), and Low-Speed (1.5 Mbps)
2534ac72f5cSPhilipp Tomsich	  operation is compliant to the controller Supplement. If you want to
2544ac72f5cSPhilipp Tomsich	  enable this controller in host mode, say Y.
25542637fdaSAlexey Brodkin
25642637fdaSAlexey Brodkinif USB_DWC2
25742637fdaSAlexey Brodkinconfig USB_DWC2_BUFFER_SIZE
25842637fdaSAlexey Brodkin	int "Data buffer size in kB"
25942637fdaSAlexey Brodkin	default 64
26042637fdaSAlexey Brodkin	---help---
26142637fdaSAlexey Brodkin	  By default 64 kB buffer is used but if amount of RAM avaialble on
26242637fdaSAlexey Brodkin	  the target is not enough to accommodate allocation of buffer of
26342637fdaSAlexey Brodkin	  that size it is possible to shrink it. Smaller sizes should be fine
26442637fdaSAlexey Brodkin	  because larger transactions could be split in smaller ones.
26542637fdaSAlexey Brodkin
26642637fdaSAlexey Brodkinendif # USB_DWC2
267