# 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 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#/$defs/ethernet-ports properties: compatible: items: - enum: - renesas,r9a06g032-a5psw - const: renesas,rzn1-a5psw reg: maxItems: 1 interrupts: items: - description: Device Level Ring (DLR) interrupt - description: Switch interrupt - description: Parallel Redundancy Protocol (PRP) interrupt - description: Integrated HUB module interrupt - description: Receive Pattern Match interrupt interrupt-names: items: - const: dlr - const: switch - const: prp - const: hub - const: ptrn 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 additionalProperties: true patternProperties: "^(ethernet-)?port@[0-4]$": type: object additionalProperties: true properties: pcs-handle: maxItems: 1 description: phandle pointing to a PCS sub-node compatible with renesas,rzn1-miic.yaml# unevaluatedProperties: false required: - compatible - reg - clocks - clock-names - power-domains examples: - | #include #include #include 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>; interrupts = , , , , ; interrupt-names = "dlr", "switch", "prp", "hub", "ptrn"; 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>; phy-mode = "internal"; 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>; }; }; };