Merge tag 'xilinx-for-v2020.01' of https://gitlab.denx.de/u-boot/custodians/u-boot...
[platform/kernel/u-boot.git] / drivers / net / phy / Kconfig
1
2 config BITBANGMII
3         bool "Bit-banged ethernet MII management channel support"
4
5 config MV88E6352_SWITCH
6         bool "Marvell 88E6352 switch support"
7
8 menuconfig PHYLIB
9         bool "Ethernet PHY (physical media interface) support"
10         depends on NET
11         help
12           Enable Ethernet PHY (physical media interface) support.
13
14 if PHYLIB
15
16 config 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
22 if PHY_ADDR_ENABLE
23 config 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.
29 endif
30
31 config 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
37 if B53_SWITCH
38
39 config B53_CPU_PORT
40         int "CPU port"
41         default 8
42
43 config B53_PHY_PORTS
44         hex "Bitmask of PHY ports"
45
46 endif # B53_SWITCH
47
48 config MV88E61XX_SWITCH
49         bool "Marvel MV88E61xx Ethernet switch PHY support."
50
51 if MV88E61XX_SWITCH
52
53 config MV88E61XX_CPU_PORT
54         int "CPU Port"
55
56 config MV88E61XX_PHY_PORTS
57         hex "Bitmask of PHY Ports"
58
59 config MV88E61XX_FIXED_PORTS
60         hex "Bitmask of PHYless serdes Ports"
61
62 endif # MV88E61XX_SWITCH
63
64 config PHYLIB_10G
65         bool "Generic 10G PHY support"
66
67 menuconfig PHY_AQUANTIA
68         bool "Aquantia Ethernet PHYs support"
69         select PHY_GIGE
70         select PHYLIB_10G
71
72 config 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
82 config 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
88 config PHY_AQUANTIA_FW_NAME
89         string "Aquantia firmware filename"
90         depends on PHY_AQUANTIA_UPLOAD_FW
91         help
92                 Firmware filename.
93
94 config PHY_ATHEROS
95         bool "Atheros Ethernet PHYs support"
96
97 config PHY_BROADCOM
98         bool "Broadcom Ethernet PHYs support"
99
100 config PHY_CORTINA
101         bool "Cortina Ethernet PHYs support"
102
103 config PHY_DAVICOM
104         bool "Davicom Ethernet PHYs support"
105
106 config PHY_ET1011C
107         bool "LSI TruePHY ET1011C support"
108
109 config PHY_LXT
110         bool "LXT971 Ethernet PHY support"
111
112 config PHY_MARVELL
113         bool "Marvell Ethernet PHYs support"
114
115 config PHY_MESON_GXL
116         bool "Amlogic Meson GXL Internal PHY support"
117
118 config PHY_MICREL
119         bool "Micrel Ethernet PHYs support"
120         help
121           Enable support for the GbE PHYs manufactured by Micrel (now
122           a part of Microchip). This includes drivers for the KSZ804, KSZ8031,
123           KSZ8051, KSZ8081, KSZ8895, KSZ886x and KSZ8721 (if "Micrel KSZ8xxx
124           family support" is selected) and the KSZ9021 and KSZ9031 (if "Micrel
125           KSZ90x1 family support" is selected).
126
127 if PHY_MICREL
128
129 config PHY_MICREL_KSZ9021
130         bool
131         select PHY_MICREL_KSZ90X1
132
133 config PHY_MICREL_KSZ9031
134         bool
135         select PHY_MICREL_KSZ90X1
136
137 config PHY_MICREL_KSZ90X1
138         bool "Micrel KSZ90x1 family support"
139         select PHY_GIGE
140         help
141           Enable support for the Micrel KSZ9021 and KSZ9031 GbE PHYs. If
142           enabled, the extended register read/write for KSZ90x1 PHYs
143           is supported through the 'mdio' command and any RGMII signal
144           delays configured in the device tree will be applied to the
145           PHY during initialization.
146
147 config PHY_MICREL_KSZ8XXX
148         bool "Micrel KSZ8xxx family support"
149         help
150           Enable support for the 8000 series 10/100 PHYs manufactured by Micrel
151           (now a part of Microchip). This includes drivers for the KSZ804,
152           KSZ8031, KSZ8051, KSZ8081, KSZ8895, KSZ886x, and KSZ8721.
153
154 endif # PHY_MICREL
155
156 config PHY_MSCC
157         bool "Microsemi Corp Ethernet PHYs support"
158
159 config PHY_NATSEMI
160         bool "National Semiconductor Ethernet PHYs support"
161
162 config PHY_REALTEK
163         bool "Realtek Ethernet PHYs support"
164
165 config RTL8211E_PINE64_GIGABIT_FIX
166         bool "Fix gigabit throughput on some Pine64+ models"
167         depends on PHY_REALTEK
168         help
169           Configure the Realtek RTL8211E found on some Pine64+ models differently to
170           fix throughput on Gigabit links, turning off all internal delays in the
171           process. The settings that this touches are not documented in the CONFREG
172           section of the RTL8211E datasheet, but come from Realtek by way of the
173           Pine64 engineering team.
174
175 config RTL8211X_PHY_FORCE_MASTER
176         bool "Ethernet PHY RTL8211x: force 1000BASE-T master mode"
177         depends on PHY_REALTEK
178         help
179           Force master mode for 1000BASE-T on RTl8211x PHYs (except for RTL8211F).
180           This can work around link stability and data corruption issues on gigabit
181           links which can occur in slave mode on certain PHYs, e.g. on the
182           RTL8211C(L).
183
184           Please note that two directly connected devices (i.e. via crossover cable)
185           will not be able to establish a link between each other if they both force
186           master mode. Multiple devices forcing master mode when connected by a
187           network switch do not pose a problem as the switch configures its affected
188           ports into slave mode.
189
190           This option only affects gigabit links. If you must establish a direct
191           connection between two devices which both force master mode, try forcing
192           the link speed to 100MBit/s.
193
194           If unsure, say N.
195
196 config RTL8211F_PHY_FORCE_EEE_RXC_ON
197         bool "Ethernet PHY RTL8211F: do not stop receiving the xMII clock during LPI"
198         depends on PHY_REALTEK
199         default n
200         help
201           The IEEE 802.3az-2010 (EEE) standard provides a protocol to coordinate
202           transitions to/from a lower power consumption level (Low Power Idle
203           mode) based on link utilization. When no packets are being
204           transmitted, the system goes to Low Power Idle mode to save power.
205
206           Under particular circumstances this setting can cause issues where
207           the PHY is unable to transmit or receive any packet when in LPI mode.
208           The problem is caused when the PHY is configured to stop receiving
209           the xMII clock while it is signaling LPI. For some PHYs the bit
210           configuring this behavior is set by the Linux kernel, causing the
211           issue in U-Boot on reboot if the PHY retains the register value.
212
213           Default n, which means that the PHY state is not changed. To work
214           around the issues, change this setting to y.
215
216 config PHY_SMSC
217         bool  "Microchip(SMSC) Ethernet PHYs support"
218
219 config PHY_TERANETICS
220         bool "Teranetics Ethernet PHYs support"
221
222 config PHY_TI
223         bool "Texas Instruments Ethernet PHYs support"
224
225 config PHY_VITESSE
226         bool "Vitesse Ethernet PHYs support"
227
228 config PHY_XILINX
229         bool "Xilinx Ethernet PHYs support"
230
231 config PHY_XILINX_GMII2RGMII
232         bool "Xilinx GMII to RGMII Ethernet PHYs support"
233         help
234           This adds support for Xilinx GMII to RGMII IP core. This IP acts
235           as bridge between MAC connected over GMII and external phy that
236           is connected over RGMII interface.
237
238 config PHY_FIXED
239         bool "Fixed-Link PHY"
240         depends on DM_ETH
241         help
242           Fixed PHY is used for having a 'fixed-link' to another MAC with a direct
243           connection (MII, RGMII, ...).
244           There is nothing like autoneogation and so
245           on, the link is always up with fixed speed and fixed duplex-setting.
246           More information: doc/device-tree-bindings/net/fixed-link.txt
247
248 endif #PHYLIB