blob: 6806e3c0903246b2a09533d0451d71dd2075cd8c [file] [log] [blame]
Alexaf2cbfd2017-02-06 19:17:34 -08001
2config BITBANGMII
3 bool "Bit-banged ethernet MII management channel support"
4
Tom Rini448dfb42022-03-21 21:33:31 -04005config BITBANGMII_MULTI
6 bool "Enable the multi bus support"
7 depends on BITBANGMII
8
Alexaf2cbfd2017-02-06 19:17:34 -08009config MV88E6352_SWITCH
10 bool "Marvell 88E6352 switch support"
11
12menuconfig PHYLIB
13 bool "Ethernet PHY (physical media interface) support"
Michal Simekc946b0e2018-02-06 13:23:52 +010014 depends on NET
Alexaf2cbfd2017-02-06 19:17:34 -080015 help
16 Enable Ethernet PHY (physical media interface) support.
17
18if PHYLIB
19
Joe Hershberger16879cd2018-03-30 11:52:16 -050020config 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
26if PHY_ADDR_ENABLE
Stefan Mavrodievb30c4192018-02-02 15:53:38 +020027config 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 Hershberger16879cd2018-03-30 11:52:16 -050033endif
Stefan Mavrodievb30c4192018-02-02 15:53:38 +020034
Florian Fainelli137963d2017-12-09 14:59:54 -080035config 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
41if B53_SWITCH
42
43config B53_CPU_PORT
44 int "CPU port"
45 default 8
46
47config B53_PHY_PORTS
48 hex "Bitmask of PHY ports"
49
50endif # B53_SWITCH
51
Alexaf2cbfd2017-02-06 19:17:34 -080052config MV88E61XX_SWITCH
Anatolij Gustschin389488d2019-10-27 01:14:41 +020053 bool "Marvell MV88E61xx Ethernet switch PHY support."
Alexaf2cbfd2017-02-06 19:17:34 -080054
Tim Harveyb4f4b0f2017-03-17 07:29:51 -070055if MV88E61XX_SWITCH
56
57config MV88E61XX_CPU_PORT
58 int "CPU Port"
59
60config MV88E61XX_PHY_PORTS
61 hex "Bitmask of PHY Ports"
62
63config MV88E61XX_FIXED_PORTS
64 hex "Bitmask of PHYless serdes Ports"
Tom Rinibd22bde2023-01-10 11:19:40 -050065 default 0x0
66 help
67 These are ports without PHYs that may be wired directly to other
68 serdes interfaces
Tim Harveyb4f4b0f2017-03-17 07:29:51 -070069
70endif # MV88E61XX_SWITCH
71
Alexaf2cbfd2017-02-06 19:17:34 -080072config PHYLIB_10G
73 bool "Generic 10G PHY support"
74
Nate Druded79f1a82022-04-08 11:28:14 -050075config PHY_ADIN
76 bool "Analog Devices Industrial Ethernet PHYs"
77 help
78 Add support for configuring RGMII on Analog Devices ADIN PHYs.
79
Jeremy Gebben45064232018-09-18 15:49:36 -060080menuconfig PHY_AQUANTIA
Alexaf2cbfd2017-02-06 19:17:34 -080081 bool "Aquantia Ethernet PHYs support"
Jeremy Gebben1c650102018-09-18 15:49:35 -060082 select PHY_GIGE
83 select PHYLIB_10G
Alexaf2cbfd2017-02-06 19:17:34 -080084
Jeremy Gebben45064232018-09-18 15:49:36 -060085config PHY_AQUANTIA_UPLOAD_FW
86 bool "Aquantia firmware loading support"
Jeremy Gebben45064232018-09-18 15:49:36 -060087 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
94config 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
100config PHY_AQUANTIA_FW_NAME
101 string "Aquantia firmware filename"
102 depends on PHY_AQUANTIA_UPLOAD_FW
103 help
104 Firmware filename.
105
Alexaf2cbfd2017-02-06 19:17:34 -0800106config PHY_ATHEROS
107 bool "Atheros Ethernet PHYs support"
108
Simon Glasse6c52052023-02-22 09:34:18 -0700109config SPL_PHY_ATHEROS
110 bool "Atheros Ethernet PHYs support (SPL)"
111
Alexaf2cbfd2017-02-06 19:17:34 -0800112config PHY_BROADCOM
113 bool "Broadcom Ethernet PHYs support"
114
115config PHY_CORTINA
116 bool "Cortina Ethernet PHYs support"
117
Meenakshi Aggarwal2a29a9a2020-10-29 19:16:15 +0530118config SYS_CORTINA_NO_FW_UPLOAD
119 bool "Cortina firmware loading support"
Meenakshi Aggarwal2a29a9a2020-10-29 19:16:15 +0530120 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 Rinie78f16b2019-11-26 17:32:43 -0500126choice
127 prompt "Location of the Cortina firmware"
128 default SYS_CORTINA_FW_IN_NOR
129 depends on PHY_CORTINA
130
131config SYS_CORTINA_FW_IN_MMC
132 bool "Cortina firmware in MMC"
133
134config SYS_CORTINA_FW_IN_NAND
135 bool "Cortina firmware in NAND flash"
136
137config SYS_CORTINA_FW_IN_NOR
138 bool "Cortina firmware in NOR flash"
139
140config SYS_CORTINA_FW_IN_REMOTE
141 bool "Cortina firmware in remote device"
142
143config SYS_CORTINA_FW_IN_SPIFLASH
144 bool "Cortina firmware in SPI flash"
145
146endchoice
147
Kuldeep Singhe99b1df2021-08-10 11:20:07 +0530148config CORTINA_FW_ADDR
149 hex "Cortina Firmware Address"
150 depends on PHY_CORTINA && !SYS_CORTINA_NO_FW_UPLOAD
151 default 0x0
152
153config CORTINA_FW_LENGTH
154 hex "Cortina Firmware Length"
155 depends on PHY_CORTINA && !SYS_CORTINA_NO_FW_UPLOAD
156 default 0x40000
157
Abbie Changa70d7b02021-01-14 13:34:12 -0800158config 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
Alexaf2cbfd2017-02-06 19:17:34 -0800165config PHY_DAVICOM
166 bool "Davicom Ethernet PHYs support"
167
168config PHY_ET1011C
169 bool "LSI TruePHY ET1011C support"
170
171config PHY_LXT
172 bool "LXT971 Ethernet PHY support"
173
174config PHY_MARVELL
175 bool "Marvell Ethernet PHYs support"
176
Neil Armstrong8995a962017-10-18 10:02:10 +0200177config PHY_MESON_GXL
178 bool "Amlogic Meson GXL Internal PHY support"
179
Alexaf2cbfd2017-02-06 19:17:34 -0800180config PHY_MICREL
181 bool "Micrel Ethernet PHYs support"
Philipp Tomsich449ea2c2017-03-26 18:50:23 +0200182 help
183 Enable support for the GbE PHYs manufactured by Micrel (now
James Byrne77b508d2019-03-06 12:48:27 +0000184 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 Tomsich449ea2c2017-03-26 18:50:23 +0200188
189if PHY_MICREL
190
191config PHY_MICREL_KSZ9021
Alexandru Gagniuc9a31c732017-07-07 11:37:00 -0700192 bool
Alexandru Gagniucd397f7c2017-07-07 11:36:57 -0700193 select PHY_MICREL_KSZ90X1
Alexandru Gagniucd397f7c2017-07-07 11:36:57 -0700194
Philipp Tomsich449ea2c2017-03-26 18:50:23 +0200195config PHY_MICREL_KSZ9031
Alexandru Gagniuc9a31c732017-07-07 11:37:00 -0700196 bool
Alexandru Gagniucd397f7c2017-07-07 11:36:57 -0700197 select PHY_MICREL_KSZ90X1
Alexandru Gagniucd397f7c2017-07-07 11:36:57 -0700198
199config 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 Gagniucd397f7c2017-07-07 11:36:57 -0700209config PHY_MICREL_KSZ8XXX
210 bool "Micrel KSZ8xxx family support"
Alexandru Gagniucd397f7c2017-07-07 11:36:57 -0700211 help
James Byrne77b508d2019-03-06 12:48:27 +0000212 Enable support for the 8000 series 10/100 PHYs manufactured by Micrel
Alexandru Gagniucd397f7c2017-07-07 11:36:57 -0700213 (now a part of Microchip). This includes drivers for the KSZ804,
214 KSZ8031, KSZ8051, KSZ8081, KSZ8895, KSZ886x, and KSZ8721.
215
Philipp Tomsich449ea2c2017-03-26 18:50:23 +0200216endif # PHY_MICREL
Alexaf2cbfd2017-02-06 19:17:34 -0800217
John Haechtena5fd13a2016-12-09 22:15:17 +0000218config PHY_MSCC
219 bool "Microsemi Corp Ethernet PHYs support"
220
Alexaf2cbfd2017-02-06 19:17:34 -0800221config PHY_NATSEMI
222 bool "National Semiconductor Ethernet PHYs support"
223
Radu Pirea (NXP OSS)3ef20502021-06-18 21:58:30 +0300224config 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 Trimarchia2f5c932022-04-12 10:31:37 -0300230config PHY_NXP_TJA11XX
231 bool "NXP TJA11XX Ethernet PHYs support"
232 help
233 Currently supports the NXP TJA1100 and TJA1101 PHY.
234
Alexaf2cbfd2017-02-06 19:17:34 -0800235config PHY_REALTEK
236 bool "Realtek Ethernet PHYs support"
237
238config 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 Caioned47cfdb2019-01-24 08:54:37 +0000259config 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 Caioned47cfdb2019-01-24 08:54:37 +0000262 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 Tomarfa6539a2020-05-09 19:55:11 +0530278config 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
Alexaf2cbfd2017-02-06 19:17:34 -0800287config PHY_SMSC
288 bool "Microchip(SMSC) Ethernet PHYs support"
289
290config PHY_TERANETICS
291 bool "Teranetics Ethernet PHYs support"
292
293config PHY_TI
294 bool "Texas Instruments Ethernet PHYs support"
Dan Murphybc0e5782020-05-04 16:14:39 -0500295 ---help---
296 Adds PHY registration support for TI PHYs.
297
298config 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.
Alexaf2cbfd2017-02-06 19:17:34 -0800303
Dominic Rathf3e22ee2021-12-22 08:57:46 +0100304config 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 Murphy88822382020-05-04 16:14:40 -0500310config 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
Alexaf2cbfd2017-02-06 19:17:34 -0800317config PHY_VITESSE
318 bool "Vitesse Ethernet PHYs support"
319
320config PHY_XILINX
321 bool "Xilinx Ethernet PHYs support"
322
Siva Durga Prasad Paladuguf41e5882018-11-27 11:49:11 +0530323config 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 Harvey5e6c0692022-11-17 13:27:09 -0800330config PHY_XWAY
331 bool "Intel XWAY PHY support"
332 help
333 This adds support for the Intel XWAY (formerly Lantiq) Gbe PHYs.
334
Michal Simeka744a282022-02-23 15:45:42 +0100335config 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 Schmelzerdb40c1a2017-03-23 15:11:43 +0100343config PHY_FIXED
344 bool "Fixed-Link PHY"
Hannes Schmelzerdb40c1a2017-03-23 15:11:43 +0100345 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-Jonasf641a8a2019-06-18 11:37:17 +1000352config PHY_NCSI
353 bool "NC-SI based PHY"
Samuel Mendoza-Jonasf641a8a2019-06-18 11:37:17 +1000354
Alexaf2cbfd2017-02-06 19:17:34 -0800355endif #PHYLIB
Tom Rini16199a82022-03-18 08:38:26 -0400356
Tom Rini612f7a62022-07-23 13:05:10 -0400357config FSL_MEMAC
358 bool "NXP mEMAC PHY support"
359
360config SYS_MEMAC_LITTLE_ENDIAN
361 bool "mEMAC is access in little endian mode"
362 depends on FSL_MEMAC || FSL_LS_MDIO
363
Tom Rini16199a82022-03-18 08:38:26 -0400364config 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.