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 27*cc73ba97SJean-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 7863d74747SMichal Simek help 7963d74747SMichal Simek Enables support for the on-chip xHCI controller on Xilinx ZynqMP SoCs. 8063d74747SMichal Simek 81ef3f3b81SUri Mashiachconfig USB_XHCI_DRA7XX_INDEX 82ef3f3b81SUri Mashiach int "DRA7XX xHCI USB index" 83ef3f3b81SUri Mashiach range 0 1 84ef3f3b81SUri Mashiach default 0 85ef3f3b81SUri Mashiach depends on DRA7XX 86ef3f3b81SUri Mashiach help 87ef3f3b81SUri Mashiach Select the DRA7XX xHCI USB index. 88ef3f3b81SUri Mashiach Current supported values: 0, 1. 89ef3f3b81SUri Mashiach 90420b0ebaSRan Wangconfig USB_XHCI_FSL 91420b0ebaSRan Wang bool "Support for NXP Layerscape on-chip xHCI USB controller" 92420b0ebaSRan Wang default y if ARCH_LS1021A || FSL_LSCH3 || FSL_LSCH2 93420b0ebaSRan Wang depends on !SPL_NO_USB 94420b0ebaSRan Wang help 95420b0ebaSRan Wang Enables support for the on-chip xHCI controller on NXP Layerscape SoCs. 9693cb8247SMasahiro Yamadaendif # USB_XHCI_HCD 97fee331f6SAlexey Brodkin 986e7e9294SMasahiro Yamadaconfig USB_EHCI_HCD 996e7e9294SMasahiro Yamada bool "EHCI HCD (USB 2.0) support" 10064d6ac5bSTom Rini default y if ARCH_MX5 || ARCH_MX6 1012b58e1b7SMasahiro Yamada select USB_HOST 1026e7e9294SMasahiro Yamada ---help--- 1036e7e9294SMasahiro Yamada The Enhanced Host Controller Interface (EHCI) is standard for USB 2.0 1046e7e9294SMasahiro Yamada "high speed" (480 Mbit/sec, 60 Mbyte/sec) host controller hardware. 1056e7e9294SMasahiro Yamada If your USB host controller supports USB 2.0, you will likely want to 1066e7e9294SMasahiro Yamada configure this Host Controller Driver. 1076e7e9294SMasahiro Yamada 1086e7e9294SMasahiro Yamada EHCI controllers are packaged with "companion" host controllers (OHCI 1096e7e9294SMasahiro Yamada or UHCI) to handle USB 1.1 devices connected to root hub ports. Ports 1106e7e9294SMasahiro Yamada will connect to EHCI if the device is high speed, otherwise they 1116e7e9294SMasahiro Yamada connect to a companion controller. If you configure EHCI, you should 1126e7e9294SMasahiro Yamada probably configure the OHCI (for NEC and some other vendors) USB Host 1136e7e9294SMasahiro Yamada Controller Driver or UHCI (for Via motherboards) Host Controller 1146e7e9294SMasahiro Yamada Driver too. 1156e7e9294SMasahiro Yamada 1166e7e9294SMasahiro Yamada You may want to read <file:Documentation/usb/ehci.txt>. 1176e7e9294SMasahiro Yamada 1186e7e9294SMasahiro Yamadaif USB_EHCI_HCD 1196e7e9294SMasahiro Yamada 12017b68b5aSWenyou Yangconfig USB_EHCI_ATMEL 12117b68b5aSWenyou Yang bool "Support for Atmel on-chip EHCI USB controller" 12217b68b5aSWenyou Yang depends on ARCH_AT91 12317b68b5aSWenyou Yang default y 12417b68b5aSWenyou Yang ---help--- 12517b68b5aSWenyou Yang Enables support for the on-chip EHCI controller on Atmel chips. 12617b68b5aSWenyou Yang 127cd48225bSStefan Roeseconfig USB_EHCI_MARVELL 12880f1f320STom Rini bool "Support for Marvell on-chip EHCI USB controller" 12980f1f320STom Rini depends on ARCH_MVEBU || KIRKWOOD || ORION5X 130cd48225bSStefan Roese default y 131cd48225bSStefan Roese ---help--- 132cd48225bSStefan Roese Enables support for the on-chip EHCI controller on MVEBU SoCs. 133cd48225bSStefan Roese 134919e802cSNikita Kiryanovconfig USB_EHCI_MX6 135919e802cSNikita Kiryanov bool "Support for i.MX6 on-chip EHCI USB controller" 136919e802cSNikita Kiryanov depends on ARCH_MX6 137919e802cSNikita Kiryanov default y 138919e802cSNikita Kiryanov ---help--- 139919e802cSNikita Kiryanov Enables support for the on-chip EHCI controller on i.MX6 SoCs. 140919e802cSNikita Kiryanov 1412deebe24SStefan Agnerconfig USB_EHCI_MX7 1422deebe24SStefan Agner bool "Support for i.MX7 on-chip EHCI USB controller" 1432deebe24SStefan Agner depends on ARCH_MX7 1442deebe24SStefan Agner default y 1452deebe24SStefan Agner ---help--- 1462deebe24SStefan Agner Enables support for the on-chip EHCI controller on i.MX7 SoCs. 1472deebe24SStefan Agner 1481d1ab61cSTom Riniconfig USB_EHCI_OMAP 1491d1ab61cSTom Rini bool "Support for OMAP3+ on-chip EHCI USB controller" 1501d1ab61cSTom Rini depends on ARCH_OMAP2PLUS 1511d1ab61cSTom Rini default y 1521d1ab61cSTom Rini ---help--- 1531d1ab61cSTom Rini Enables support for the on-chip EHCI controller on OMAP3 and later 1541d1ab61cSTom Rini SoCs. 1551d1ab61cSTom Rini 156c4483093SStefan Agnerif USB_EHCI_MX7 157c4483093SStefan Agner 158c4483093SStefan Agnerconfig MXC_USB_OTG_HACTIVE 159c4483093SStefan Agner bool "USB Power pin high active" 160c4483093SStefan Agner ---help--- 161c4483093SStefan Agner Set the USB Power pin polarity to be high active (PWR_POL) 162c4483093SStefan Agner 163c4483093SStefan Agnerendif 164c4483093SStefan Agner 1655a822118SMateusz Kulikowskiconfig USB_EHCI_MSM 1665a822118SMateusz Kulikowski bool "Support for Qualcomm on-chip EHCI USB controller" 1675a822118SMateusz Kulikowski depends on DM_USB 1685a822118SMateusz Kulikowski select USB_ULPI_VIEWPORT 1695a822118SMateusz Kulikowski default n 1705a822118SMateusz Kulikowski ---help--- 1715a822118SMateusz Kulikowski Enables support for the on-chip EHCI controller on Qualcomm 1725a822118SMateusz Kulikowski Snapdragon SoCs. 1735a822118SMateusz Kulikowski This driver supports combination of Chipidea USB controller 1745a822118SMateusz Kulikowski and Synapsys USB PHY in host mode only. 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 19390fbb282SAlexey Brodkin default n 19490fbb282SAlexey Brodkin ---help--- 19590fbb282SAlexey Brodkin Enables support for generic EHCI controller. 19690fbb282SAlexey Brodkin 19791f4fb9bSRan Wangconfig USB_EHCI_FSL 19891f4fb9bSRan Wang bool "Support for FSL on-chip EHCI USB controller" 19991f4fb9bSRan Wang default n 20091f4fb9bSRan Wang select CONFIG_EHCI_HCD_INIT_AFTER_RESET 20191f4fb9bSRan Wang ---help--- 20291f4fb9bSRan Wang Enables support for the on-chip EHCI controller on FSL chips. 20393cb8247SMasahiro Yamadaendif # USB_EHCI_HCD 20493cb8247SMasahiro Yamada 20593cb8247SMasahiro Yamadaconfig USB_OHCI_HCD 20693cb8247SMasahiro Yamada bool "OHCI HCD (USB 1.1) support" 20793cb8247SMasahiro Yamada ---help--- 20893cb8247SMasahiro Yamada The Open Host Controller Interface (OHCI) is a standard for accessing 20993cb8247SMasahiro Yamada USB 1.1 host controller hardware. It does more in hardware than Intel's 21093cb8247SMasahiro Yamada UHCI specification. If your USB host controller follows the OHCI spec, 21193cb8247SMasahiro Yamada say Y. On most non-x86 systems, and on x86 hardware that's not using a 21293cb8247SMasahiro Yamada USB controller from Intel or VIA, this is appropriate. If your host 21393cb8247SMasahiro Yamada controller doesn't use PCI, this is probably appropriate. For a PCI 21493cb8247SMasahiro Yamada based system where you're not sure, the "lspci -v" entry will list the 21593cb8247SMasahiro Yamada right "prog-if" for your USB controller(s): EHCI, OHCI, or UHCI. 21693cb8247SMasahiro Yamada 21793cb8247SMasahiro Yamadaif USB_OHCI_HCD 21893cb8247SMasahiro Yamada 21993cb8247SMasahiro Yamadaconfig USB_OHCI_GENERIC 22093cb8247SMasahiro Yamada bool "Support for generic OHCI USB controller" 22193cb8247SMasahiro Yamada depends on OF_CONTROL 22293cb8247SMasahiro Yamada depends on DM_USB 2232b58e1b7SMasahiro Yamada select USB_HOST 22493cb8247SMasahiro Yamada ---help--- 22593cb8247SMasahiro Yamada Enables support for generic OHCI controller. 22693cb8247SMasahiro Yamada 22793cb8247SMasahiro Yamadaendif # USB_OHCI_HCD 22896d8284bSMasahiro Yamada 22996d8284bSMasahiro Yamadaconfig USB_UHCI_HCD 23096d8284bSMasahiro Yamada bool "UHCI HCD (most Intel and VIA) support" 2312b58e1b7SMasahiro Yamada select USB_HOST 23296d8284bSMasahiro Yamada ---help--- 23396d8284bSMasahiro Yamada The Universal Host Controller Interface is a standard by Intel for 23496d8284bSMasahiro Yamada accessing the USB hardware in the PC (which is also called the USB 23596d8284bSMasahiro Yamada host controller). If your USB host controller conforms to this 23696d8284bSMasahiro Yamada standard, you may want to say Y, but see below. All recent boards 23796d8284bSMasahiro Yamada with Intel PCI chipsets (like intel 430TX, 440FX, 440LX, 440BX, 23896d8284bSMasahiro Yamada i810, i820) conform to this standard. Also all VIA PCI chipsets 23996d8284bSMasahiro Yamada (like VIA VP2, VP3, MVP3, Apollo Pro, Apollo Pro II or Apollo Pro 24096d8284bSMasahiro Yamada 133) and LEON/GRLIB SoCs with the GRUSBHC controller. 24196d8284bSMasahiro Yamada If unsure, say Y. 24296d8284bSMasahiro Yamada 24396d8284bSMasahiro Yamadaif USB_UHCI_HCD 24496d8284bSMasahiro Yamada 24596d8284bSMasahiro Yamadaendif # USB_UHCI_HCD 2464ac72f5cSPhilipp Tomsich 2474ac72f5cSPhilipp Tomsichconfig USB_DWC2 2484ac72f5cSPhilipp Tomsich bool "DesignWare USB2 Core support" 2494ac72f5cSPhilipp Tomsich select USB_HOST 2504ac72f5cSPhilipp Tomsich ---help--- 2514ac72f5cSPhilipp Tomsich The DesignWare USB 2.0 controller is compliant with the 2524ac72f5cSPhilipp Tomsich USB-Implementers Forum (USB-IF) USB 2.0 specifications. 2534ac72f5cSPhilipp Tomsich Hi-Speed (480 Mbps), Full-Speed (12 Mbps), and Low-Speed (1.5 Mbps) 2544ac72f5cSPhilipp Tomsich operation is compliant to the controller Supplement. If you want to 2554ac72f5cSPhilipp Tomsich enable this controller in host mode, say Y. 25642637fdaSAlexey Brodkin 25742637fdaSAlexey Brodkinif USB_DWC2 25842637fdaSAlexey Brodkinconfig USB_DWC2_BUFFER_SIZE 25942637fdaSAlexey Brodkin int "Data buffer size in kB" 26042637fdaSAlexey Brodkin default 64 26142637fdaSAlexey Brodkin ---help--- 26242637fdaSAlexey Brodkin By default 64 kB buffer is used but if amount of RAM avaialble on 26342637fdaSAlexey Brodkin the target is not enough to accommodate allocation of buffer of 26442637fdaSAlexey Brodkin that size it is possible to shrink it. Smaller sizes should be fine 26542637fdaSAlexey Brodkin because larger transactions could be split in smaller ones. 26642637fdaSAlexey Brodkin 26742637fdaSAlexey Brodkinendif # USB_DWC2 268