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 12117b68b5aSWenyou Yangconfig USB_EHCI_ATMEL 12217b68b5aSWenyou Yang bool "Support for Atmel on-chip EHCI USB controller" 12317b68b5aSWenyou Yang depends on ARCH_AT91 12417b68b5aSWenyou Yang default y 12517b68b5aSWenyou Yang ---help--- 12617b68b5aSWenyou Yang Enables support for the on-chip EHCI controller on Atmel chips. 12717b68b5aSWenyou Yang 128cd48225bSStefan Roeseconfig USB_EHCI_MARVELL 12980f1f320STom Rini bool "Support for Marvell on-chip EHCI USB controller" 13080f1f320STom Rini depends on ARCH_MVEBU || KIRKWOOD || ORION5X 131cd48225bSStefan Roese default y 132cd48225bSStefan Roese ---help--- 133cd48225bSStefan Roese Enables support for the on-chip EHCI controller on MVEBU SoCs. 134cd48225bSStefan Roese 135919e802cSNikita Kiryanovconfig USB_EHCI_MX6 136919e802cSNikita Kiryanov bool "Support for i.MX6 on-chip EHCI USB controller" 137919e802cSNikita Kiryanov depends on ARCH_MX6 138919e802cSNikita Kiryanov default y 139919e802cSNikita Kiryanov ---help--- 140919e802cSNikita Kiryanov Enables support for the on-chip EHCI controller on i.MX6 SoCs. 141919e802cSNikita Kiryanov 1422deebe24SStefan Agnerconfig USB_EHCI_MX7 1432deebe24SStefan Agner bool "Support for i.MX7 on-chip EHCI USB controller" 1442deebe24SStefan Agner depends on ARCH_MX7 1452deebe24SStefan Agner default y 1462deebe24SStefan Agner ---help--- 1472deebe24SStefan Agner Enables support for the on-chip EHCI controller on i.MX7 SoCs. 1482deebe24SStefan Agner 1491d1ab61cSTom Riniconfig USB_EHCI_OMAP 1501d1ab61cSTom Rini bool "Support for OMAP3+ on-chip EHCI USB controller" 1511d1ab61cSTom Rini depends on ARCH_OMAP2PLUS 1521d1ab61cSTom Rini default y 1531d1ab61cSTom Rini ---help--- 1541d1ab61cSTom Rini Enables support for the on-chip EHCI controller on OMAP3 and later 1551d1ab61cSTom Rini SoCs. 1561d1ab61cSTom Rini 157c4483093SStefan Agnerif USB_EHCI_MX7 158c4483093SStefan Agner 159c4483093SStefan Agnerconfig MXC_USB_OTG_HACTIVE 160c4483093SStefan Agner bool "USB Power pin high active" 161c4483093SStefan Agner ---help--- 162c4483093SStefan Agner Set the USB Power pin polarity to be high active (PWR_POL) 163c4483093SStefan Agner 164c4483093SStefan Agnerendif 165c4483093SStefan Agner 1665a822118SMateusz Kulikowskiconfig USB_EHCI_MSM 1675a822118SMateusz Kulikowski bool "Support for Qualcomm on-chip EHCI USB controller" 1685a822118SMateusz Kulikowski depends on DM_USB 1695a822118SMateusz Kulikowski select USB_ULPI_VIEWPORT 1700ac0b6ebSRamon Fried select MSM8916_USB_PHY 1715a822118SMateusz Kulikowski default n 1725a822118SMateusz Kulikowski ---help--- 1735a822118SMateusz Kulikowski Enables support for the on-chip EHCI controller on Qualcomm 1745a822118SMateusz Kulikowski Snapdragon SoCs. 1755a822118SMateusz Kulikowski 176a11a5b8aSBin Mengconfig USB_EHCI_PCI 177a11a5b8aSBin Meng bool "Support for PCI-based EHCI USB controller" 178a11a5b8aSBin Meng default y if X86 179a11a5b8aSBin Meng help 180a11a5b8aSBin Meng Enables support for the PCI-based EHCI controller. 181a11a5b8aSBin Meng 1822cdc778bSSiva Durga Prasad Paladuguconfig USB_EHCI_ZYNQ 1832cdc778bSSiva Durga Prasad Paladugu bool "Support for Xilinx Zynq on-chip EHCI USB controller" 1842cdc778bSSiva Durga Prasad Paladugu depends on ARCH_ZYNQ 1852cdc778bSSiva Durga Prasad Paladugu default y 1862cdc778bSSiva Durga Prasad Paladugu ---help--- 1872cdc778bSSiva Durga Prasad Paladugu Enable support for Zynq on-chip EHCI USB controller 1882cdc778bSSiva Durga Prasad Paladugu 18990fbb282SAlexey Brodkinconfig USB_EHCI_GENERIC 19090fbb282SAlexey Brodkin bool "Support for generic EHCI USB controller" 19190fbb282SAlexey Brodkin depends on OF_CONTROL 19290fbb282SAlexey Brodkin depends on DM_USB 193*29d280c8SJagan Teki default ARCH_SUNXI 19490fbb282SAlexey Brodkin default n 19590fbb282SAlexey Brodkin ---help--- 19690fbb282SAlexey Brodkin Enables support for generic EHCI controller. 19790fbb282SAlexey Brodkin 19891f4fb9bSRan Wangconfig USB_EHCI_FSL 19991f4fb9bSRan Wang bool "Support for FSL on-chip EHCI USB controller" 20091f4fb9bSRan Wang default n 20191f4fb9bSRan Wang select CONFIG_EHCI_HCD_INIT_AFTER_RESET 20291f4fb9bSRan Wang ---help--- 20391f4fb9bSRan Wang Enables support for the on-chip EHCI controller on FSL chips. 20493cb8247SMasahiro Yamadaendif # USB_EHCI_HCD 20593cb8247SMasahiro Yamada 20693cb8247SMasahiro Yamadaconfig USB_OHCI_HCD 20793cb8247SMasahiro Yamada bool "OHCI HCD (USB 1.1) support" 20893cb8247SMasahiro Yamada ---help--- 20993cb8247SMasahiro Yamada The Open Host Controller Interface (OHCI) is a standard for accessing 21093cb8247SMasahiro Yamada USB 1.1 host controller hardware. It does more in hardware than Intel's 21193cb8247SMasahiro Yamada UHCI specification. If your USB host controller follows the OHCI spec, 21293cb8247SMasahiro Yamada say Y. On most non-x86 systems, and on x86 hardware that's not using a 21393cb8247SMasahiro Yamada USB controller from Intel or VIA, this is appropriate. If your host 21493cb8247SMasahiro Yamada controller doesn't use PCI, this is probably appropriate. For a PCI 21593cb8247SMasahiro Yamada based system where you're not sure, the "lspci -v" entry will list the 21693cb8247SMasahiro Yamada right "prog-if" for your USB controller(s): EHCI, OHCI, or UHCI. 21793cb8247SMasahiro Yamada 21893cb8247SMasahiro Yamadaif USB_OHCI_HCD 21993cb8247SMasahiro Yamada 22093cb8247SMasahiro Yamadaconfig USB_OHCI_GENERIC 22193cb8247SMasahiro Yamada bool "Support for generic OHCI USB controller" 22293cb8247SMasahiro Yamada depends on OF_CONTROL 22393cb8247SMasahiro Yamada depends on DM_USB 224*29d280c8SJagan Teki default ARCH_SUNXI 2252b58e1b7SMasahiro Yamada select USB_HOST 22693cb8247SMasahiro Yamada ---help--- 22793cb8247SMasahiro Yamada Enables support for generic OHCI controller. 22893cb8247SMasahiro Yamada 22993cb8247SMasahiro Yamadaendif # USB_OHCI_HCD 23096d8284bSMasahiro Yamada 23196d8284bSMasahiro Yamadaconfig USB_UHCI_HCD 23296d8284bSMasahiro Yamada bool "UHCI HCD (most Intel and VIA) support" 2332b58e1b7SMasahiro Yamada select USB_HOST 23496d8284bSMasahiro Yamada ---help--- 23596d8284bSMasahiro Yamada The Universal Host Controller Interface is a standard by Intel for 23696d8284bSMasahiro Yamada accessing the USB hardware in the PC (which is also called the USB 23796d8284bSMasahiro Yamada host controller). If your USB host controller conforms to this 23896d8284bSMasahiro Yamada standard, you may want to say Y, but see below. All recent boards 23996d8284bSMasahiro Yamada with Intel PCI chipsets (like intel 430TX, 440FX, 440LX, 440BX, 24096d8284bSMasahiro Yamada i810, i820) conform to this standard. Also all VIA PCI chipsets 24196d8284bSMasahiro Yamada (like VIA VP2, VP3, MVP3, Apollo Pro, Apollo Pro II or Apollo Pro 24296d8284bSMasahiro Yamada 133) and LEON/GRLIB SoCs with the GRUSBHC controller. 24396d8284bSMasahiro Yamada If unsure, say Y. 24496d8284bSMasahiro Yamada 24596d8284bSMasahiro Yamadaif USB_UHCI_HCD 24696d8284bSMasahiro Yamada 24796d8284bSMasahiro Yamadaendif # USB_UHCI_HCD 2484ac72f5cSPhilipp Tomsich 2494ac72f5cSPhilipp Tomsichconfig USB_DWC2 2504ac72f5cSPhilipp Tomsich bool "DesignWare USB2 Core support" 2514ac72f5cSPhilipp Tomsich select USB_HOST 2524ac72f5cSPhilipp Tomsich ---help--- 2534ac72f5cSPhilipp Tomsich The DesignWare USB 2.0 controller is compliant with the 2544ac72f5cSPhilipp Tomsich USB-Implementers Forum (USB-IF) USB 2.0 specifications. 2554ac72f5cSPhilipp Tomsich Hi-Speed (480 Mbps), Full-Speed (12 Mbps), and Low-Speed (1.5 Mbps) 2564ac72f5cSPhilipp Tomsich operation is compliant to the controller Supplement. If you want to 2574ac72f5cSPhilipp Tomsich enable this controller in host mode, say Y. 25842637fdaSAlexey Brodkin 25942637fdaSAlexey Brodkinif USB_DWC2 26042637fdaSAlexey Brodkinconfig USB_DWC2_BUFFER_SIZE 26142637fdaSAlexey Brodkin int "Data buffer size in kB" 26242637fdaSAlexey Brodkin default 64 26342637fdaSAlexey Brodkin ---help--- 26442637fdaSAlexey Brodkin By default 64 kB buffer is used but if amount of RAM avaialble on 26542637fdaSAlexey Brodkin the target is not enough to accommodate allocation of buffer of 26642637fdaSAlexey Brodkin that size it is possible to shrink it. Smaller sizes should be fine 26742637fdaSAlexey Brodkin because larger transactions could be split in smaller ones. 26842637fdaSAlexey Brodkin 26942637fdaSAlexey Brodkinendif # USB_DWC2 270