Alex | af2cbfd | 2017-02-06 19:17:34 -0800 | [diff] [blame] | 1 | |
| 2 | config BITBANGMII |
| 3 | bool "Bit-banged ethernet MII management channel support" |
| 4 | |
Tom Rini | 448dfb4 | 2022-03-21 21:33:31 -0400 | [diff] [blame] | 5 | config BITBANGMII_MULTI |
| 6 | bool "Enable the multi bus support" |
| 7 | depends on BITBANGMII |
| 8 | |
Alex | af2cbfd | 2017-02-06 19:17:34 -0800 | [diff] [blame] | 9 | config MV88E6352_SWITCH |
| 10 | bool "Marvell 88E6352 switch support" |
| 11 | |
| 12 | menuconfig PHYLIB |
| 13 | bool "Ethernet PHY (physical media interface) support" |
Michal Simek | c946b0e | 2018-02-06 13:23:52 +0100 | [diff] [blame] | 14 | depends on NET |
Alex | af2cbfd | 2017-02-06 19:17:34 -0800 | [diff] [blame] | 15 | help |
| 16 | Enable Ethernet PHY (physical media interface) support. |
| 17 | |
| 18 | if PHYLIB |
| 19 | |
Joe Hershberger | 16879cd | 2018-03-30 11:52:16 -0500 | [diff] [blame] | 20 | config PHY_ADDR_ENABLE |
| 21 | bool "Limit phy address" |
| 22 | default y if ARCH_SUNXI |
| 23 | help |
| 24 | Select this if you want to control which phy address is used |
| 25 | |
| 26 | if PHY_ADDR_ENABLE |
Stefan Mavrodiev | b30c419 | 2018-02-02 15:53:38 +0200 | [diff] [blame] | 27 | config PHY_ADDR |
| 28 | int "PHY address" |
| 29 | default 1 if ARCH_SUNXI |
| 30 | default 0 |
| 31 | help |
| 32 | The address of PHY on MII bus. Usually in range of 0 to 31. |
Joe Hershberger | 16879cd | 2018-03-30 11:52:16 -0500 | [diff] [blame] | 33 | endif |
Stefan Mavrodiev | b30c419 | 2018-02-02 15:53:38 +0200 | [diff] [blame] | 34 | |
Florian Fainelli | 137963d | 2017-12-09 14:59:54 -0800 | [diff] [blame] | 35 | config B53_SWITCH |
| 36 | bool "Broadcom BCM53xx (RoboSwitch) Ethernet switch PHY support." |
| 37 | help |
| 38 | Enable support for Broadcom BCM53xx (RoboSwitch) Ethernet switches. |
| 39 | This currently supports BCM53125 and similar models. |
| 40 | |
| 41 | if B53_SWITCH |
| 42 | |
| 43 | config B53_CPU_PORT |
| 44 | int "CPU port" |
| 45 | default 8 |
| 46 | |
| 47 | config B53_PHY_PORTS |
| 48 | hex "Bitmask of PHY ports" |
| 49 | |
| 50 | endif # B53_SWITCH |
| 51 | |
Alex | af2cbfd | 2017-02-06 19:17:34 -0800 | [diff] [blame] | 52 | config MV88E61XX_SWITCH |
Anatolij Gustschin | 389488d | 2019-10-27 01:14:41 +0200 | [diff] [blame] | 53 | bool "Marvell MV88E61xx Ethernet switch PHY support." |
Alex | af2cbfd | 2017-02-06 19:17:34 -0800 | [diff] [blame] | 54 | |
Tim Harvey | b4f4b0f | 2017-03-17 07:29:51 -0700 | [diff] [blame] | 55 | if MV88E61XX_SWITCH |
| 56 | |
| 57 | config MV88E61XX_CPU_PORT |
| 58 | int "CPU Port" |
| 59 | |
| 60 | config MV88E61XX_PHY_PORTS |
| 61 | hex "Bitmask of PHY Ports" |
| 62 | |
| 63 | config MV88E61XX_FIXED_PORTS |
| 64 | hex "Bitmask of PHYless serdes Ports" |
Tom Rini | bd22bde | 2023-01-10 11:19:40 -0500 | [diff] [blame] | 65 | default 0x0 |
| 66 | help |
| 67 | These are ports without PHYs that may be wired directly to other |
| 68 | serdes interfaces |
Tim Harvey | b4f4b0f | 2017-03-17 07:29:51 -0700 | [diff] [blame] | 69 | |
| 70 | endif # MV88E61XX_SWITCH |
| 71 | |
Alex | af2cbfd | 2017-02-06 19:17:34 -0800 | [diff] [blame] | 72 | config PHYLIB_10G |
| 73 | bool "Generic 10G PHY support" |
| 74 | |
Nate Drude | d79f1a8 | 2022-04-08 11:28:14 -0500 | [diff] [blame] | 75 | config PHY_ADIN |
| 76 | bool "Analog Devices Industrial Ethernet PHYs" |
| 77 | help |
| 78 | Add support for configuring RGMII on Analog Devices ADIN PHYs. |
| 79 | |
Jeremy Gebben | 4506423 | 2018-09-18 15:49:36 -0600 | [diff] [blame] | 80 | menuconfig PHY_AQUANTIA |
Alex | af2cbfd | 2017-02-06 19:17:34 -0800 | [diff] [blame] | 81 | bool "Aquantia Ethernet PHYs support" |
Jeremy Gebben | 1c65010 | 2018-09-18 15:49:35 -0600 | [diff] [blame] | 82 | select PHY_GIGE |
| 83 | select PHYLIB_10G |
Alex | af2cbfd | 2017-02-06 19:17:34 -0800 | [diff] [blame] | 84 | |
Jeremy Gebben | 4506423 | 2018-09-18 15:49:36 -0600 | [diff] [blame] | 85 | config PHY_AQUANTIA_UPLOAD_FW |
| 86 | bool "Aquantia firmware loading support" |
Jeremy Gebben | 4506423 | 2018-09-18 15:49:36 -0600 | [diff] [blame] | 87 | depends on PHY_AQUANTIA |
| 88 | help |
| 89 | Aquantia PHYs use firmware which can be either loaded automatically |
| 90 | from storage directly attached to the phy or loaded by the boot loader |
| 91 | via MDIO commands. The firmware is loaded from a file, specified by |
| 92 | the PHY_AQUANTIA_FW_PART and PHY_AQUANTIA_FW_NAME options. |
| 93 | |
| 94 | config PHY_AQUANTIA_FW_PART |
| 95 | string "Aquantia firmware partition" |
| 96 | depends on PHY_AQUANTIA_UPLOAD_FW |
| 97 | help |
| 98 | Partition containing the firmware file. |
| 99 | |
| 100 | config PHY_AQUANTIA_FW_NAME |
| 101 | string "Aquantia firmware filename" |
| 102 | depends on PHY_AQUANTIA_UPLOAD_FW |
| 103 | help |
| 104 | Firmware filename. |
| 105 | |
Alex | af2cbfd | 2017-02-06 19:17:34 -0800 | [diff] [blame] | 106 | config PHY_ATHEROS |
| 107 | bool "Atheros Ethernet PHYs support" |
| 108 | |
Simon Glass | e6c5205 | 2023-02-22 09:34:18 -0700 | [diff] [blame] | 109 | config SPL_PHY_ATHEROS |
| 110 | bool "Atheros Ethernet PHYs support (SPL)" |
| 111 | |
Alex | af2cbfd | 2017-02-06 19:17:34 -0800 | [diff] [blame] | 112 | config PHY_BROADCOM |
| 113 | bool "Broadcom Ethernet PHYs support" |
| 114 | |
| 115 | config PHY_CORTINA |
| 116 | bool "Cortina Ethernet PHYs support" |
| 117 | |
Meenakshi Aggarwal | 2a29a9a | 2020-10-29 19:16:15 +0530 | [diff] [blame] | 118 | config SYS_CORTINA_NO_FW_UPLOAD |
| 119 | bool "Cortina firmware loading support" |
Meenakshi Aggarwal | 2a29a9a | 2020-10-29 19:16:15 +0530 | [diff] [blame] | 120 | depends on PHY_CORTINA |
| 121 | help |
| 122 | Cortina phy has provision to store phy firmware in attached dedicated |
| 123 | EEPROM. And boards designed with such EEPROM does not require firmware |
| 124 | upload. |
| 125 | |
Tom Rini | e78f16b | 2019-11-26 17:32:43 -0500 | [diff] [blame] | 126 | choice |
| 127 | prompt "Location of the Cortina firmware" |
| 128 | default SYS_CORTINA_FW_IN_NOR |
| 129 | depends on PHY_CORTINA |
| 130 | |
| 131 | config SYS_CORTINA_FW_IN_MMC |
| 132 | bool "Cortina firmware in MMC" |
| 133 | |
| 134 | config SYS_CORTINA_FW_IN_NAND |
| 135 | bool "Cortina firmware in NAND flash" |
| 136 | |
| 137 | config SYS_CORTINA_FW_IN_NOR |
| 138 | bool "Cortina firmware in NOR flash" |
| 139 | |
| 140 | config SYS_CORTINA_FW_IN_REMOTE |
| 141 | bool "Cortina firmware in remote device" |
| 142 | |
| 143 | config SYS_CORTINA_FW_IN_SPIFLASH |
| 144 | bool "Cortina firmware in SPI flash" |
| 145 | |
| 146 | endchoice |
| 147 | |
Kuldeep Singh | e99b1df | 2021-08-10 11:20:07 +0530 | [diff] [blame] | 148 | config CORTINA_FW_ADDR |
| 149 | hex "Cortina Firmware Address" |
| 150 | depends on PHY_CORTINA && !SYS_CORTINA_NO_FW_UPLOAD |
| 151 | default 0x0 |
| 152 | |
| 153 | config CORTINA_FW_LENGTH |
| 154 | hex "Cortina Firmware Length" |
| 155 | depends on PHY_CORTINA && !SYS_CORTINA_NO_FW_UPLOAD |
| 156 | default 0x40000 |
| 157 | |
Abbie Chang | a70d7b0 | 2021-01-14 13:34:12 -0800 | [diff] [blame] | 158 | config PHY_CORTINA_ACCESS |
| 159 | bool "Cortina Access Ethernet PHYs support" |
| 160 | default y |
| 161 | depends on CORTINA_NI_ENET |
| 162 | help |
| 163 | Cortina Access Ethernet PHYs init process |
| 164 | |
Alex | af2cbfd | 2017-02-06 19:17:34 -0800 | [diff] [blame] | 165 | config PHY_DAVICOM |
| 166 | bool "Davicom Ethernet PHYs support" |
| 167 | |
| 168 | config PHY_ET1011C |
| 169 | bool "LSI TruePHY ET1011C support" |
| 170 | |
| 171 | config PHY_LXT |
| 172 | bool "LXT971 Ethernet PHY support" |
| 173 | |
| 174 | config PHY_MARVELL |
| 175 | bool "Marvell Ethernet PHYs support" |
| 176 | |
Neil Armstrong | 8995a96 | 2017-10-18 10:02:10 +0200 | [diff] [blame] | 177 | config PHY_MESON_GXL |
| 178 | bool "Amlogic Meson GXL Internal PHY support" |
| 179 | |
Alex | af2cbfd | 2017-02-06 19:17:34 -0800 | [diff] [blame] | 180 | config PHY_MICREL |
| 181 | bool "Micrel Ethernet PHYs support" |
Philipp Tomsich | 449ea2c | 2017-03-26 18:50:23 +0200 | [diff] [blame] | 182 | help |
| 183 | Enable support for the GbE PHYs manufactured by Micrel (now |
James Byrne | 77b508d | 2019-03-06 12:48:27 +0000 | [diff] [blame] | 184 | a part of Microchip). This includes drivers for the KSZ804, KSZ8031, |
| 185 | KSZ8051, KSZ8081, KSZ8895, KSZ886x and KSZ8721 (if "Micrel KSZ8xxx |
| 186 | family support" is selected) and the KSZ9021 and KSZ9031 (if "Micrel |
| 187 | KSZ90x1 family support" is selected). |
Philipp Tomsich | 449ea2c | 2017-03-26 18:50:23 +0200 | [diff] [blame] | 188 | |
| 189 | if PHY_MICREL |
| 190 | |
| 191 | config PHY_MICREL_KSZ9021 |
Alexandru Gagniuc | 9a31c73 | 2017-07-07 11:37:00 -0700 | [diff] [blame] | 192 | bool |
Alexandru Gagniuc | d397f7c | 2017-07-07 11:36:57 -0700 | [diff] [blame] | 193 | select PHY_MICREL_KSZ90X1 |
Alexandru Gagniuc | d397f7c | 2017-07-07 11:36:57 -0700 | [diff] [blame] | 194 | |
Philipp Tomsich | 449ea2c | 2017-03-26 18:50:23 +0200 | [diff] [blame] | 195 | config PHY_MICREL_KSZ9031 |
Alexandru Gagniuc | 9a31c73 | 2017-07-07 11:37:00 -0700 | [diff] [blame] | 196 | bool |
Alexandru Gagniuc | d397f7c | 2017-07-07 11:36:57 -0700 | [diff] [blame] | 197 | select PHY_MICREL_KSZ90X1 |
Alexandru Gagniuc | d397f7c | 2017-07-07 11:36:57 -0700 | [diff] [blame] | 198 | |
| 199 | config PHY_MICREL_KSZ90X1 |
| 200 | bool "Micrel KSZ90x1 family support" |
| 201 | select PHY_GIGE |
| 202 | help |
| 203 | Enable support for the Micrel KSZ9021 and KSZ9031 GbE PHYs. If |
| 204 | enabled, the extended register read/write for KSZ90x1 PHYs |
| 205 | is supported through the 'mdio' command and any RGMII signal |
| 206 | delays configured in the device tree will be applied to the |
| 207 | PHY during initialization. |
| 208 | |
Alexandru Gagniuc | d397f7c | 2017-07-07 11:36:57 -0700 | [diff] [blame] | 209 | config PHY_MICREL_KSZ8XXX |
| 210 | bool "Micrel KSZ8xxx family support" |
Alexandru Gagniuc | d397f7c | 2017-07-07 11:36:57 -0700 | [diff] [blame] | 211 | help |
James Byrne | 77b508d | 2019-03-06 12:48:27 +0000 | [diff] [blame] | 212 | Enable support for the 8000 series 10/100 PHYs manufactured by Micrel |
Alexandru Gagniuc | d397f7c | 2017-07-07 11:36:57 -0700 | [diff] [blame] | 213 | (now a part of Microchip). This includes drivers for the KSZ804, |
| 214 | KSZ8031, KSZ8051, KSZ8081, KSZ8895, KSZ886x, and KSZ8721. |
| 215 | |
Philipp Tomsich | 449ea2c | 2017-03-26 18:50:23 +0200 | [diff] [blame] | 216 | endif # PHY_MICREL |
Alex | af2cbfd | 2017-02-06 19:17:34 -0800 | [diff] [blame] | 217 | |
John Haechten | a5fd13a | 2016-12-09 22:15:17 +0000 | [diff] [blame] | 218 | config PHY_MSCC |
| 219 | bool "Microsemi Corp Ethernet PHYs support" |
| 220 | |
Alex | af2cbfd | 2017-02-06 19:17:34 -0800 | [diff] [blame] | 221 | config PHY_NATSEMI |
| 222 | bool "National Semiconductor Ethernet PHYs support" |
| 223 | |
Radu Pirea (NXP OSS) | 3ef2050 | 2021-06-18 21:58:30 +0300 | [diff] [blame] | 224 | config PHY_NXP_C45_TJA11XX |
| 225 | tristate "NXP C45 TJA11XX PHYs" |
| 226 | help |
| 227 | Enable support for NXP C45 TJA11XX PHYs. |
| 228 | Currently supports only the TJA1103 PHY. |
| 229 | |
Michael Trimarchi | a2f5c93 | 2022-04-12 10:31:37 -0300 | [diff] [blame] | 230 | config PHY_NXP_TJA11XX |
| 231 | bool "NXP TJA11XX Ethernet PHYs support" |
| 232 | help |
| 233 | Currently supports the NXP TJA1100 and TJA1101 PHY. |
| 234 | |
Alex | af2cbfd | 2017-02-06 19:17:34 -0800 | [diff] [blame] | 235 | config PHY_REALTEK |
| 236 | bool "Realtek Ethernet PHYs support" |
| 237 | |
| 238 | config RTL8211X_PHY_FORCE_MASTER |
| 239 | bool "Ethernet PHY RTL8211x: force 1000BASE-T master mode" |
| 240 | depends on PHY_REALTEK |
| 241 | help |
| 242 | Force master mode for 1000BASE-T on RTl8211x PHYs (except for RTL8211F). |
| 243 | This can work around link stability and data corruption issues on gigabit |
| 244 | links which can occur in slave mode on certain PHYs, e.g. on the |
| 245 | RTL8211C(L). |
| 246 | |
| 247 | Please note that two directly connected devices (i.e. via crossover cable) |
| 248 | will not be able to establish a link between each other if they both force |
| 249 | master mode. Multiple devices forcing master mode when connected by a |
| 250 | network switch do not pose a problem as the switch configures its affected |
| 251 | ports into slave mode. |
| 252 | |
| 253 | This option only affects gigabit links. If you must establish a direct |
| 254 | connection between two devices which both force master mode, try forcing |
| 255 | the link speed to 100MBit/s. |
| 256 | |
| 257 | If unsure, say N. |
| 258 | |
Carlo Caione | d47cfdb | 2019-01-24 08:54:37 +0000 | [diff] [blame] | 259 | config RTL8211F_PHY_FORCE_EEE_RXC_ON |
| 260 | bool "Ethernet PHY RTL8211F: do not stop receiving the xMII clock during LPI" |
| 261 | depends on PHY_REALTEK |
Carlo Caione | d47cfdb | 2019-01-24 08:54:37 +0000 | [diff] [blame] | 262 | help |
| 263 | The IEEE 802.3az-2010 (EEE) standard provides a protocol to coordinate |
| 264 | transitions to/from a lower power consumption level (Low Power Idle |
| 265 | mode) based on link utilization. When no packets are being |
| 266 | transmitted, the system goes to Low Power Idle mode to save power. |
| 267 | |
| 268 | Under particular circumstances this setting can cause issues where |
| 269 | the PHY is unable to transmit or receive any packet when in LPI mode. |
| 270 | The problem is caused when the PHY is configured to stop receiving |
| 271 | the xMII clock while it is signaling LPI. For some PHYs the bit |
| 272 | configuring this behavior is set by the Linux kernel, causing the |
| 273 | issue in U-Boot on reboot if the PHY retains the register value. |
| 274 | |
| 275 | Default n, which means that the PHY state is not changed. To work |
| 276 | around the issues, change this setting to y. |
| 277 | |
Amit Singh Tomar | fa6539a | 2020-05-09 19:55:11 +0530 | [diff] [blame] | 278 | config RTL8201F_PHY_S700_RMII_TIMINGS |
| 279 | bool "Ethernet PHY RTL8201F: adjust RMII Tx Interface timings" |
| 280 | depends on PHY_REALTEK |
| 281 | help |
| 282 | This provides an option to configure specific timing requirements (needed |
| 283 | for proper PHY operations) for the PHY module present on ACTION SEMI S700 |
| 284 | based cubieboard7. Exact timing requiremnets seems to be SoC specific |
| 285 | (and it's undocumented) that comes from vendor code itself. |
| 286 | |
Alex | af2cbfd | 2017-02-06 19:17:34 -0800 | [diff] [blame] | 287 | config PHY_SMSC |
| 288 | bool "Microchip(SMSC) Ethernet PHYs support" |
| 289 | |
| 290 | config PHY_TERANETICS |
| 291 | bool "Teranetics Ethernet PHYs support" |
| 292 | |
| 293 | config PHY_TI |
| 294 | bool "Texas Instruments Ethernet PHYs support" |
Dan Murphy | bc0e578 | 2020-05-04 16:14:39 -0500 | [diff] [blame] | 295 | ---help--- |
| 296 | Adds PHY registration support for TI PHYs. |
| 297 | |
| 298 | config PHY_TI_DP83867 |
| 299 | select PHY_TI |
| 300 | bool "Texas Instruments Ethernet DP83867 PHY support" |
| 301 | ---help--- |
| 302 | Adds support for the TI DP83867 1Gbit PHY. |
Alex | af2cbfd | 2017-02-06 19:17:34 -0800 | [diff] [blame] | 303 | |
Dominic Rath | f3e22ee | 2021-12-22 08:57:46 +0100 | [diff] [blame] | 304 | config PHY_TI_DP83869 |
| 305 | select PHY_TI |
| 306 | bool "Texas Instruments Ethernet DP83869 PHY support" |
| 307 | ---help--- |
| 308 | Adds support for the TI DP83869 1Gbit PHY. |
| 309 | |
Dan Murphy | 8882238 | 2020-05-04 16:14:40 -0500 | [diff] [blame] | 310 | config PHY_TI_GENERIC |
| 311 | select PHY_TI |
| 312 | bool "Texas Instruments Generic Ethernet PHYs support" |
| 313 | ---help--- |
| 314 | Adds support for Generic TI PHYs that don't need special handling but |
| 315 | the PHY name is associated with a PHY ID. |
| 316 | |
Alex | af2cbfd | 2017-02-06 19:17:34 -0800 | [diff] [blame] | 317 | config PHY_VITESSE |
| 318 | bool "Vitesse Ethernet PHYs support" |
| 319 | |
| 320 | config PHY_XILINX |
| 321 | bool "Xilinx Ethernet PHYs support" |
| 322 | |
Siva Durga Prasad Paladugu | f41e588 | 2018-11-27 11:49:11 +0530 | [diff] [blame] | 323 | config PHY_XILINX_GMII2RGMII |
| 324 | bool "Xilinx GMII to RGMII Ethernet PHYs support" |
| 325 | help |
| 326 | This adds support for Xilinx GMII to RGMII IP core. This IP acts |
| 327 | as bridge between MAC connected over GMII and external phy that |
| 328 | is connected over RGMII interface. |
| 329 | |
Tim Harvey | 5e6c069 | 2022-11-17 13:27:09 -0800 | [diff] [blame] | 330 | config PHY_XWAY |
| 331 | bool "Intel XWAY PHY support" |
| 332 | help |
| 333 | This adds support for the Intel XWAY (formerly Lantiq) Gbe PHYs. |
| 334 | |
Michal Simek | a744a28 | 2022-02-23 15:45:42 +0100 | [diff] [blame] | 335 | config PHY_ETHERNET_ID |
| 336 | bool "Read ethernet PHY id" |
| 337 | depends on DM_GPIO |
| 338 | default y if ZYNQ_GEM |
| 339 | help |
| 340 | Enable this config to read ethernet phy id from the phy node of DT |
| 341 | and create a phy device using id. |
| 342 | |
Hannes Schmelzer | db40c1a | 2017-03-23 15:11:43 +0100 | [diff] [blame] | 343 | config PHY_FIXED |
| 344 | bool "Fixed-Link PHY" |
Hannes Schmelzer | db40c1a | 2017-03-23 15:11:43 +0100 | [diff] [blame] | 345 | help |
| 346 | Fixed PHY is used for having a 'fixed-link' to another MAC with a direct |
| 347 | connection (MII, RGMII, ...). |
| 348 | There is nothing like autoneogation and so |
| 349 | on, the link is always up with fixed speed and fixed duplex-setting. |
| 350 | More information: doc/device-tree-bindings/net/fixed-link.txt |
| 351 | |
Samuel Mendoza-Jonas | f641a8a | 2019-06-18 11:37:17 +1000 | [diff] [blame] | 352 | config PHY_NCSI |
| 353 | bool "NC-SI based PHY" |
Samuel Mendoza-Jonas | f641a8a | 2019-06-18 11:37:17 +1000 | [diff] [blame] | 354 | |
Alex | af2cbfd | 2017-02-06 19:17:34 -0800 | [diff] [blame] | 355 | endif #PHYLIB |
Tom Rini | 16199a8 | 2022-03-18 08:38:26 -0400 | [diff] [blame] | 356 | |
Tom Rini | 612f7a6 | 2022-07-23 13:05:10 -0400 | [diff] [blame] | 357 | config FSL_MEMAC |
| 358 | bool "NXP mEMAC PHY support" |
| 359 | |
| 360 | config SYS_MEMAC_LITTLE_ENDIAN |
| 361 | bool "mEMAC is access in little endian mode" |
| 362 | depends on FSL_MEMAC || FSL_LS_MDIO |
| 363 | |
Tom Rini | 16199a8 | 2022-03-18 08:38:26 -0400 | [diff] [blame] | 364 | config PHY_RESET_DELAY |
| 365 | int "Extra delay after reset before MII register access" |
| 366 | default 0 |
| 367 | help |
| 368 | Some PHYs need extra delay after reset before any MII register access |
| 369 | is possible. For such PHY, set this option to the usec delay |
| 370 | required. |