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" 26103774b7SJean-Jacques Hiblot depends on DM_USB 27cc73ba97SJean-Jacques Hiblot default y if DRA7XX 28ca7fdc8bSNeil Armstrong help 29ca7fdc8bSNeil Armstrong Support USB2/3 functionality in simple SoC integrations with 30ca7fdc8bSNeil Armstrong USB controller based on the DesignWare USB3 IP Core. 31ca7fdc8bSNeil Armstrong 3281c1f6f0SStefan Roeseconfig USB_XHCI_MVEBU 3381c1f6f0SStefan Roese bool "MVEBU USB 3.0 support" 3481c1f6f0SStefan Roese default y 3581c1f6f0SStefan Roese depends on ARCH_MVEBU 3681192b79SKonstantin Porotchkin select DM_REGULATOR 3781c1f6f0SStefan Roese help 3881c1f6f0SStefan Roese Choose this option to add support for USB 3.0 driver on mvebu 3981c1f6f0SStefan Roese SoCs, which includes Armada8K, Armada3700 and other Armada 4081c1f6f0SStefan Roese family SoCs. 4181c1f6f0SStefan Roese 42d7cde281SBin Mengconfig USB_XHCI_PCI 43d7cde281SBin Meng bool "Support for PCI-based xHCI USB controller" 44978f6a3bSBin Meng depends on DM_USB 45d7cde281SBin Meng default y if X86 46d7cde281SBin Meng help 47d7cde281SBin Meng Enables support for the PCI-based xHCI controller. 48d7cde281SBin Meng 49f7bb27a5SKever Yangconfig USB_XHCI_ROCKCHIP 50f7bb27a5SKever Yang bool "Support for Rockchip on-chip xHCI USB controller" 51f7bb27a5SKever Yang depends on ARCH_ROCKCHIP 52e85f00abSMeng Dongyang depends on DM_REGULATOR 53e85f00abSMeng Dongyang depends on DM_USB 54f7bb27a5SKever Yang default y 55f7bb27a5SKever Yang help 56f7bb27a5SKever Yang Enables support for the on-chip xHCI controller on Rockchip SoCs. 57f7bb27a5SKever Yang 58e1cc60c0SMarek Vasutconfig USB_XHCI_RCAR 59e1cc60c0SMarek Vasut bool "Renesas RCar USB 3.0 support" 60e1cc60c0SMarek Vasut default y 61e1cc60c0SMarek Vasut depends on ARCH_RMOBILE 62e1cc60c0SMarek Vasut help 63e1cc60c0SMarek Vasut Choose this option to add support for USB 3.0 driver on Renesas 64e1cc60c0SMarek Vasut RCar Gen3 SoCs. 65e1cc60c0SMarek Vasut 6640d1a31eSPatrice Chotardconfig USB_XHCI_STI 6740d1a31eSPatrice Chotard bool "Support for STMicroelectronics STiH407 family on-chip xHCI USB controller" 6840d1a31eSPatrice Chotard depends on ARCH_STI 6940d1a31eSPatrice Chotard default y 7040d1a31eSPatrice Chotard help 7140d1a31eSPatrice Chotard Enables support for the on-chip xHCI controller on STMicroelectronics 7240d1a31eSPatrice Chotard STiH407 family SoCs. This is a driver for the dwc3 to provide the glue logic 7340d1a31eSPatrice Chotard to configure the controller. 7440d1a31eSPatrice Chotard 7563d74747SMichal Simekconfig USB_XHCI_ZYNQMP 7663d74747SMichal Simek bool "Support for Xilinx ZynqMP on-chip xHCI USB controller" 7763d74747SMichal Simek depends on ARCH_ZYNQMP 78d067624cSMichal Simek depends on DM_USB 7963d74747SMichal Simek help 8063d74747SMichal Simek Enables support for the on-chip xHCI controller on Xilinx ZynqMP SoCs. 8163d74747SMichal Simek 82ef3f3b81SUri Mashiachconfig USB_XHCI_DRA7XX_INDEX 83ef3f3b81SUri Mashiach int "DRA7XX xHCI USB index" 84ef3f3b81SUri Mashiach range 0 1 85ef3f3b81SUri Mashiach default 0 86ef3f3b81SUri Mashiach depends on DRA7XX 87ef3f3b81SUri Mashiach help 88ef3f3b81SUri Mashiach Select the DRA7XX xHCI USB index. 89ef3f3b81SUri Mashiach Current supported values: 0, 1. 90ef3f3b81SUri Mashiach 91420b0ebaSRan Wangconfig USB_XHCI_FSL 92420b0ebaSRan Wang bool "Support for NXP Layerscape on-chip xHCI USB controller" 93420b0ebaSRan Wang default y if ARCH_LS1021A || FSL_LSCH3 || FSL_LSCH2 94420b0ebaSRan Wang depends on !SPL_NO_USB 95420b0ebaSRan Wang help 96420b0ebaSRan Wang Enables support for the on-chip xHCI controller on NXP Layerscape SoCs. 9793cb8247SMasahiro Yamadaendif # USB_XHCI_HCD 98fee331f6SAlexey Brodkin 996e7e9294SMasahiro Yamadaconfig USB_EHCI_HCD 1006e7e9294SMasahiro Yamada bool "EHCI HCD (USB 2.0) support" 10164d6ac5bSTom Rini default y if ARCH_MX5 || ARCH_MX6 1022b58e1b7SMasahiro Yamada select USB_HOST 1036e7e9294SMasahiro Yamada ---help--- 1046e7e9294SMasahiro Yamada The Enhanced Host Controller Interface (EHCI) is standard for USB 2.0 1056e7e9294SMasahiro Yamada "high speed" (480 Mbit/sec, 60 Mbyte/sec) host controller hardware. 1066e7e9294SMasahiro Yamada If your USB host controller supports USB 2.0, you will likely want to 1076e7e9294SMasahiro Yamada configure this Host Controller Driver. 1086e7e9294SMasahiro Yamada 1096e7e9294SMasahiro Yamada EHCI controllers are packaged with "companion" host controllers (OHCI 1106e7e9294SMasahiro Yamada or UHCI) to handle USB 1.1 devices connected to root hub ports. Ports 1116e7e9294SMasahiro Yamada will connect to EHCI if the device is high speed, otherwise they 1126e7e9294SMasahiro Yamada connect to a companion controller. If you configure EHCI, you should 1136e7e9294SMasahiro Yamada probably configure the OHCI (for NEC and some other vendors) USB Host 1146e7e9294SMasahiro Yamada Controller Driver or UHCI (for Via motherboards) Host Controller 1156e7e9294SMasahiro Yamada Driver too. 1166e7e9294SMasahiro Yamada 1176e7e9294SMasahiro Yamada You may want to read <file:Documentation/usb/ehci.txt>. 1186e7e9294SMasahiro Yamada 1196e7e9294SMasahiro Yamadaif USB_EHCI_HCD 1206e7e9294SMasahiro Yamada 121*07a3afcfSryan_chenconfig USB_EHCI_ASPEED 122*07a3afcfSryan_chen bool "Support for Aspeed on-chip EHCI USB controller" 123*07a3afcfSryan_chen depends on ARCH_ASPEED 124*07a3afcfSryan_chen default y 125*07a3afcfSryan_chen ---help--- 126*07a3afcfSryan_chen Enables support for the on-chip EHCI controller on ASPEED chips. 127*07a3afcfSryan_chen 12817b68b5aSWenyou Yangconfig USB_EHCI_ATMEL 12917b68b5aSWenyou Yang bool "Support for Atmel on-chip EHCI USB controller" 13017b68b5aSWenyou Yang depends on ARCH_AT91 13117b68b5aSWenyou Yang default y 13217b68b5aSWenyou Yang ---help--- 13317b68b5aSWenyou Yang Enables support for the on-chip EHCI controller on Atmel chips. 13417b68b5aSWenyou Yang 135cd48225bSStefan Roeseconfig USB_EHCI_MARVELL 13680f1f320STom Rini bool "Support for Marvell on-chip EHCI USB controller" 13780f1f320STom Rini depends on ARCH_MVEBU || KIRKWOOD || ORION5X 138cd48225bSStefan Roese default y 139cd48225bSStefan Roese ---help--- 140cd48225bSStefan Roese Enables support for the on-chip EHCI controller on MVEBU SoCs. 141cd48225bSStefan Roese 142919e802cSNikita Kiryanovconfig USB_EHCI_MX6 143919e802cSNikita Kiryanov bool "Support for i.MX6 on-chip EHCI USB controller" 144919e802cSNikita Kiryanov depends on ARCH_MX6 145919e802cSNikita Kiryanov default y 146919e802cSNikita Kiryanov ---help--- 147919e802cSNikita Kiryanov Enables support for the on-chip EHCI controller on i.MX6 SoCs. 148919e802cSNikita Kiryanov 1492deebe24SStefan Agnerconfig USB_EHCI_MX7 1502deebe24SStefan Agner bool "Support for i.MX7 on-chip EHCI USB controller" 1512deebe24SStefan Agner depends on ARCH_MX7 1522deebe24SStefan Agner default y 1532deebe24SStefan Agner ---help--- 1542deebe24SStefan Agner Enables support for the on-chip EHCI controller on i.MX7 SoCs. 1552deebe24SStefan Agner 1561d1ab61cSTom Riniconfig USB_EHCI_OMAP 1571d1ab61cSTom Rini bool "Support for OMAP3+ on-chip EHCI USB controller" 1581d1ab61cSTom Rini depends on ARCH_OMAP2PLUS 1591d1ab61cSTom Rini default y 1601d1ab61cSTom Rini ---help--- 1611d1ab61cSTom Rini Enables support for the on-chip EHCI controller on OMAP3 and later 1621d1ab61cSTom Rini SoCs. 1631d1ab61cSTom Rini 164c4483093SStefan Agnerif USB_EHCI_MX7 165c4483093SStefan Agner 166c4483093SStefan Agnerconfig MXC_USB_OTG_HACTIVE 167c4483093SStefan Agner bool "USB Power pin high active" 168c4483093SStefan Agner ---help--- 169c4483093SStefan Agner Set the USB Power pin polarity to be high active (PWR_POL) 170c4483093SStefan Agner 171c4483093SStefan Agnerendif 172c4483093SStefan Agner 1735a822118SMateusz Kulikowskiconfig USB_EHCI_MSM 1745a822118SMateusz Kulikowski bool "Support for Qualcomm on-chip EHCI USB controller" 1755a822118SMateusz Kulikowski depends on DM_USB 1765a822118SMateusz Kulikowski select USB_ULPI_VIEWPORT 1770ac0b6ebSRamon Fried select MSM8916_USB_PHY 1785a822118SMateusz Kulikowski default n 1795a822118SMateusz Kulikowski ---help--- 1805a822118SMateusz Kulikowski Enables support for the on-chip EHCI controller on Qualcomm 1815a822118SMateusz Kulikowski Snapdragon SoCs. 1825a822118SMateusz Kulikowski 183a11a5b8aSBin Mengconfig USB_EHCI_PCI 184a11a5b8aSBin Meng bool "Support for PCI-based EHCI USB controller" 185a11a5b8aSBin Meng default y if X86 186a11a5b8aSBin Meng help 187a11a5b8aSBin Meng Enables support for the PCI-based EHCI controller. 188a11a5b8aSBin Meng 189747fed56SPeter Robinsonconfig USB_EHCI_TEGRA 190747fed56SPeter Robinson bool "Support for NVIDIA Tegra on-chip EHCI USB controller" 191747fed56SPeter Robinson depends on TEGRA 192747fed56SPeter Robinson ---help--- 193747fed56SPeter Robinson Enable support for Tegra on-chip EHCI USB controller 194747fed56SPeter Robinson 1952cdc778bSSiva Durga Prasad Paladuguconfig USB_EHCI_ZYNQ 1962cdc778bSSiva Durga Prasad Paladugu bool "Support for Xilinx Zynq on-chip EHCI USB controller" 1972cdc778bSSiva Durga Prasad Paladugu depends on ARCH_ZYNQ 1982cdc778bSSiva Durga Prasad Paladugu default y 1992cdc778bSSiva Durga Prasad Paladugu ---help--- 2002cdc778bSSiva Durga Prasad Paladugu Enable support for Zynq on-chip EHCI USB controller 2012cdc778bSSiva Durga Prasad Paladugu 20290fbb282SAlexey Brodkinconfig USB_EHCI_GENERIC 20390fbb282SAlexey Brodkin bool "Support for generic EHCI USB controller" 20490fbb282SAlexey Brodkin depends on OF_CONTROL 20590fbb282SAlexey Brodkin depends on DM_USB 20629d280c8SJagan Teki default ARCH_SUNXI 20790fbb282SAlexey Brodkin default n 20890fbb282SAlexey Brodkin ---help--- 20990fbb282SAlexey Brodkin Enables support for generic EHCI controller. 21090fbb282SAlexey Brodkin 21191f4fb9bSRan Wangconfig USB_EHCI_FSL 21291f4fb9bSRan Wang bool "Support for FSL on-chip EHCI USB controller" 21391f4fb9bSRan Wang default n 21491f4fb9bSRan Wang select CONFIG_EHCI_HCD_INIT_AFTER_RESET 21591f4fb9bSRan Wang ---help--- 21691f4fb9bSRan Wang Enables support for the on-chip EHCI controller on FSL chips. 21793cb8247SMasahiro Yamadaendif # USB_EHCI_HCD 21893cb8247SMasahiro Yamada 21993cb8247SMasahiro Yamadaconfig USB_OHCI_HCD 22093cb8247SMasahiro Yamada bool "OHCI HCD (USB 1.1) support" 22193cb8247SMasahiro Yamada ---help--- 22293cb8247SMasahiro Yamada The Open Host Controller Interface (OHCI) is a standard for accessing 22393cb8247SMasahiro Yamada USB 1.1 host controller hardware. It does more in hardware than Intel's 22493cb8247SMasahiro Yamada UHCI specification. If your USB host controller follows the OHCI spec, 22593cb8247SMasahiro Yamada say Y. On most non-x86 systems, and on x86 hardware that's not using a 22693cb8247SMasahiro Yamada USB controller from Intel or VIA, this is appropriate. If your host 22793cb8247SMasahiro Yamada controller doesn't use PCI, this is probably appropriate. For a PCI 22893cb8247SMasahiro Yamada based system where you're not sure, the "lspci -v" entry will list the 22993cb8247SMasahiro Yamada right "prog-if" for your USB controller(s): EHCI, OHCI, or UHCI. 23093cb8247SMasahiro Yamada 23193cb8247SMasahiro Yamadaif USB_OHCI_HCD 23293cb8247SMasahiro Yamada 23393cb8247SMasahiro Yamadaconfig USB_OHCI_GENERIC 23493cb8247SMasahiro Yamada bool "Support for generic OHCI USB controller" 23593cb8247SMasahiro Yamada depends on OF_CONTROL 23693cb8247SMasahiro Yamada depends on DM_USB 23729d280c8SJagan Teki default ARCH_SUNXI 2382b58e1b7SMasahiro Yamada select USB_HOST 23993cb8247SMasahiro Yamada ---help--- 24093cb8247SMasahiro Yamada Enables support for generic OHCI controller. 24193cb8247SMasahiro Yamada 24293cb8247SMasahiro Yamadaendif # USB_OHCI_HCD 24396d8284bSMasahiro Yamada 24496d8284bSMasahiro Yamadaconfig USB_UHCI_HCD 24596d8284bSMasahiro Yamada bool "UHCI HCD (most Intel and VIA) support" 2462b58e1b7SMasahiro Yamada select USB_HOST 24796d8284bSMasahiro Yamada ---help--- 24896d8284bSMasahiro Yamada The Universal Host Controller Interface is a standard by Intel for 24996d8284bSMasahiro Yamada accessing the USB hardware in the PC (which is also called the USB 25096d8284bSMasahiro Yamada host controller). If your USB host controller conforms to this 25196d8284bSMasahiro Yamada standard, you may want to say Y, but see below. All recent boards 25296d8284bSMasahiro Yamada with Intel PCI chipsets (like intel 430TX, 440FX, 440LX, 440BX, 25396d8284bSMasahiro Yamada i810, i820) conform to this standard. Also all VIA PCI chipsets 25496d8284bSMasahiro Yamada (like VIA VP2, VP3, MVP3, Apollo Pro, Apollo Pro II or Apollo Pro 25596d8284bSMasahiro Yamada 133) and LEON/GRLIB SoCs with the GRUSBHC controller. 25696d8284bSMasahiro Yamada If unsure, say Y. 25796d8284bSMasahiro Yamada 25896d8284bSMasahiro Yamadaif USB_UHCI_HCD 25996d8284bSMasahiro Yamada 26096d8284bSMasahiro Yamadaendif # USB_UHCI_HCD 2614ac72f5cSPhilipp Tomsich 2624ac72f5cSPhilipp Tomsichconfig USB_DWC2 2634ac72f5cSPhilipp Tomsich bool "DesignWare USB2 Core support" 2644ac72f5cSPhilipp Tomsich select USB_HOST 2654ac72f5cSPhilipp Tomsich ---help--- 2664ac72f5cSPhilipp Tomsich The DesignWare USB 2.0 controller is compliant with the 2674ac72f5cSPhilipp Tomsich USB-Implementers Forum (USB-IF) USB 2.0 specifications. 2684ac72f5cSPhilipp Tomsich Hi-Speed (480 Mbps), Full-Speed (12 Mbps), and Low-Speed (1.5 Mbps) 2694ac72f5cSPhilipp Tomsich operation is compliant to the controller Supplement. If you want to 2704ac72f5cSPhilipp Tomsich enable this controller in host mode, say Y. 27142637fdaSAlexey Brodkin 27242637fdaSAlexey Brodkinif USB_DWC2 27342637fdaSAlexey Brodkinconfig USB_DWC2_BUFFER_SIZE 27442637fdaSAlexey Brodkin int "Data buffer size in kB" 27542637fdaSAlexey Brodkin default 64 27642637fdaSAlexey Brodkin ---help--- 27742637fdaSAlexey Brodkin By default 64 kB buffer is used but if amount of RAM avaialble on 27842637fdaSAlexey Brodkin the target is not enough to accommodate allocation of buffer of 27942637fdaSAlexey Brodkin that size it is possible to shrink it. Smaller sizes should be fine 28042637fdaSAlexey Brodkin because larger transactions could be split in smaller ones. 28142637fdaSAlexey Brodkin 28242637fdaSAlexey Brodkinendif # USB_DWC2 283