xref: /linux/Documentation/devicetree/bindings/usb/onnn,nb7vpq904m.yaml (revision 3ba84ac69b53e6ee07c31d54554e00793d7b144f)
1# SPDX-License-Identifier: GPL-2.0-only OR BSD-2-Clause
2%YAML 1.2
3---
4$id: http://devicetree.org/schemas/usb/onnn,nb7vpq904m.yaml#
5$schema: http://devicetree.org/meta-schemas/core.yaml#
6
7title: ON Semiconductor Type-C DisplayPort ALT Mode Linear Redriver
8
9maintainers:
10  - Neil Armstrong <neil.armstrong@linaro.org>
11
12properties:
13  compatible:
14    enum:
15      - onnn,nb7vpq904m
16
17  reg:
18    maxItems: 1
19
20  vcc-supply:
21    description: power supply (1.8V)
22
23  enable-gpios: true
24  orientation-switch: true
25  retimer-switch: true
26
27  ports:
28    $ref: /schemas/graph.yaml#/properties/ports
29    properties:
30      port@0:
31        $ref: /schemas/graph.yaml#/properties/port
32        description: Super Speed (SS) Output endpoint to the Type-C connector
33
34      port@1:
35        $ref: /schemas/graph.yaml#/$defs/port-base
36        description: Super Speed (SS) Input endpoint from the Super-Speed PHY
37        unevaluatedProperties: false
38
39        properties:
40          endpoint:
41            $ref: /schemas/graph.yaml#/$defs/endpoint-base
42            unevaluatedProperties: false
43
44            properties:
45              data-lanes:
46                $ref: /schemas/types.yaml#/definitions/uint32-array
47                description: |
48                  An array of physical data lane indexes. Position determines how
49                  lanes are connected to the redriver, It is assumed the same order
50                  is kept on the other side of the redriver.
51                  Lane number represents the following
52                  - 0 is RX2 lane
53                  - 1 is TX2 lane
54                  - 2 is TX1 lane
55                  - 3 is RX1 lane
56                  The position determines the physical port of the redriver, in the
57                  order A, B, C & D.
58                oneOf:
59                  - items:
60                      - const: 0
61                      - const: 1
62                      - const: 2
63                      - const: 3
64                    description: |
65                      This is the lanes default layout
66                      - Port A to RX2 lane
67                      - Port B to TX2 lane
68                      - Port C to TX1 lane
69                      - Port D to RX1 lane
70                  - items:
71                      - const: 3
72                      - const: 2
73                      - const: 1
74                      - const: 0
75                    description: |
76                      This is the USBRX2/USBTX2 and USBRX1/USBTX1 swapped lanes layout
77                      - Port A to RX1 lane
78                      - Port B to TX1 lane
79                      - Port C to TX2 lane
80                      - Port D to RX2 lane
81
82      port@2:
83        $ref: /schemas/graph.yaml#/properties/port
84        description:
85          Sideband Use (SBU) AUX lines endpoint to the Type-C connector for the purpose of
86          handling altmode muxing and orientation switching.
87
88required:
89  - compatible
90  - reg
91
92allOf:
93  - $ref: usb-switch.yaml#
94
95additionalProperties: false
96
97examples:
98  - |
99    i2c {
100        #address-cells = <1>;
101        #size-cells = <0>;
102
103        typec-mux@32 {
104            compatible = "onnn,nb7vpq904m";
105            reg = <0x32>;
106
107            vcc-supply = <&vreg_l15b_1p8>;
108
109            retimer-switch;
110            orientation-switch;
111
112            ports {
113                #address-cells = <1>;
114                #size-cells = <0>;
115
116                port@0 {
117                    reg = <0>;
118                    usb_con_ss: endpoint {
119                        remote-endpoint = <&typec_con_ss>;
120                    };
121                };
122                port@1 {
123                    reg = <1>;
124                    phy_con_ss: endpoint {
125                        remote-endpoint = <&usb_phy_ss>;
126                        data-lanes = <3 2 1 0>;
127                    };
128                };
129                port@2 {
130                    reg = <2>;
131                    usb_con_sbu: endpoint {
132                        remote-endpoint = <&typec_dp_aux>;
133                    };
134                };
135            };
136        };
137    };
138...
139