162306a36Sopenharmony_ci# SPDX-License-Identifier: GPL-2.0-only 262306a36Sopenharmony_ci%YAML 1.2 362306a36Sopenharmony_ci--- 462306a36Sopenharmony_ci$id: http://devicetree.org/schemas/usb/renesas,usb3-peri.yaml# 562306a36Sopenharmony_ci$schema: http://devicetree.org/meta-schemas/core.yaml# 662306a36Sopenharmony_ci 762306a36Sopenharmony_cititle: Renesas USB 3.0 Peripheral controller 862306a36Sopenharmony_ci 962306a36Sopenharmony_cimaintainers: 1062306a36Sopenharmony_ci - Yoshihiro Shimoda <yoshihiro.shimoda.uh@renesas.com> 1162306a36Sopenharmony_ci 1262306a36Sopenharmony_ciproperties: 1362306a36Sopenharmony_ci compatible: 1462306a36Sopenharmony_ci oneOf: 1562306a36Sopenharmony_ci - items: 1662306a36Sopenharmony_ci - enum: 1762306a36Sopenharmony_ci - renesas,r8a774a1-usb3-peri # RZ/G2M 1862306a36Sopenharmony_ci - renesas,r8a774b1-usb3-peri # RZ/G2N 1962306a36Sopenharmony_ci - renesas,r8a774c0-usb3-peri # RZ/G2E 2062306a36Sopenharmony_ci - renesas,r8a774e1-usb3-peri # RZ/G2H 2162306a36Sopenharmony_ci - renesas,r8a7795-usb3-peri # R-Car H3 2262306a36Sopenharmony_ci - renesas,r8a7796-usb3-peri # R-Car M3-W 2362306a36Sopenharmony_ci - renesas,r8a77961-usb3-peri # R-Car M3-W+ 2462306a36Sopenharmony_ci - renesas,r8a77965-usb3-peri # R-Car M3-N 2562306a36Sopenharmony_ci - renesas,r8a77990-usb3-peri # R-Car E3 2662306a36Sopenharmony_ci - const: renesas,rcar-gen3-usb3-peri 2762306a36Sopenharmony_ci 2862306a36Sopenharmony_ci - items: 2962306a36Sopenharmony_ci - enum: 3062306a36Sopenharmony_ci - renesas,r9a09g011-usb3-peri # RZ/V2M 3162306a36Sopenharmony_ci - renesas,r9a09g055-usb3-peri # RZ/V2MA 3262306a36Sopenharmony_ci - const: renesas,rzv2m-usb3-peri 3362306a36Sopenharmony_ci 3462306a36Sopenharmony_ci reg: 3562306a36Sopenharmony_ci maxItems: 1 3662306a36Sopenharmony_ci 3762306a36Sopenharmony_ci interrupts: 3862306a36Sopenharmony_ci maxItems: 1 3962306a36Sopenharmony_ci 4062306a36Sopenharmony_ci clocks: 4162306a36Sopenharmony_ci minItems: 1 4262306a36Sopenharmony_ci items: 4362306a36Sopenharmony_ci - description: Main clock 4462306a36Sopenharmony_ci - description: Register access clock 4562306a36Sopenharmony_ci 4662306a36Sopenharmony_ci clock-names: 4762306a36Sopenharmony_ci minItems: 1 4862306a36Sopenharmony_ci items: 4962306a36Sopenharmony_ci - const: axi 5062306a36Sopenharmony_ci - const: reg 5162306a36Sopenharmony_ci 5262306a36Sopenharmony_ci phys: 5362306a36Sopenharmony_ci maxItems: 1 5462306a36Sopenharmony_ci 5562306a36Sopenharmony_ci phy-names: 5662306a36Sopenharmony_ci const: usb 5762306a36Sopenharmony_ci 5862306a36Sopenharmony_ci power-domains: 5962306a36Sopenharmony_ci maxItems: 1 6062306a36Sopenharmony_ci 6162306a36Sopenharmony_ci resets: 6262306a36Sopenharmony_ci maxItems: 1 6362306a36Sopenharmony_ci 6462306a36Sopenharmony_ci usb-role-switch: 6562306a36Sopenharmony_ci $ref: /schemas/types.yaml#/definitions/flag 6662306a36Sopenharmony_ci description: Support role switch. 6762306a36Sopenharmony_ci 6862306a36Sopenharmony_ci companion: 6962306a36Sopenharmony_ci $ref: /schemas/types.yaml#/definitions/phandle 7062306a36Sopenharmony_ci description: phandle of a companion. 7162306a36Sopenharmony_ci 7262306a36Sopenharmony_ci ports: 7362306a36Sopenharmony_ci $ref: /schemas/graph.yaml#/properties/ports 7462306a36Sopenharmony_ci description: | 7562306a36Sopenharmony_ci any connector to the data bus of this controller should be modelled 7662306a36Sopenharmony_ci using the OF graph bindings specified, if the "usb-role-switch" 7762306a36Sopenharmony_ci property is used. 7862306a36Sopenharmony_ci 7962306a36Sopenharmony_ci properties: 8062306a36Sopenharmony_ci port@0: 8162306a36Sopenharmony_ci $ref: /schemas/graph.yaml#/properties/port 8262306a36Sopenharmony_ci description: High Speed (HS) data bus. 8362306a36Sopenharmony_ci 8462306a36Sopenharmony_ci port@1: 8562306a36Sopenharmony_ci $ref: /schemas/graph.yaml#/properties/port 8662306a36Sopenharmony_ci description: Super Speed (SS) data bus. 8762306a36Sopenharmony_ci 8862306a36Sopenharmony_ci required: 8962306a36Sopenharmony_ci - port@0 9062306a36Sopenharmony_ci - port@1 9162306a36Sopenharmony_ci 9262306a36Sopenharmony_cirequired: 9362306a36Sopenharmony_ci - compatible 9462306a36Sopenharmony_ci - interrupts 9562306a36Sopenharmony_ci - clocks 9662306a36Sopenharmony_ci 9762306a36Sopenharmony_ciallOf: 9862306a36Sopenharmony_ci - if: 9962306a36Sopenharmony_ci properties: 10062306a36Sopenharmony_ci compatible: 10162306a36Sopenharmony_ci contains: 10262306a36Sopenharmony_ci enum: 10362306a36Sopenharmony_ci - renesas,rzv2m-usb3-peri 10462306a36Sopenharmony_ci then: 10562306a36Sopenharmony_ci properties: 10662306a36Sopenharmony_ci clocks: 10762306a36Sopenharmony_ci minItems: 2 10862306a36Sopenharmony_ci clock-names: 10962306a36Sopenharmony_ci minItems: 2 11062306a36Sopenharmony_ci required: 11162306a36Sopenharmony_ci - clock-names 11262306a36Sopenharmony_ci - resets 11362306a36Sopenharmony_ci else: 11462306a36Sopenharmony_ci properties: 11562306a36Sopenharmony_ci clocks: 11662306a36Sopenharmony_ci maxItems: 1 11762306a36Sopenharmony_ci 11862306a36Sopenharmony_ciadditionalProperties: false 11962306a36Sopenharmony_ci 12062306a36Sopenharmony_ciexamples: 12162306a36Sopenharmony_ci - | 12262306a36Sopenharmony_ci #include <dt-bindings/clock/r8a774c0-cpg-mssr.h> 12362306a36Sopenharmony_ci #include <dt-bindings/interrupt-controller/arm-gic.h> 12462306a36Sopenharmony_ci #include <dt-bindings/power/r8a774c0-sysc.h> 12562306a36Sopenharmony_ci 12662306a36Sopenharmony_ci usb3_peri0: usb@ee020000 { 12762306a36Sopenharmony_ci compatible = "renesas,r8a774c0-usb3-peri", "renesas,rcar-gen3-usb3-peri"; 12862306a36Sopenharmony_ci reg = <0xee020000 0x400>; 12962306a36Sopenharmony_ci interrupts = <GIC_SPI 104 IRQ_TYPE_LEVEL_HIGH>; 13062306a36Sopenharmony_ci clocks = <&cpg CPG_MOD 328>; 13162306a36Sopenharmony_ci companion = <&xhci0>; 13262306a36Sopenharmony_ci usb-role-switch; 13362306a36Sopenharmony_ci 13462306a36Sopenharmony_ci ports { 13562306a36Sopenharmony_ci #address-cells = <1>; 13662306a36Sopenharmony_ci #size-cells = <0>; 13762306a36Sopenharmony_ci port@0 { 13862306a36Sopenharmony_ci reg = <0>; 13962306a36Sopenharmony_ci usb3_hs_ep: endpoint { 14062306a36Sopenharmony_ci remote-endpoint = <&hs_ep>; 14162306a36Sopenharmony_ci }; 14262306a36Sopenharmony_ci }; 14362306a36Sopenharmony_ci port@1 { 14462306a36Sopenharmony_ci reg = <1>; 14562306a36Sopenharmony_ci usb3_role_switch: endpoint { 14662306a36Sopenharmony_ci remote-endpoint = <&hd3ss3220_out_ep>; 14762306a36Sopenharmony_ci }; 14862306a36Sopenharmony_ci }; 14962306a36Sopenharmony_ci }; 15062306a36Sopenharmony_ci }; 151