2023-08-30 17:31:07 +02:00
|
|
|
# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
|
|
|
|
%YAML 1.2
|
|
|
|
---
|
|
|
|
$id: http://devicetree.org/schemas/net/dsa/nxp,sja1105.yaml#
|
|
|
|
$schema: http://devicetree.org/meta-schemas/core.yaml#
|
|
|
|
|
|
|
|
title: NXP SJA1105 Automotive Ethernet Switch Family
|
|
|
|
|
|
|
|
description:
|
|
|
|
The SJA1105 SPI interface requires a CS-to-CLK time (t2 in UM10944.pdf) of at
|
|
|
|
least one half of t_CLK. At an SPI frequency of 1MHz, this means a minimum
|
|
|
|
cs_sck_delay of 500ns. Ensuring that this SPI timing requirement is observed
|
|
|
|
depends on the SPI bus master driver.
|
|
|
|
|
|
|
|
maintainers:
|
|
|
|
- Vladimir Oltean <vladimir.oltean@nxp.com>
|
|
|
|
|
|
|
|
properties:
|
|
|
|
compatible:
|
|
|
|
enum:
|
|
|
|
- nxp,sja1105e
|
|
|
|
- nxp,sja1105t
|
|
|
|
- nxp,sja1105p
|
|
|
|
- nxp,sja1105q
|
|
|
|
- nxp,sja1105r
|
|
|
|
- nxp,sja1105s
|
|
|
|
- nxp,sja1110a
|
|
|
|
- nxp,sja1110b
|
|
|
|
- nxp,sja1110c
|
|
|
|
- nxp,sja1110d
|
|
|
|
|
|
|
|
reg:
|
|
|
|
maxItems: 1
|
|
|
|
|
2023-10-24 12:59:35 +02:00
|
|
|
spi-cpha: true
|
|
|
|
spi-cpol: true
|
|
|
|
|
2023-08-30 17:31:07 +02:00
|
|
|
# Optional container node for the 2 internal MDIO buses of the SJA1110
|
|
|
|
# (one for the internal 100base-T1 PHYs and the other for the single
|
|
|
|
# 100base-TX PHY). The "reg" property does not have physical significance.
|
|
|
|
# The PHY addresses to port correspondence is as follows: for 100base-T1,
|
|
|
|
# port 5 has PHY 1, port 6 has PHY 2 etc, while for 100base-TX, port 1 has
|
|
|
|
# PHY 1.
|
|
|
|
mdios:
|
|
|
|
type: object
|
|
|
|
|
|
|
|
properties:
|
|
|
|
'#address-cells':
|
|
|
|
const: 1
|
|
|
|
'#size-cells':
|
|
|
|
const: 0
|
|
|
|
|
|
|
|
patternProperties:
|
|
|
|
"^mdio@[0-1]$":
|
|
|
|
$ref: /schemas/net/mdio.yaml#
|
|
|
|
unevaluatedProperties: false
|
|
|
|
|
|
|
|
properties:
|
|
|
|
compatible:
|
|
|
|
oneOf:
|
|
|
|
- enum:
|
|
|
|
- nxp,sja1110-base-t1-mdio
|
|
|
|
- nxp,sja1110-base-tx-mdio
|
|
|
|
|
|
|
|
reg:
|
|
|
|
oneOf:
|
|
|
|
- enum:
|
|
|
|
- 0
|
|
|
|
- 1
|
|
|
|
|
|
|
|
required:
|
|
|
|
- compatible
|
|
|
|
- reg
|
|
|
|
|
|
|
|
patternProperties:
|
|
|
|
"^(ethernet-)?ports$":
|
|
|
|
patternProperties:
|
|
|
|
"^(ethernet-)?port@[0-9]+$":
|
|
|
|
allOf:
|
|
|
|
- if:
|
|
|
|
properties:
|
|
|
|
phy-mode:
|
|
|
|
contains:
|
|
|
|
enum:
|
|
|
|
- rgmii
|
|
|
|
- rgmii-rxid
|
|
|
|
- rgmii-txid
|
|
|
|
- rgmii-id
|
|
|
|
then:
|
|
|
|
properties:
|
|
|
|
rx-internal-delay-ps:
|
|
|
|
$ref: "#/$defs/internal-delay-ps"
|
|
|
|
tx-internal-delay-ps:
|
|
|
|
$ref: "#/$defs/internal-delay-ps"
|
|
|
|
|
|
|
|
required:
|
|
|
|
- compatible
|
|
|
|
- reg
|
|
|
|
|
|
|
|
$defs:
|
|
|
|
internal-delay-ps:
|
|
|
|
description:
|
|
|
|
Disable tunable delay lines using 0 ps, or enable them and select
|
|
|
|
the phase between 1640 ps (73.8 degree shift at 1Gbps) and 2260 ps
|
|
|
|
(101.7 degree shift) in increments of 0.9 degrees (20 ps).
|
|
|
|
enum:
|
|
|
|
[0, 1640, 1660, 1680, 1700, 1720, 1740, 1760, 1780, 1800, 1820, 1840,
|
|
|
|
1860, 1880, 1900, 1920, 1940, 1960, 1980, 2000, 2020, 2040, 2060, 2080,
|
|
|
|
2100, 2120, 2140, 2160, 2180, 2200, 2220, 2240, 2260]
|
|
|
|
|
2023-10-24 12:59:35 +02:00
|
|
|
allOf:
|
|
|
|
- $ref: dsa.yaml#/$defs/ethernet-ports
|
|
|
|
- $ref: /schemas/spi/spi-peripheral-props.yaml#
|
|
|
|
- if:
|
|
|
|
properties:
|
|
|
|
compatible:
|
|
|
|
enum:
|
|
|
|
- nxp,sja1105e
|
|
|
|
- nxp,sja1105p
|
|
|
|
- nxp,sja1105q
|
|
|
|
- nxp,sja1105r
|
|
|
|
- nxp,sja1105s
|
|
|
|
- nxp,sja1105t
|
|
|
|
then:
|
|
|
|
properties:
|
|
|
|
spi-cpol: false
|
|
|
|
required:
|
|
|
|
- spi-cpha
|
|
|
|
else:
|
|
|
|
properties:
|
|
|
|
spi-cpha: false
|
|
|
|
required:
|
|
|
|
- spi-cpol
|
|
|
|
|
2023-08-30 17:31:07 +02:00
|
|
|
unevaluatedProperties: false
|
|
|
|
|
|
|
|
examples:
|
|
|
|
- |
|
|
|
|
spi {
|
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <0>;
|
|
|
|
|
|
|
|
ethernet-switch@1 {
|
|
|
|
reg = <0x1>;
|
|
|
|
compatible = "nxp,sja1105t";
|
2023-10-24 12:59:35 +02:00
|
|
|
spi-cpha;
|
2023-08-30 17:31:07 +02:00
|
|
|
|
|
|
|
ethernet-ports {
|
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <0>;
|
|
|
|
|
|
|
|
port@0 {
|
|
|
|
phy-handle = <&rgmii_phy6>;
|
|
|
|
phy-mode = "rgmii-id";
|
|
|
|
rx-internal-delay-ps = <0>;
|
|
|
|
tx-internal-delay-ps = <0>;
|
|
|
|
reg = <0>;
|
|
|
|
};
|
|
|
|
|
|
|
|
port@1 {
|
|
|
|
phy-handle = <&rgmii_phy3>;
|
|
|
|
phy-mode = "rgmii-id";
|
|
|
|
rx-internal-delay-ps = <0>;
|
|
|
|
tx-internal-delay-ps = <0>;
|
|
|
|
reg = <1>;
|
|
|
|
};
|
|
|
|
|
|
|
|
port@2 {
|
|
|
|
phy-handle = <&rgmii_phy4>;
|
|
|
|
phy-mode = "rgmii-id";
|
|
|
|
rx-internal-delay-ps = <0>;
|
|
|
|
tx-internal-delay-ps = <0>;
|
|
|
|
reg = <2>;
|
|
|
|
};
|
|
|
|
|
|
|
|
port@3 {
|
|
|
|
phy-handle = <&rgmii_phy4>;
|
|
|
|
phy-mode = "rgmii-id";
|
|
|
|
rx-internal-delay-ps = <0>;
|
|
|
|
tx-internal-delay-ps = <0>;
|
|
|
|
reg = <3>;
|
|
|
|
};
|
|
|
|
|
|
|
|
port@4 {
|
|
|
|
ethernet = <&enet2>;
|
|
|
|
phy-mode = "rgmii";
|
|
|
|
rx-internal-delay-ps = <0>;
|
|
|
|
tx-internal-delay-ps = <0>;
|
|
|
|
reg = <4>;
|
|
|
|
|
|
|
|
fixed-link {
|
|
|
|
speed = <1000>;
|
|
|
|
full-duplex;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|