1a9770eacSAndrew Lunn# SPDX-License-Identifier: GPL-2.0-only 2a9770eacSAndrew Lunn# 3a9770eacSAndrew Lunn# MDIO Layer Configuration 4a9770eacSAndrew Lunn# 5a9770eacSAndrew Lunn 6a3e1c0adSHeiner Kallweitif PHYLIB 7a3e1c0adSHeiner Kallweit 8bc1bee3bSCalvin Johnsonconfig FWNODE_MDIO 9a3e1c0adSHeiner Kallweit def_tristate (ACPI || OF) || COMPILE_TEST 10bc1bee3bSCalvin Johnson select FIXED_PHY 11bc1bee3bSCalvin Johnson help 12bc1bee3bSCalvin Johnson FWNODE MDIO bus (Ethernet PHY) accessors 13bc1bee3bSCalvin Johnson 1414b26b12SCalvin Johnsonconfig OF_MDIO 15a3e1c0adSHeiner Kallweit def_tristate OF 1614b26b12SCalvin Johnson select FIXED_PHY 1714b26b12SCalvin Johnson help 1814b26b12SCalvin Johnson OpenFirmware MDIO bus (Ethernet PHY) accessors 1914b26b12SCalvin Johnson 20803ca24dSCalvin Johnsonconfig ACPI_MDIO 21a3e1c0adSHeiner Kallweit def_tristate ACPI 22803ca24dSCalvin Johnson help 23803ca24dSCalvin Johnson ACPI MDIO bus (Ethernet PHY) accessors 24803ca24dSCalvin Johnson 25*67e3ba97SChristian Marangiconfig MDIO_AIROHA 26*67e3ba97SChristian Marangi tristate "Airoha AN7583 MDIO bus controller" 27*67e3ba97SChristian Marangi depends on ARCH_AIROHA || COMPILE_TEST 28*67e3ba97SChristian Marangi help 29*67e3ba97SChristian Marangi This module provides a driver for the MDIO busses found in the 30*67e3ba97SChristian Marangi Airoha AN7583 SoC's. 31*67e3ba97SChristian Marangi 32a9770eacSAndrew Lunnconfig MDIO_SUN4I 33a9770eacSAndrew Lunn tristate "Allwinner sun4i MDIO interface support" 34a9770eacSAndrew Lunn depends on ARCH_SUNXI || COMPILE_TEST 35a9770eacSAndrew Lunn help 36a9770eacSAndrew Lunn This driver supports the MDIO interface found in the network 37a9770eacSAndrew Lunn interface units of the Allwinner SoC that have an EMAC (A10, 38a9770eacSAndrew Lunn A12, A10s, etc.) 39a9770eacSAndrew Lunn 40a9770eacSAndrew Lunnconfig MDIO_XGENE 41a9770eacSAndrew Lunn tristate "APM X-Gene SoC MDIO bus controller" 42a9770eacSAndrew Lunn depends on ARCH_XGENE || COMPILE_TEST 43a9770eacSAndrew Lunn help 44a9770eacSAndrew Lunn This module provides a driver for the MDIO busses found in the 45a9770eacSAndrew Lunn APM X-Gene SoC's. 46a9770eacSAndrew Lunn 47a9770eacSAndrew Lunnconfig MDIO_ASPEED 48a9770eacSAndrew Lunn tristate "ASPEED MDIO bus controller" 49a9770eacSAndrew Lunn depends on ARCH_ASPEED || COMPILE_TEST 50a9770eacSAndrew Lunn depends on OF_MDIO && HAS_IOMEM 51a9770eacSAndrew Lunn help 52a9770eacSAndrew Lunn This module provides a driver for the independent MDIO bus 53a9770eacSAndrew Lunn controllers found in the ASPEED AST2600 SoC. This is a driver for the 54a9770eacSAndrew Lunn third revision of the ASPEED MDIO register interface - the first two 55a9770eacSAndrew Lunn revisions are the "old" and "new" interfaces found in the AST2400 and 56a9770eacSAndrew Lunn AST2500, embedded in the MAC. For legacy reasons, FTGMAC100 driver 57a9770eacSAndrew Lunn continues to drive the embedded MDIO controller for the AST2400 and 58a9770eacSAndrew Lunn AST2500 SoCs, so say N if AST2600 support is not required. 59a9770eacSAndrew Lunn 60a9770eacSAndrew Lunnconfig MDIO_BITBANG 61a9770eacSAndrew Lunn tristate "Bitbanged MDIO buses" 62a9770eacSAndrew Lunn help 63a9770eacSAndrew Lunn This module implements the MDIO bus protocol in software, 64a9770eacSAndrew Lunn for use by low level drivers that export the ability to 65a9770eacSAndrew Lunn drive the relevant pins. 66a9770eacSAndrew Lunn 67a9770eacSAndrew Lunn If in doubt, say N. 68a9770eacSAndrew Lunn 69a9770eacSAndrew Lunnconfig MDIO_BCM_IPROC 70a9770eacSAndrew Lunn tristate "Broadcom iProc MDIO bus controller" 71a9770eacSAndrew Lunn depends on ARCH_BCM_IPROC || COMPILE_TEST 72a9770eacSAndrew Lunn depends on HAS_IOMEM && OF_MDIO 73a9770eacSAndrew Lunn default ARCH_BCM_IPROC 74a9770eacSAndrew Lunn help 75a9770eacSAndrew Lunn This module provides a driver for the MDIO busses found in the 76a9770eacSAndrew Lunn Broadcom iProc SoC's. 77a9770eacSAndrew Lunn 78a9770eacSAndrew Lunnconfig MDIO_BCM_UNIMAC 79a9770eacSAndrew Lunn tristate "Broadcom UniMAC MDIO bus controller" 80a9770eacSAndrew Lunn depends on HAS_IOMEM 81a9770eacSAndrew Lunn help 82a9770eacSAndrew Lunn This module provides a driver for the Broadcom UniMAC MDIO busses. 83a9770eacSAndrew Lunn This hardware can be found in the Broadcom GENET Ethernet MAC 84a9770eacSAndrew Lunn controllers as well as some Broadcom Ethernet switches such as the 85a9770eacSAndrew Lunn Starfighter 2 switches. 86a9770eacSAndrew Lunn 87a9770eacSAndrew Lunnconfig MDIO_CAVIUM 88a9770eacSAndrew Lunn tristate 89a9770eacSAndrew Lunn 90a9770eacSAndrew Lunnconfig MDIO_GPIO 91a9770eacSAndrew Lunn tristate "GPIO lib-based bitbanged MDIO buses" 92a9770eacSAndrew Lunn depends on MDIO_BITBANG 93a9770eacSAndrew Lunn depends on GPIOLIB || COMPILE_TEST 94a9770eacSAndrew Lunn help 95a9770eacSAndrew Lunn Supports GPIO lib-based MDIO busses. 96a9770eacSAndrew Lunn 97a9770eacSAndrew Lunn To compile this driver as a module, choose M here: the module 98a9770eacSAndrew Lunn will be called mdio-gpio. 99a9770eacSAndrew Lunn 100a9770eacSAndrew Lunnconfig MDIO_HISI_FEMAC 101a9770eacSAndrew Lunn tristate "Hisilicon FEMAC MDIO bus controller" 102a9770eacSAndrew Lunn depends on HAS_IOMEM && OF_MDIO 103a9770eacSAndrew Lunn help 104a9770eacSAndrew Lunn This module provides a driver for the MDIO busses found in the 105a9770eacSAndrew Lunn Hisilicon SoC that have an Fast Ethernet MAC. 106a9770eacSAndrew Lunn 107a9770eacSAndrew Lunnconfig MDIO_I2C 108a9770eacSAndrew Lunn tristate 109a9770eacSAndrew Lunn depends on I2C 110a9770eacSAndrew Lunn help 111a9770eacSAndrew Lunn Support I2C based PHYs. This provides a MDIO bus bridged 112a9770eacSAndrew Lunn to I2C to allow PHYs connected in I2C mode to be accessed 113a9770eacSAndrew Lunn using the existing infrastructure. 114a9770eacSAndrew Lunn 115a9770eacSAndrew Lunn This is library mode. 116a9770eacSAndrew Lunn 117a9770eacSAndrew Lunnconfig MDIO_MVUSB 118a9770eacSAndrew Lunn tristate "Marvell USB to MDIO Adapter" 119a9770eacSAndrew Lunn depends on USB 120a9770eacSAndrew Lunn help 121a9770eacSAndrew Lunn A USB to MDIO converter present on development boards for 122a9770eacSAndrew Lunn Marvell's Link Street family of Ethernet switches. 123a9770eacSAndrew Lunn 124a9770eacSAndrew Lunnconfig MDIO_MSCC_MIIM 125a9770eacSAndrew Lunn tristate "Microsemi MIIM interface support" 1268057cbb8STianchen Ding depends on HAS_IOMEM && REGMAP_MMIO 127a9770eacSAndrew Lunn help 128a9770eacSAndrew Lunn This driver supports the MIIM (MDIO) interface found in the network 129a9770eacSAndrew Lunn switches of the Microsemi SoCs; it is recommended to switch on 130a9770eacSAndrew Lunn CONFIG_HIGH_RES_TIMERS 131a9770eacSAndrew Lunn 132a9770eacSAndrew Lunnconfig MDIO_MOXART 133a9770eacSAndrew Lunn tristate "MOXA ART MDIO interface support" 134a9770eacSAndrew Lunn depends on ARCH_MOXART || COMPILE_TEST 135a9770eacSAndrew Lunn help 136a9770eacSAndrew Lunn This driver supports the MDIO interface found in the network 137a9770eacSAndrew Lunn interface units of the MOXA ART SoC 138a9770eacSAndrew Lunn 139a9770eacSAndrew Lunnconfig MDIO_OCTEON 140a9770eacSAndrew Lunn tristate "Octeon and some ThunderX SOCs MDIO buses" 141a9770eacSAndrew Lunn depends on (64BIT && OF_MDIO) || COMPILE_TEST 142a9770eacSAndrew Lunn depends on HAS_IOMEM 143a9770eacSAndrew Lunn select MDIO_CAVIUM 144a9770eacSAndrew Lunn help 145a9770eacSAndrew Lunn This module provides a driver for the Octeon and ThunderX MDIO 146a9770eacSAndrew Lunn buses. It is required by the Octeon and ThunderX ethernet device 147a9770eacSAndrew Lunn drivers on some systems. 148a9770eacSAndrew Lunn 149a9770eacSAndrew Lunnconfig MDIO_IPQ4019 150a9770eacSAndrew Lunn tristate "Qualcomm IPQ4019 MDIO interface support" 151a9770eacSAndrew Lunn depends on HAS_IOMEM && OF_MDIO 15223a890d4SLuo Jie depends on COMMON_CLK 153a9770eacSAndrew Lunn help 154a9770eacSAndrew Lunn This driver supports the MDIO interface found in Qualcomm 155c76ee263SLuo Jie IPQ40xx, IPQ60xx, IPQ807x and IPQ50xx series Soc-s. 156a9770eacSAndrew Lunn 157a9770eacSAndrew Lunnconfig MDIO_IPQ8064 158a9770eacSAndrew Lunn tristate "Qualcomm IPQ8064 MDIO interface support" 159a9770eacSAndrew Lunn depends on HAS_IOMEM && OF_MDIO 160a9770eacSAndrew Lunn depends on MFD_SYSCON 161a9770eacSAndrew Lunn help 162a9770eacSAndrew Lunn This driver supports the MDIO interface found in the network 163a9770eacSAndrew Lunn interface units of the IPQ8064 SoC 164a9770eacSAndrew Lunn 16524e31e47SChris Packhamconfig MDIO_REALTEK_RTL9300 16624e31e47SChris Packham tristate "Realtek RTL9300 MDIO interface support" 16724e31e47SChris Packham depends on MACH_REALTEK_RTL || COMPILE_TEST 16824e31e47SChris Packham help 16924e31e47SChris Packham This driver supports the MDIO interface found in the Realtek 17024e31e47SChris Packham RTL9300 family of Ethernet switches with integrated SoC. 17124e31e47SChris Packham 172642af0f9SMaxime Chevallierconfig MDIO_REGMAP 173642af0f9SMaxime Chevallier tristate 174642af0f9SMaxime Chevallier help 175642af0f9SMaxime Chevallier This driver allows using MDIO devices that are not sitting on a 176642af0f9SMaxime Chevallier regular MDIO bus, but still exposes the standard 802.3 register 177642af0f9SMaxime Chevallier layout. It's regmap-based so that it can be used on integrated, 178642af0f9SMaxime Chevallier memory-mapped PHYs, SPI PHYs and so on. A new virtual MDIO bus is 179642af0f9SMaxime Chevallier created, and its read/write operations are mapped to the underlying 180642af0f9SMaxime Chevallier regmap. Users willing to use this driver must explicitly select 181642af0f9SMaxime Chevallier REGMAP. 182642af0f9SMaxime Chevallier 183a9770eacSAndrew Lunnconfig MDIO_THUNDER 184a9770eacSAndrew Lunn tristate "ThunderX SOCs MDIO buses" 185a9770eacSAndrew Lunn depends on 64BIT 186a9770eacSAndrew Lunn depends on PCI 187a9770eacSAndrew Lunn select MDIO_CAVIUM 188a9770eacSAndrew Lunn help 189a9770eacSAndrew Lunn This driver supports the MDIO interfaces found on Cavium 190a9770eacSAndrew Lunn ThunderX SoCs when the MDIO bus device appears as a PCI 191a9770eacSAndrew Lunn device. 192a9770eacSAndrew Lunn 193a9770eacSAndrew Lunncomment "MDIO Multiplexers" 194a9770eacSAndrew Lunn 195a9770eacSAndrew Lunnconfig MDIO_BUS_MUX 196a9770eacSAndrew Lunn tristate 197a9770eacSAndrew Lunn depends on OF_MDIO 198a9770eacSAndrew Lunn help 199a9770eacSAndrew Lunn This module provides a driver framework for MDIO bus 200a9770eacSAndrew Lunn multiplexers which connect one of several child MDIO busses 201a9770eacSAndrew Lunn to a parent bus. Switching between child busses is done by 202a9770eacSAndrew Lunn device specific drivers. 203a9770eacSAndrew Lunn 204a9770eacSAndrew Lunnconfig MDIO_BUS_MUX_MESON_G12A 205a9770eacSAndrew Lunn tristate "Amlogic G12a based MDIO bus multiplexer" 206a9770eacSAndrew Lunn depends on ARCH_MESON || COMPILE_TEST 207a9770eacSAndrew Lunn depends on OF_MDIO && HAS_IOMEM && COMMON_CLK 208a9770eacSAndrew Lunn select MDIO_BUS_MUX 209a9770eacSAndrew Lunn default m if ARCH_MESON 210a9770eacSAndrew Lunn help 211a9770eacSAndrew Lunn This module provides a driver for the MDIO multiplexer/glue of 212a9770eacSAndrew Lunn the amlogic g12a SoC. The multiplexers connects either the external 213a9770eacSAndrew Lunn or the internal MDIO bus to the parent bus. 214a9770eacSAndrew Lunn 2159a24e1ffSJerome Brunetconfig MDIO_BUS_MUX_MESON_GXL 2169a24e1ffSJerome Brunet tristate "Amlogic GXL based MDIO bus multiplexer" 2179a24e1ffSJerome Brunet depends on ARCH_MESON || COMPILE_TEST 2189a24e1ffSJerome Brunet depends on OF_MDIO && HAS_IOMEM && COMMON_CLK 2199a24e1ffSJerome Brunet select MDIO_BUS_MUX 2209a24e1ffSJerome Brunet default m if ARCH_MESON 2219a24e1ffSJerome Brunet help 2229a24e1ffSJerome Brunet This module provides a driver for the MDIO multiplexer/glue of 2239a24e1ffSJerome Brunet the amlogic GXL SoC. The multiplexer connects either the external 2249a24e1ffSJerome Brunet or the internal MDIO bus to the parent bus. 2259a24e1ffSJerome Brunet 226e2397567SÁlvaro Fernández Rojasconfig MDIO_BUS_MUX_BCM6368 227e2397567SÁlvaro Fernández Rojas tristate "Broadcom BCM6368 MDIO bus multiplexers" 228e2397567SÁlvaro Fernández Rojas depends on OF && OF_MDIO && (BMIPS_GENERIC || COMPILE_TEST) 229e2397567SÁlvaro Fernández Rojas select MDIO_BUS_MUX 230e2397567SÁlvaro Fernández Rojas default BMIPS_GENERIC 231e2397567SÁlvaro Fernández Rojas help 232e2397567SÁlvaro Fernández Rojas This module provides a driver for MDIO bus multiplexers found in 233e2397567SÁlvaro Fernández Rojas BCM6368 based Broadcom SoCs. This multiplexer connects one of several 234e2397567SÁlvaro Fernández Rojas child MDIO bus to a parent bus. Buses could be internal as well as 235e2397567SÁlvaro Fernández Rojas external and selection logic lies inside the same multiplexer. 236e2397567SÁlvaro Fernández Rojas 237a9770eacSAndrew Lunnconfig MDIO_BUS_MUX_BCM_IPROC 238a9770eacSAndrew Lunn tristate "Broadcom iProc based MDIO bus multiplexers" 239a9770eacSAndrew Lunn depends on OF && OF_MDIO && (ARCH_BCM_IPROC || COMPILE_TEST) 240a9770eacSAndrew Lunn select MDIO_BUS_MUX 241a9770eacSAndrew Lunn default ARCH_BCM_IPROC 242a9770eacSAndrew Lunn help 243a9770eacSAndrew Lunn This module provides a driver for MDIO bus multiplexers found in 244a9770eacSAndrew Lunn iProc based Broadcom SoCs. This multiplexer connects one of several 245a9770eacSAndrew Lunn child MDIO bus to a parent bus. Buses could be internal as well as 246a9770eacSAndrew Lunn external and selection logic lies inside the same multiplexer. 247a9770eacSAndrew Lunn 248a9770eacSAndrew Lunnconfig MDIO_BUS_MUX_GPIO 249a9770eacSAndrew Lunn tristate "GPIO controlled MDIO bus multiplexers" 250a9770eacSAndrew Lunn depends on OF_GPIO && OF_MDIO 251a9770eacSAndrew Lunn select MDIO_BUS_MUX 252a9770eacSAndrew Lunn help 253a9770eacSAndrew Lunn This module provides a driver for MDIO bus multiplexers that 254a9770eacSAndrew Lunn are controlled via GPIO lines. The multiplexer connects one of 255a9770eacSAndrew Lunn several child MDIO busses to a parent bus. Child bus 256a9770eacSAndrew Lunn selection is under the control of GPIO lines. 257a9770eacSAndrew Lunn 258a9770eacSAndrew Lunnconfig MDIO_BUS_MUX_MULTIPLEXER 259a9770eacSAndrew Lunn tristate "MDIO bus multiplexer using kernel multiplexer subsystem" 260a9770eacSAndrew Lunn depends on OF_MDIO 261a9770eacSAndrew Lunn select MULTIPLEXER 262a9770eacSAndrew Lunn select MDIO_BUS_MUX 263a9770eacSAndrew Lunn help 264a9770eacSAndrew Lunn This module provides a driver for MDIO bus multiplexer 265a9770eacSAndrew Lunn that is controlled via the kernel multiplexer subsystem. The 266a9770eacSAndrew Lunn bus multiplexer connects one of several child MDIO busses to 267a9770eacSAndrew Lunn a parent bus. Child bus selection is under the control of 268a9770eacSAndrew Lunn the kernel multiplexer subsystem. 269a9770eacSAndrew Lunn 270a9770eacSAndrew Lunnconfig MDIO_BUS_MUX_MMIOREG 271a9770eacSAndrew Lunn tristate "MMIO device-controlled MDIO bus multiplexers" 272a9770eacSAndrew Lunn depends on OF_MDIO && HAS_IOMEM 273a9770eacSAndrew Lunn select MDIO_BUS_MUX 274a9770eacSAndrew Lunn help 275a9770eacSAndrew Lunn This module provides a driver for MDIO bus multiplexers that 276a9770eacSAndrew Lunn are controlled via a simple memory-mapped device, like an FPGA. 277a9770eacSAndrew Lunn The multiplexer connects one of several child MDIO busses to a 278a9770eacSAndrew Lunn parent bus. Child bus selection is under the control of one of 279a9770eacSAndrew Lunn the FPGA's registers. 280a9770eacSAndrew Lunn 281a9770eacSAndrew Lunn Currently, only 8/16/32 bits registers are supported. 282a9770eacSAndrew Lunn 283a9770eacSAndrew Lunn 284a9770eacSAndrew Lunnendif 285