blob: 631b52b1cfe2634a11e828395cd98ffd90fd650b [file] [log] [blame]
Alex89e50d92017-02-06 19:17:34 -08001
2config BITBANGMII
3 bool "Bit-banged ethernet MII management channel support"
4
5config MV88E6352_SWITCH
6 bool "Marvell 88E6352 switch support"
7
8menuconfig PHYLIB
9 bool "Ethernet PHY (physical media interface) support"
Michal Simek5647da02018-02-06 13:23:52 +010010 depends on NET
Alex89e50d92017-02-06 19:17:34 -080011 help
12 Enable Ethernet PHY (physical media interface) support.
13
14if PHYLIB
15
Joe Hershberger46b7bd12018-03-30 11:52:16 -050016config PHY_ADDR_ENABLE
17 bool "Limit phy address"
18 default y if ARCH_SUNXI
19 help
20 Select this if you want to control which phy address is used
21
22if PHY_ADDR_ENABLE
Stefan Mavrodieve3ee5f52018-02-02 15:53:38 +020023config PHY_ADDR
24 int "PHY address"
25 default 1 if ARCH_SUNXI
26 default 0
27 help
28 The address of PHY on MII bus. Usually in range of 0 to 31.
Joe Hershberger46b7bd12018-03-30 11:52:16 -050029endif
Stefan Mavrodieve3ee5f52018-02-02 15:53:38 +020030
Florian Fainelli01b4ade2017-12-09 14:59:54 -080031config B53_SWITCH
32 bool "Broadcom BCM53xx (RoboSwitch) Ethernet switch PHY support."
33 help
34 Enable support for Broadcom BCM53xx (RoboSwitch) Ethernet switches.
35 This currently supports BCM53125 and similar models.
36
37if B53_SWITCH
38
39config B53_CPU_PORT
40 int "CPU port"
41 default 8
42
43config B53_PHY_PORTS
44 hex "Bitmask of PHY ports"
45
46endif # B53_SWITCH
47
Alex89e50d92017-02-06 19:17:34 -080048config MV88E61XX_SWITCH
49 bool "Marvel MV88E61xx Ethernet switch PHY support."
50
Tim Harveyc2cc9d42017-03-17 07:29:51 -070051if MV88E61XX_SWITCH
52
53config MV88E61XX_CPU_PORT
54 int "CPU Port"
55
56config MV88E61XX_PHY_PORTS
57 hex "Bitmask of PHY Ports"
58
59config MV88E61XX_FIXED_PORTS
60 hex "Bitmask of PHYless serdes Ports"
61
62endif # MV88E61XX_SWITCH
63
Alex89e50d92017-02-06 19:17:34 -080064config PHYLIB_10G
65 bool "Generic 10G PHY support"
66
Jeremy Gebbene662c0d2018-09-18 15:49:36 -060067menuconfig PHY_AQUANTIA
Alex89e50d92017-02-06 19:17:34 -080068 bool "Aquantia Ethernet PHYs support"
Jeremy Gebbenabe3edf2018-09-18 15:49:35 -060069 select PHY_GIGE
70 select PHYLIB_10G
Alex89e50d92017-02-06 19:17:34 -080071
Jeremy Gebbene662c0d2018-09-18 15:49:36 -060072config PHY_AQUANTIA_UPLOAD_FW
73 bool "Aquantia firmware loading support"
74 default n
75 depends on PHY_AQUANTIA
76 help
77 Aquantia PHYs use firmware which can be either loaded automatically
78 from storage directly attached to the phy or loaded by the boot loader
79 via MDIO commands. The firmware is loaded from a file, specified by
80 the PHY_AQUANTIA_FW_PART and PHY_AQUANTIA_FW_NAME options.
81
82config PHY_AQUANTIA_FW_PART
83 string "Aquantia firmware partition"
84 depends on PHY_AQUANTIA_UPLOAD_FW
85 help
86 Partition containing the firmware file.
87
88config PHY_AQUANTIA_FW_NAME
89 string "Aquantia firmware filename"
90 depends on PHY_AQUANTIA_UPLOAD_FW
91 help
92 Firmware filename.
93
Alex89e50d92017-02-06 19:17:34 -080094config PHY_ATHEROS
95 bool "Atheros Ethernet PHYs support"
96
97config PHY_BROADCOM
98 bool "Broadcom Ethernet PHYs support"
99
100config PHY_CORTINA
101 bool "Cortina Ethernet PHYs support"
102
103config PHY_DAVICOM
104 bool "Davicom Ethernet PHYs support"
105
106config PHY_ET1011C
107 bool "LSI TruePHY ET1011C support"
108
109config PHY_LXT
110 bool "LXT971 Ethernet PHY support"
111
112config PHY_MARVELL
113 bool "Marvell Ethernet PHYs support"
114
Neil Armstrong7a4c90d2017-10-18 10:02:10 +0200115config PHY_MESON_GXL
116 bool "Amlogic Meson GXL Internal PHY support"
117
Alex89e50d92017-02-06 19:17:34 -0800118config PHY_MICREL
119 bool "Micrel Ethernet PHYs support"
Philipp Tomsich00c33612017-03-26 18:50:23 +0200120 help
121 Enable support for the GbE PHYs manufactured by Micrel (now
122 a part of Microchip). This includes drivers for the KSZ804,
123 KSZ8031, KSZ8051, KSZ8081, KSZ8895, KSZ886x, KSZ8721
124 either/or KSZ9021 (see the "Micrel KSZ9021 family support"
125 config option for details), and KSZ9031 (if configured).
126
127if PHY_MICREL
128
129config PHY_MICREL_KSZ9021
Alexandru Gagniuc4c69ccb2017-07-07 11:37:00 -0700130 bool
Philipp Tomsich00c33612017-03-26 18:50:23 +0200131 select PHY_GIGE
Alexandru Gagniuc757bb672017-07-07 11:36:57 -0700132 select PHY_MICREL_KSZ90X1
Alexandru Gagniuc757bb672017-07-07 11:36:57 -0700133
Philipp Tomsich00c33612017-03-26 18:50:23 +0200134config PHY_MICREL_KSZ9031
Alexandru Gagniuc4c69ccb2017-07-07 11:37:00 -0700135 bool
Philipp Tomsich00c33612017-03-26 18:50:23 +0200136 select PHY_GIGE
Alexandru Gagniuc757bb672017-07-07 11:36:57 -0700137 select PHY_MICREL_KSZ90X1
Alexandru Gagniuc757bb672017-07-07 11:36:57 -0700138
139config PHY_MICREL_KSZ90X1
140 bool "Micrel KSZ90x1 family support"
141 select PHY_GIGE
142 help
143 Enable support for the Micrel KSZ9021 and KSZ9031 GbE PHYs. If
144 enabled, the extended register read/write for KSZ90x1 PHYs
145 is supported through the 'mdio' command and any RGMII signal
146 delays configured in the device tree will be applied to the
147 PHY during initialization.
148
149 This should not be enabled at the same time with PHY_MICREL_KSZ8XXX
150 as the KSZ9021 and KS8721 share the same ID.
151
152config PHY_MICREL_KSZ8XXX
153 bool "Micrel KSZ8xxx family support"
154 default y if !PHY_MICREL_KSZ90X1
155 help
156 Enable support for the 8000 series GbE PHYs manufactured by Micrel
157 (now a part of Microchip). This includes drivers for the KSZ804,
158 KSZ8031, KSZ8051, KSZ8081, KSZ8895, KSZ886x, and KSZ8721.
159
160 This should not be enabled at the same time with PHY_MICREL_KSZ90X1
161 as the KSZ9021 and KS8721 share the same ID.
162
Philipp Tomsich00c33612017-03-26 18:50:23 +0200163endif # PHY_MICREL
Alex89e50d92017-02-06 19:17:34 -0800164
John Haechtenee253f92016-12-09 22:15:17 +0000165config PHY_MSCC
166 bool "Microsemi Corp Ethernet PHYs support"
167
Alex89e50d92017-02-06 19:17:34 -0800168config PHY_NATSEMI
169 bool "National Semiconductor Ethernet PHYs support"
170
171config PHY_REALTEK
172 bool "Realtek Ethernet PHYs support"
173
kevans@FreeBSD.org7c824012018-02-14 17:02:15 -0600174config RTL8211E_PINE64_GIGABIT_FIX
175 bool "Fix gigabit throughput on some Pine64+ models"
176 depends on PHY_REALTEK
177 help
178 Configure the Realtek RTL8211E found on some Pine64+ models differently to
179 fix throughput on Gigabit links, turning off all internal delays in the
180 process. The settings that this touches are not documented in the CONFREG
181 section of the RTL8211E datasheet, but come from Realtek by way of the
182 Pine64 engineering team.
183
Alex89e50d92017-02-06 19:17:34 -0800184config RTL8211X_PHY_FORCE_MASTER
185 bool "Ethernet PHY RTL8211x: force 1000BASE-T master mode"
186 depends on PHY_REALTEK
187 help
188 Force master mode for 1000BASE-T on RTl8211x PHYs (except for RTL8211F).
189 This can work around link stability and data corruption issues on gigabit
190 links which can occur in slave mode on certain PHYs, e.g. on the
191 RTL8211C(L).
192
193 Please note that two directly connected devices (i.e. via crossover cable)
194 will not be able to establish a link between each other if they both force
195 master mode. Multiple devices forcing master mode when connected by a
196 network switch do not pose a problem as the switch configures its affected
197 ports into slave mode.
198
199 This option only affects gigabit links. If you must establish a direct
200 connection between two devices which both force master mode, try forcing
201 the link speed to 100MBit/s.
202
203 If unsure, say N.
204
Carlo Caionecf93d022019-01-24 08:54:37 +0000205config RTL8211F_PHY_FORCE_EEE_RXC_ON
206 bool "Ethernet PHY RTL8211F: do not stop receiving the xMII clock during LPI"
207 depends on PHY_REALTEK
208 default n
209 help
210 The IEEE 802.3az-2010 (EEE) standard provides a protocol to coordinate
211 transitions to/from a lower power consumption level (Low Power Idle
212 mode) based on link utilization. When no packets are being
213 transmitted, the system goes to Low Power Idle mode to save power.
214
215 Under particular circumstances this setting can cause issues where
216 the PHY is unable to transmit or receive any packet when in LPI mode.
217 The problem is caused when the PHY is configured to stop receiving
218 the xMII clock while it is signaling LPI. For some PHYs the bit
219 configuring this behavior is set by the Linux kernel, causing the
220 issue in U-Boot on reboot if the PHY retains the register value.
221
222 Default n, which means that the PHY state is not changed. To work
223 around the issues, change this setting to y.
224
Alex89e50d92017-02-06 19:17:34 -0800225config PHY_SMSC
226 bool "Microchip(SMSC) Ethernet PHYs support"
227
228config PHY_TERANETICS
229 bool "Teranetics Ethernet PHYs support"
230
231config PHY_TI
232 bool "Texas Instruments Ethernet PHYs support"
233
234config PHY_VITESSE
235 bool "Vitesse Ethernet PHYs support"
236
237config PHY_XILINX
238 bool "Xilinx Ethernet PHYs support"
239
Hannes Schmelzerda494602017-03-23 15:11:43 +0100240config PHY_FIXED
241 bool "Fixed-Link PHY"
242 depends on DM_ETH
243 help
244 Fixed PHY is used for having a 'fixed-link' to another MAC with a direct
245 connection (MII, RGMII, ...).
246 There is nothing like autoneogation and so
247 on, the link is always up with fixed speed and fixed duplex-setting.
248 More information: doc/device-tree-bindings/net/fixed-link.txt
249
Alex89e50d92017-02-06 19:17:34 -0800250endif #PHYLIB