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