xref: /linux/Documentation/devicetree/bindings/net/ethernet-phy.yaml (revision fcc79e1714e8c2b8e216dc3149812edd37884eef)
1# SPDX-License-Identifier: GPL-2.0
2%YAML 1.2
3---
4$id: http://devicetree.org/schemas/net/ethernet-phy.yaml#
5$schema: http://devicetree.org/meta-schemas/core.yaml#
6
7title: Ethernet PHY Common Properties
8
9maintainers:
10  - Andrew Lunn <andrew@lunn.ch>
11  - Florian Fainelli <f.fainelli@gmail.com>
12  - Heiner Kallweit <hkallweit1@gmail.com>
13
14# The dt-schema tools will generate a select statement first by using
15# the compatible, and second by using the node name if any. In our
16# case, the node name is the one we want to match on, while the
17# compatible is optional.
18select:
19  properties:
20    $nodename:
21      pattern: "^ethernet-phy(@[a-f0-9]+)?$"
22
23  required:
24    - $nodename
25
26properties:
27  $nodename:
28    pattern: "^ethernet-phy(@[a-f0-9]+)?$"
29
30  compatible:
31    oneOf:
32      - const: ethernet-phy-ieee802.3-c22
33        description: PHYs that implement IEEE802.3 clause 22
34      - const: ethernet-phy-ieee802.3-c45
35        description: PHYs that implement IEEE802.3 clause 45
36      - pattern: "^ethernet-phy-id[a-f0-9]{4}\\.[a-f0-9]{4}$"
37        description:
38          If the PHY reports an incorrect ID (or none at all) then the
39          compatible list may contain an entry with the correct PHY ID
40          in the above form.
41          The first group of digits is the 16 bit Phy Identifier 1
42          register, this is the chip vendor OUI bits 3:18. The
43          second group of digits is the Phy Identifier 2 register,
44          this is the chip vendor OUI bits 19:24, followed by 10
45          bits of a vendor specific ID.
46      - items:
47          - pattern: "^ethernet-phy-id[a-f0-9]{4}\\.[a-f0-9]{4}$"
48          - const: ethernet-phy-ieee802.3-c22
49      - items:
50          - pattern: "^ethernet-phy-id[a-f0-9]{4}\\.[a-f0-9]{4}$"
51          - const: ethernet-phy-ieee802.3-c45
52
53  reg:
54    minimum: 0
55    maximum: 31
56    description:
57      The ID number for the PHY.
58
59  interrupts:
60    maxItems: 1
61
62  max-speed:
63    enum:
64      - 10
65      - 100
66      - 1000
67      - 2500
68      - 5000
69      - 10000
70      - 20000
71      - 25000
72      - 40000
73      - 50000
74      - 56000
75      - 100000
76      - 200000
77    description:
78      Maximum PHY supported speed in Mbits / seconds.
79
80  phy-10base-t1l-2.4vpp:
81    description: |
82      tristate, request/disable 2.4 Vpp operating mode. The values are:
83      0: Disable 2.4 Vpp operating mode.
84      1: Request 2.4 Vpp operating mode from link partner.
85      Absence of this property will leave configuration to default values.
86    $ref: /schemas/types.yaml#/definitions/uint32
87    enum: [0, 1]
88
89  broken-turn-around:
90    $ref: /schemas/types.yaml#/definitions/flag
91    description:
92      If set, indicates the PHY device does not correctly release
93      the turn around line low at end of the control phase of the
94      MDIO transaction.
95
96  brr-mode:
97    $ref: /schemas/types.yaml#/definitions/flag
98    description:
99      If set, indicates the network cable interface is an alternative one as
100      defined in the BroadR-Reach link mode specification under 1BR-100 and
101      1BR-10 names. The PHY must be configured to operate in BroadR-Reach mode
102      by software.
103
104  clocks:
105    maxItems: 1
106    description:
107      External clock connected to the PHY. If not specified it is assumed
108      that the PHY uses a fixed crystal or an internal oscillator.
109
110  enet-phy-lane-swap:
111    $ref: /schemas/types.yaml#/definitions/flag
112    description:
113      If set, indicates the PHY will swap the TX/RX lanes to
114      compensate for the board being designed with the lanes
115      swapped.
116
117  enet-phy-lane-no-swap:
118    $ref: /schemas/types.yaml#/definitions/flag
119    description:
120      If set, indicates that PHY will disable swap of the
121      TX/RX lanes. This property allows the PHY to work correctly after
122      e.g. wrong bootstrap configuration caused by issues in PCB
123      layout design.
124
125  eee-broken-100tx:
126    $ref: /schemas/types.yaml#/definitions/flag
127    description:
128      Mark the corresponding energy efficient ethernet mode as
129      broken and request the ethernet to stop advertising it.
130
131  eee-broken-1000t:
132    $ref: /schemas/types.yaml#/definitions/flag
133    description:
134      Mark the corresponding energy efficient ethernet mode as
135      broken and request the ethernet to stop advertising it.
136
137  eee-broken-10gt:
138    $ref: /schemas/types.yaml#/definitions/flag
139    description:
140      Mark the corresponding energy efficient ethernet mode as
141      broken and request the ethernet to stop advertising it.
142
143  eee-broken-1000kx:
144    $ref: /schemas/types.yaml#/definitions/flag
145    description:
146      Mark the corresponding energy efficient ethernet mode as
147      broken and request the ethernet to stop advertising it.
148
149  eee-broken-10gkx4:
150    $ref: /schemas/types.yaml#/definitions/flag
151    description:
152      Mark the corresponding energy efficient ethernet mode as
153      broken and request the ethernet to stop advertising it.
154
155  eee-broken-10gkr:
156    $ref: /schemas/types.yaml#/definitions/flag
157    description:
158      Mark the corresponding energy efficient ethernet mode as
159      broken and request the ethernet to stop advertising it.
160
161  timing-role:
162    $ref: /schemas/types.yaml#/definitions/string
163    enum:
164      - forced-master
165      - forced-slave
166      - preferred-master
167      - preferred-slave
168    description: |
169      Specifies the timing role of the PHY in the network link. This property is
170      required for setups where the role must be explicitly assigned via the
171      device tree due to limitations in hardware strapping or incorrect strap
172      configurations.
173      It is applicable to Single Pair Ethernet (1000/100/10Base-T1) and other
174      PHY types, including 1000Base-T, where it controls whether the PHY should
175      be a master (clock source) or a slave (clock receiver).
176
177      - 'forced-master': The PHY is forced to operate as a master.
178      - 'forced-slave': The PHY is forced to operate as a slave.
179      - 'preferred-master': Prefer the PHY to be master but allow negotiation.
180      - 'preferred-slave': Prefer the PHY to be slave but allow negotiation.
181
182  pses:
183    $ref: /schemas/types.yaml#/definitions/phandle-array
184    maxItems: 1
185    description:
186      Specifies a reference to a node representing a Power Sourcing Equipment.
187
188  phy-is-integrated:
189    $ref: /schemas/types.yaml#/definitions/flag
190    description:
191      If set, indicates that the PHY is integrated into the same
192      physical package as the Ethernet MAC. If needed, muxers
193      should be configured to ensure the integrated PHY is
194      used. The absence of this property indicates the muxers
195      should be configured so that the external PHY is used.
196
197  resets:
198    maxItems: 1
199
200  reset-names:
201    const: phy
202
203  reset-gpios:
204    maxItems: 1
205    description:
206      The GPIO phandle and specifier for the PHY reset signal.
207
208  reset-assert-us:
209    description:
210      Delay after the reset was asserted in microseconds. If this
211      property is missing the delay will be skipped.
212
213  reset-deassert-us:
214    description:
215      Delay after the reset was deasserted in microseconds. If
216      this property is missing the delay will be skipped.
217
218  sfp:
219    $ref: /schemas/types.yaml#/definitions/phandle
220    description:
221      Specifies a reference to a node representing a SFP cage.
222
223  rx-internal-delay-ps:
224    description: |
225      RGMII Receive PHY Clock Delay defined in pico seconds.  This is used for
226      PHY's that have configurable RX internal delays.  If this property is
227      present then the PHY applies the RX delay.
228
229  tx-internal-delay-ps:
230    description: |
231      RGMII Transmit PHY Clock Delay defined in pico seconds.  This is used for
232      PHY's that have configurable TX internal delays. If this property is
233      present then the PHY applies the TX delay.
234
235  leds:
236    type: object
237
238    properties:
239      '#address-cells':
240        const: 1
241
242      '#size-cells':
243        const: 0
244
245    patternProperties:
246      '^led@[a-f0-9]+$':
247        $ref: /schemas/leds/common.yaml#
248
249        properties:
250          reg:
251            maxItems: 1
252            description:
253              This define the LED index in the PHY or the MAC. It's really
254              driver dependent and required for ports that define multiple
255              LED for the same port.
256
257        required:
258          - reg
259
260        unevaluatedProperties: false
261
262    additionalProperties: false
263
264required:
265  - reg
266
267additionalProperties: true
268
269examples:
270  - |
271    #include <dt-bindings/leds/common.h>
272
273    ethernet {
274        #address-cells = <1>;
275        #size-cells = <0>;
276
277        ethernet-phy@0 {
278            compatible = "ethernet-phy-id0141.0e90", "ethernet-phy-ieee802.3-c45";
279            interrupt-parent = <&PIC>;
280            interrupts = <35 1>;
281            reg = <0>;
282
283            resets = <&rst 8>;
284            reset-names = "phy";
285            reset-gpios = <&gpio1 4 1>;
286            reset-assert-us = <1000>;
287            reset-deassert-us = <2000>;
288
289            leds {
290                #address-cells = <1>;
291                #size-cells = <0>;
292
293                led@0 {
294                    reg = <0>;
295                    color = <LED_COLOR_ID_WHITE>;
296                    function = LED_FUNCTION_LAN;
297                    default-state = "keep";
298                };
299            };
300        };
301    };
302