162306a36Sopenharmony_ci# SPDX-License-Identifier: (GPL-2.0 OR BSD-2-Clause) 262306a36Sopenharmony_ci 362306a36Sopenharmony_ci%YAML 1.2 462306a36Sopenharmony_ci--- 562306a36Sopenharmony_ci$id: http://devicetree.org/schemas/phy/marvell,armada-cp110-utmi-phy.yaml# 662306a36Sopenharmony_ci$schema: http://devicetree.org/meta-schemas/core.yaml# 762306a36Sopenharmony_ci 862306a36Sopenharmony_cititle: Marvell Armada CP110/CP115 UTMI PHY 962306a36Sopenharmony_ci 1062306a36Sopenharmony_cimaintainers: 1162306a36Sopenharmony_ci - Konstantin Porotchkin <kostap@marvell.com> 1262306a36Sopenharmony_ci 1362306a36Sopenharmony_cidescription: 1462306a36Sopenharmony_ci On Armada 7k/8k and CN913x, there are two host and one device USB controllers. 1562306a36Sopenharmony_ci Each of two exiting UTMI PHYs could be connected to either USB host or USB device 1662306a36Sopenharmony_ci controller. 1762306a36Sopenharmony_ci The USB device controller can only be connected to a single UTMI PHY port 1862306a36Sopenharmony_ci 0.H----- USB HOST0 1962306a36Sopenharmony_ci UTMI PHY0 --------/ 2062306a36Sopenharmony_ci 0.D-----0 2162306a36Sopenharmony_ci \------ USB DEVICE 2262306a36Sopenharmony_ci 1.D-----1 2362306a36Sopenharmony_ci UTMI PHY1 --------\ 2462306a36Sopenharmony_ci 1.H----- USB HOST1 2562306a36Sopenharmony_ci 2662306a36Sopenharmony_ciproperties: 2762306a36Sopenharmony_ci compatible: 2862306a36Sopenharmony_ci const: marvell,cp110-utmi-phy 2962306a36Sopenharmony_ci 3062306a36Sopenharmony_ci reg: 3162306a36Sopenharmony_ci maxItems: 1 3262306a36Sopenharmony_ci 3362306a36Sopenharmony_ci "#address-cells": 3462306a36Sopenharmony_ci const: 1 3562306a36Sopenharmony_ci 3662306a36Sopenharmony_ci "#size-cells": 3762306a36Sopenharmony_ci const: 0 3862306a36Sopenharmony_ci 3962306a36Sopenharmony_ci marvell,system-controller: 4062306a36Sopenharmony_ci description: 4162306a36Sopenharmony_ci Phandle to the system controller node 4262306a36Sopenharmony_ci $ref: /schemas/types.yaml#/definitions/phandle 4362306a36Sopenharmony_ci 4462306a36Sopenharmony_ci# Required child nodes: 4562306a36Sopenharmony_ci 4662306a36Sopenharmony_cipatternProperties: 4762306a36Sopenharmony_ci "^usb-phy@[0|1]$": 4862306a36Sopenharmony_ci type: object 4962306a36Sopenharmony_ci description: 5062306a36Sopenharmony_ci Each UTMI PHY port must be represented as a sub-node. 5162306a36Sopenharmony_ci 5262306a36Sopenharmony_ci properties: 5362306a36Sopenharmony_ci reg: 5462306a36Sopenharmony_ci description: phy port index. 5562306a36Sopenharmony_ci maxItems: 1 5662306a36Sopenharmony_ci 5762306a36Sopenharmony_ci "#phy-cells": 5862306a36Sopenharmony_ci const: 0 5962306a36Sopenharmony_ci 6062306a36Sopenharmony_ci required: 6162306a36Sopenharmony_ci - reg 6262306a36Sopenharmony_ci - "#phy-cells" 6362306a36Sopenharmony_ci 6462306a36Sopenharmony_ci additionalProperties: false 6562306a36Sopenharmony_ci 6662306a36Sopenharmony_cirequired: 6762306a36Sopenharmony_ci - compatible 6862306a36Sopenharmony_ci - reg 6962306a36Sopenharmony_ci - "#address-cells" 7062306a36Sopenharmony_ci - "#size-cells" 7162306a36Sopenharmony_ci - marvell,system-controller 7262306a36Sopenharmony_ci 7362306a36Sopenharmony_ciadditionalProperties: false 7462306a36Sopenharmony_ci 7562306a36Sopenharmony_ciexamples: 7662306a36Sopenharmony_ci - | 7762306a36Sopenharmony_ci cp0_utmi: utmi@580000 { 7862306a36Sopenharmony_ci compatible = "marvell,cp110-utmi-phy"; 7962306a36Sopenharmony_ci reg = <0x580000 0x2000>; 8062306a36Sopenharmony_ci marvell,system-controller = <&cp0_syscon0>; 8162306a36Sopenharmony_ci #address-cells = <1>; 8262306a36Sopenharmony_ci #size-cells = <0>; 8362306a36Sopenharmony_ci 8462306a36Sopenharmony_ci cp0_utmi0: usb-phy@0 { 8562306a36Sopenharmony_ci reg = <0>; 8662306a36Sopenharmony_ci #phy-cells = <0>; 8762306a36Sopenharmony_ci }; 8862306a36Sopenharmony_ci 8962306a36Sopenharmony_ci cp0_utmi1: usb-phy@1 { 9062306a36Sopenharmony_ci reg = <1>; 9162306a36Sopenharmony_ci #phy-cells = <0>; 9262306a36Sopenharmony_ci }; 9362306a36Sopenharmony_ci }; 9462306a36Sopenharmony_ci 9562306a36Sopenharmony_ci cp0_usb3_0 { 9662306a36Sopenharmony_ci usb-phy = <&cp0_usb3_0_phy0>; 9762306a36Sopenharmony_ci phys = <&cp0_utmi0>; 9862306a36Sopenharmony_ci phy-names = "utmi"; 9962306a36Sopenharmony_ci /* UTMI0 is connected to USB host controller (default mode) */ 10062306a36Sopenharmony_ci dr_mode = "host"; 10162306a36Sopenharmony_ci }; 10262306a36Sopenharmony_ci 10362306a36Sopenharmony_ci cp0_usb3_1 { 10462306a36Sopenharmony_ci usb-phy = <&cp0_usb3_0_phy1>; 10562306a36Sopenharmony_ci phys = <&cp0_utmi1>; 10662306a36Sopenharmony_ci phy-names = "utmi"; 10762306a36Sopenharmony_ci /* UTMI1 is connected to USB device controller */ 10862306a36Sopenharmony_ci dr_mode = "peripheral"; 10962306a36Sopenharmony_ci }; 110