1# SPDX-License-Identifier: GPL-2.0 2 3config USB_DWC3 4 tristate "DesignWare USB3 DRD Core Support" 5 depends on (USB || USB_GADGET) && HAS_DMA 6 depends on (EXTCON || EXTCON=n) 7 select USB_XHCI_PLATFORM if USB_XHCI_HCD 8 select USB_ROLE_SWITCH if USB_DWC3_DUAL_ROLE 9 help 10 Say Y or M here if your system has a Dual Role SuperSpeed 11 USB controller based on the DesignWare USB3 IP Core. 12 13 If you choose to build this driver as a dynamically linked 14 module, the module will be called dwc3.ko. 15 16if USB_DWC3 17 18config USB_DWC3_ULPI 19 bool "Register ULPI PHY Interface" 20 depends on USB_ULPI_BUS=y || USB_ULPI_BUS=USB_DWC3 21 help 22 Select this if you have ULPI type PHY attached to your DWC3 23 controller. 24 25choice 26 prompt "DWC3 Mode Selection" 27 default USB_DWC3_DUAL_ROLE if (USB && USB_GADGET) 28 default USB_DWC3_HOST if (USB && !USB_GADGET) 29 default USB_DWC3_GADGET if (!USB && USB_GADGET) 30 31config USB_DWC3_HOST 32 bool "Host only mode" 33 depends on USB=y || USB=USB_DWC3 34 help 35 Select this when you want to use DWC3 in host mode only, 36 thereby the gadget feature will be regressed. 37 38config USB_DWC3_GADGET 39 bool "Gadget only mode" 40 depends on USB_GADGET=y || USB_GADGET=USB_DWC3 41 help 42 Select this when you want to use DWC3 in gadget mode only, 43 thereby the host feature will be regressed. 44 45config USB_DWC3_DUAL_ROLE 46 bool "Dual Role mode" 47 depends on ((USB=y || USB=USB_DWC3) && (USB_GADGET=y || USB_GADGET=USB_DWC3)) 48 help 49 This is the default mode of working of DWC3 controller where 50 both host and gadget features are enabled. 51 52endchoice 53 54comment "Platform Glue Driver Support" 55 56config USB_DWC3_OMAP 57 tristate "Texas Instruments OMAP5 and similar Platforms" 58 depends on ARCH_OMAP2PLUS || COMPILE_TEST 59 depends on EXTCON || !EXTCON 60 depends on OF 61 default USB_DWC3 62 help 63 Some platforms from Texas Instruments like OMAP5, DRA7xxx and 64 AM437x use this IP for USB2/3 functionality. 65 66 Say 'Y' or 'M' here if you have one such device 67 68config USB_DWC3_EXYNOS 69 tristate "Samsung Exynos SoC Platform" 70 depends on (ARCH_EXYNOS || COMPILE_TEST) && OF 71 default USB_DWC3 72 help 73 Recent Samsung Exynos SoCs (Exynos5250, Exynos5410, Exynos542x, 74 Exynos5800, Exynos5433, Exynos7) ship with one DesignWare Core USB3 75 IP inside, say 'Y' or 'M' if you have one such device. 76 77config USB_DWC3_PCI 78 tristate "PCIe-based Platforms" 79 depends on USB_PCI && ACPI 80 default USB_DWC3 81 help 82 If you're using the DesignWare Core IP with a PCIe (but not HAPS 83 platform), please say 'Y' or 'M' here. 84 85config USB_DWC3_HAPS 86 tristate "Synopsys PCIe-based HAPS Platforms" 87 depends on USB_PCI 88 default USB_DWC3 89 help 90 If you're using the DesignWare Core IP with a Synopsys PCIe HAPS 91 platform, please say 'Y' or 'M' here. 92 93config USB_DWC3_KEYSTONE 94 tristate "Texas Instruments Keystone2/AM654 Platforms" 95 depends on ARCH_KEYSTONE || ARCH_K3 || COMPILE_TEST 96 default USB_DWC3 97 help 98 Support of USB2/3 functionality in TI Keystone2 and AM654 platforms. 99 Say 'Y' or 'M' here if you have one such device 100 101config USB_DWC3_MESON_G12A 102 tristate "Amlogic Meson G12A Platforms" 103 depends on OF && COMMON_CLK 104 depends on ARCH_MESON || COMPILE_TEST 105 default USB_DWC3 106 select USB_ROLE_SWITCH 107 select REGMAP_MMIO 108 help 109 Support USB2/3 functionality in Amlogic G12A platforms. 110 Say 'Y' or 'M' if you have one such device. 111 112config USB_DWC3_OF_SIMPLE 113 tristate "Generic OF Simple Glue Layer" 114 depends on OF && COMMON_CLK 115 default USB_DWC3 116 help 117 Support USB2/3 functionality in simple SoC integrations. 118 Currently supports Xilinx and Qualcomm DWC USB3 IP. 119 Say 'Y' or 'M' if you have one such device. 120 121config USB_DWC3_ST 122 tristate "STMicroelectronics Platforms" 123 depends on (ARCH_STI || COMPILE_TEST) && OF 124 default USB_DWC3 125 help 126 STMicroelectronics SoCs with one DesignWare Core USB3 IP 127 inside (i.e. STiH407). 128 Say 'Y' or 'M' if you have one such device. 129 130config USB_DWC3_QCOM 131 tristate "Qualcomm Platform" 132 depends on ARCH_QCOM || COMPILE_TEST 133 depends on EXTCON || !EXTCON 134 depends on OF 135 default USB_DWC3 136 help 137 Some Qualcomm SoCs use DesignWare Core IP for USB2/3 138 functionality. 139 This driver also handles Qscratch wrapper which is needed 140 for peripheral mode support. 141 Say 'Y' or 'M' if you have one such device. 142 143config USB_DWC3_IMX8MP 144 tristate "NXP iMX8MP Platform" 145 depends on OF && COMMON_CLK 146 depends on (ARCH_MXC && ARM64) || COMPILE_TEST 147 default USB_DWC3 148 help 149 NXP iMX8M Plus SoC use DesignWare Core IP for USB2/3 150 functionality. 151 Say 'Y' or 'M' if you have one such device. 152 153config USB_DWC3_IMX 154 tristate "NXP iMX Platform" 155 depends on OF && COMMON_CLK 156 depends on (ARCH_MXC && ARM64) || COMPILE_TEST 157 default USB_DWC3 158 help 159 NXP iMX SoC use DesignWare Core IP for USB2/3 160 functionality. 161 This driver also handles the wakeup feature outside 162 of DesignWare Core. 163 Say 'Y' or 'M' if you have one such device. 164 165config USB_DWC3_XILINX 166 tristate "Xilinx Platforms" 167 depends on (ARCH_ZYNQMP || COMPILE_TEST) && OF 168 default USB_DWC3 169 help 170 Support Xilinx SoCs with DesignWare Core USB3 IP. 171 This driver handles ZynqMP SoC operations. 172 Say 'Y' or 'M' if you have one such device. 173 174config USB_DWC3_AM62 175 tristate "Texas Instruments AM62 Platforms" 176 depends on ARCH_K3 || COMPILE_TEST 177 default USB_DWC3 178 help 179 Support TI's AM62 platforms with DesignWare Core USB3 IP. 180 The Designware Core USB3 IP is programmed to operate in 181 in USB 2.0 mode only. 182 Say 'Y' or 'M' here if you have one such device 183 184config USB_DWC3_OCTEON 185 tristate "Cavium Octeon Platforms" 186 depends on CAVIUM_OCTEON_SOC || COMPILE_TEST 187 default USB_DWC3 188 help 189 Support Cavium Octeon platforms with DesignWare Core USB3 IP. 190 Only the host mode is currently supported. 191 Say 'Y' or 'M' here if you have one such device. 192 193config USB_DWC3_RTK 194 tristate "Realtek DWC3 Platform Driver" 195 depends on OF && ARCH_REALTEK 196 default USB_DWC3 197 select USB_ROLE_SWITCH 198 help 199 RTK DHC RTD SoCs with DesignWare Core USB3 IP inside, 200 and IP Core configured for USB 2.0 and USB 3.0 in host 201 or dual-role mode. 202 Say 'Y' or 'M' if you have such device. 203 204config USB_DWC3_GENERIC_PLAT 205 tristate "DWC3 Generic Platform Driver" 206 depends on OF && COMMON_CLK 207 default USB_DWC3 208 help 209 Support USB3 functionality in simple SoC integrations. 210 Currently supports SpacemiT DWC USB3. Platforms using 211 dwc3-of-simple can easily switch to dwc3-generic by flattening 212 the dwc3 child node in the device tree. 213 Say 'Y' or 'M' here if your platform integrates DWC3 in a similar way. 214 215config USB_DWC3_APPLE 216 tristate "Apple Silicon DWC3 Platform Driver" 217 depends on OF && ARCH_APPLE 218 default USB_DWC3 219 select USB_ROLE_SWITCH 220 help 221 Support Apple Silicon SoCs with DesignWare Core USB3 IP. 222 The DesignWare Core USB3 IP has to be used in dual-role 223 mode on these machines. 224 Say 'Y' or 'M' if you have such device. 225 226config USB_DWC3_GOOGLE 227 tristate "Google Platform" 228 help 229 Support the DesignWare Core USB3 IP found on Google Tensor SoCs, 230 starting with the G5 generation (Laguna). This driver includes 231 support for hibernation in host mode. 232 Say 'Y' or 'M' if you have one such device. 233 234 To compile this driver as a module, choose M here: the 235 module will be called dwc3-google.ko. 236 237endif 238