-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
dt-bindings: net: dsa: add bindings for Renesas RZ/N1 Advanced 5 port…
… switch Add bindings for Renesas RZ/N1 Advanced 5 port switch. This switch is present on Renesas RZ/N1 SoC and was probably provided by MoreThanIP. This company does not exists anymore and has been bought by Synopsys. Since this IP can't be find anymore in the Synospsy portfolio, lets use Renesas as the vendor compatible for this IP. Signed-off-by: Clément Léger <clement.leger@bootlin.com> Reviewed-by: Geert Uytterhoeven <geert+renesas@glider.be> Reviewed-by: Rob Herring <robh@kernel.org> Reviewed-by: Florian Fainelli <f.fainelli@gmail.com> Signed-off-by: David S. Miller <davem@davemloft.net>
- Loading branch information
Clément Léger
authored and
David S. Miller
committed
Jun 27, 2022
1 parent
7dc54d3
commit 8956e96
Showing
1 changed file
with
134 additions
and
0 deletions.
There are no files selected for viewing
134 changes: 134 additions & 0 deletions
134
Documentation/devicetree/bindings/net/dsa/renesas,rzn1-a5psw.yaml
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,134 @@ | ||
# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) | ||
%YAML 1.2 | ||
--- | ||
$id: http://devicetree.org/schemas/net/dsa/renesas,rzn1-a5psw.yaml# | ||
$schema: http://devicetree.org/meta-schemas/core.yaml# | ||
|
||
title: Renesas RZ/N1 Advanced 5 ports ethernet switch | ||
|
||
maintainers: | ||
- Clément Léger <clement.leger@bootlin.com> | ||
|
||
description: | | ||
The advanced 5 ports switch is present on the Renesas RZ/N1 SoC family and | ||
handles 4 ports + 1 CPU management port. | ||
allOf: | ||
- $ref: dsa.yaml# | ||
|
||
properties: | ||
compatible: | ||
items: | ||
- enum: | ||
- renesas,r9a06g032-a5psw | ||
- const: renesas,rzn1-a5psw | ||
|
||
reg: | ||
maxItems: 1 | ||
|
||
power-domains: | ||
maxItems: 1 | ||
|
||
mdio: | ||
$ref: /schemas/net/mdio.yaml# | ||
unevaluatedProperties: false | ||
|
||
clocks: | ||
items: | ||
- description: AHB clock used for the switch register interface | ||
- description: Switch system clock | ||
|
||
clock-names: | ||
items: | ||
- const: hclk | ||
- const: clk | ||
|
||
ethernet-ports: | ||
type: object | ||
properties: | ||
'#address-cells': | ||
const: 1 | ||
'#size-cells': | ||
const: 0 | ||
|
||
patternProperties: | ||
"^(ethernet-)?port@[0-4]$": | ||
type: object | ||
description: Ethernet switch ports | ||
|
||
properties: | ||
pcs-handle: | ||
description: | ||
phandle pointing to a PCS sub-node compatible with | ||
renesas,rzn1-miic.yaml# | ||
$ref: /schemas/types.yaml#/definitions/phandle | ||
|
||
unevaluatedProperties: false | ||
|
||
required: | ||
- compatible | ||
- reg | ||
- clocks | ||
- clock-names | ||
- power-domains | ||
|
||
examples: | ||
- | | ||
#include <dt-bindings/gpio/gpio.h> | ||
#include <dt-bindings/clock/r9a06g032-sysctrl.h> | ||
switch@44050000 { | ||
compatible = "renesas,r9a06g032-a5psw", "renesas,rzn1-a5psw"; | ||
reg = <0x44050000 0x10000>; | ||
clocks = <&sysctrl R9A06G032_HCLK_SWITCH>, <&sysctrl R9A06G032_CLK_SWITCH>; | ||
clock-names = "hclk", "clk"; | ||
power-domains = <&sysctrl>; | ||
dsa,member = <0 0>; | ||
ethernet-ports { | ||
#address-cells = <1>; | ||
#size-cells = <0>; | ||
port@0 { | ||
reg = <0>; | ||
label = "lan0"; | ||
phy-handle = <&switch0phy3>; | ||
pcs-handle = <&mii_conv4>; | ||
}; | ||
port@1 { | ||
reg = <1>; | ||
label = "lan1"; | ||
phy-handle = <&switch0phy1>; | ||
pcs-handle = <&mii_conv3>; | ||
}; | ||
port@4 { | ||
reg = <4>; | ||
ethernet = <&gmac2>; | ||
label = "cpu"; | ||
fixed-link { | ||
speed = <1000>; | ||
full-duplex; | ||
}; | ||
}; | ||
}; | ||
mdio { | ||
#address-cells = <1>; | ||
#size-cells = <0>; | ||
reset-gpios = <&gpio0a 2 GPIO_ACTIVE_HIGH>; | ||
reset-delay-us = <15>; | ||
clock-frequency = <2500000>; | ||
switch0phy1: ethernet-phy@1{ | ||
reg = <1>; | ||
}; | ||
switch0phy3: ethernet-phy@3{ | ||
reg = <3>; | ||
}; | ||
}; | ||
}; |