1665a6961SKrishna Manikandan# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
2665a6961SKrishna Manikandan%YAML 1.2
3665a6961SKrishna Manikandan---
4665a6961SKrishna Manikandan$id: http://devicetree.org/schemas/display/msm/dp-controller.yaml#
5665a6961SKrishna Manikandan$schema: http://devicetree.org/meta-schemas/core.yaml#
6665a6961SKrishna Manikandan
7665a6961SKrishna Manikandantitle: MSM Display Port Controller
8665a6961SKrishna Manikandan
9665a6961SKrishna Manikandanmaintainers:
10665a6961SKrishna Manikandan  - Kuogee Hsieh <khsieh@codeaurora.org>
11665a6961SKrishna Manikandan
12665a6961SKrishna Manikandandescription: |
13665a6961SKrishna Manikandan  Device tree bindings for DisplayPort host controller for MSM targets
14665a6961SKrishna Manikandan  that are compatible with VESA DisplayPort interface specification.
15665a6961SKrishna Manikandan
16665a6961SKrishna Manikandanproperties:
17665a6961SKrishna Manikandan  compatible:
18665a6961SKrishna Manikandan    enum:
19665a6961SKrishna Manikandan      - qcom,sc7180-dp
200a697b9cSSankeerth Billakanti      - qcom,sc7280-dp
210a697b9cSSankeerth Billakanti      - qcom,sc7280-edp
22e60af4f8SBjorn Andersson      - qcom,sc8180x-dp
23e60af4f8SBjorn Andersson      - qcom,sc8180x-edp
24f5408b21SBjorn Andersson      - qcom,sm8350-dp
25665a6961SKrishna Manikandan
26665a6961SKrishna Manikandan  reg:
27687825c4SBjorn Andersson    items:
28687825c4SBjorn Andersson      - description: ahb register block
29687825c4SBjorn Andersson      - description: aux register block
30687825c4SBjorn Andersson      - description: link register block
31687825c4SBjorn Andersson      - description: p0 register block
32687825c4SBjorn Andersson      - description: p1 register block
33665a6961SKrishna Manikandan
34665a6961SKrishna Manikandan  interrupts:
35665a6961SKrishna Manikandan    maxItems: 1
36665a6961SKrishna Manikandan
37665a6961SKrishna Manikandan  clocks:
38665a6961SKrishna Manikandan    items:
39665a6961SKrishna Manikandan      - description: AHB clock to enable register access
40665a6961SKrishna Manikandan      - description: Display Port AUX clock
41665a6961SKrishna Manikandan      - description: Display Port Link clock
42665a6961SKrishna Manikandan      - description: Link interface clock between DP and PHY
43665a6961SKrishna Manikandan      - description: Display Port Pixel clock
44665a6961SKrishna Manikandan
45665a6961SKrishna Manikandan  clock-names:
46665a6961SKrishna Manikandan    items:
47665a6961SKrishna Manikandan      - const: core_iface
48665a6961SKrishna Manikandan      - const: core_aux
49665a6961SKrishna Manikandan      - const: ctrl_link
50665a6961SKrishna Manikandan      - const: ctrl_link_iface
51665a6961SKrishna Manikandan      - const: stream_pixel
52665a6961SKrishna Manikandan
53665a6961SKrishna Manikandan  assigned-clocks:
54665a6961SKrishna Manikandan    items:
55665a6961SKrishna Manikandan      - description: link clock source
56665a6961SKrishna Manikandan      - description: pixel clock source
57665a6961SKrishna Manikandan
58665a6961SKrishna Manikandan  assigned-clock-parents:
59665a6961SKrishna Manikandan    items:
60665a6961SKrishna Manikandan      - description: phy 0 parent
61665a6961SKrishna Manikandan      - description: phy 1 parent
62665a6961SKrishna Manikandan
63665a6961SKrishna Manikandan  phys:
64665a6961SKrishna Manikandan    maxItems: 1
65665a6961SKrishna Manikandan
66665a6961SKrishna Manikandan  phy-names:
67665a6961SKrishna Manikandan    items:
68665a6961SKrishna Manikandan      - const: dp
69665a6961SKrishna Manikandan
70665a6961SKrishna Manikandan  operating-points-v2:
71665a6961SKrishna Manikandan    maxItems: 1
72665a6961SKrishna Manikandan
73665a6961SKrishna Manikandan  power-domains:
74665a6961SKrishna Manikandan    maxItems: 1
75665a6961SKrishna Manikandan
76665a6961SKrishna Manikandan  "#sound-dai-cells":
77665a6961SKrishna Manikandan    const: 0
78665a6961SKrishna Manikandan
79*ce557eafSDouglas Anderson  vdda-0p9-supply: true
80*ce557eafSDouglas Anderson  vdda-1p2-supply: true
81*ce557eafSDouglas Anderson
82665a6961SKrishna Manikandan  ports:
83665a6961SKrishna Manikandan    $ref: /schemas/graph.yaml#/properties/ports
84665a6961SKrishna Manikandan    properties:
85665a6961SKrishna Manikandan      port@0:
86665a6961SKrishna Manikandan        $ref: /schemas/graph.yaml#/properties/port
87665a6961SKrishna Manikandan        description: Input endpoint of the controller
88665a6961SKrishna Manikandan
89665a6961SKrishna Manikandan      port@1:
90665a6961SKrishna Manikandan        $ref: /schemas/graph.yaml#/properties/port
91665a6961SKrishna Manikandan        description: Output endpoint of the controller
92665a6961SKrishna Manikandan
93665a6961SKrishna Manikandanrequired:
94665a6961SKrishna Manikandan  - compatible
95665a6961SKrishna Manikandan  - reg
96665a6961SKrishna Manikandan  - interrupts
97665a6961SKrishna Manikandan  - clocks
98665a6961SKrishna Manikandan  - clock-names
99665a6961SKrishna Manikandan  - phys
100665a6961SKrishna Manikandan  - phy-names
101665a6961SKrishna Manikandan  - "#sound-dai-cells"
102665a6961SKrishna Manikandan  - power-domains
103665a6961SKrishna Manikandan  - ports
104665a6961SKrishna Manikandan
105665a6961SKrishna ManikandanadditionalProperties: false
106665a6961SKrishna Manikandan
107665a6961SKrishna Manikandanexamples:
108665a6961SKrishna Manikandan  - |
109665a6961SKrishna Manikandan    #include <dt-bindings/interrupt-controller/arm-gic.h>
110665a6961SKrishna Manikandan    #include <dt-bindings/clock/qcom,dispcc-sc7180.h>
111665a6961SKrishna Manikandan    #include <dt-bindings/power/qcom-rpmpd.h>
112665a6961SKrishna Manikandan
113665a6961SKrishna Manikandan    displayport-controller@ae90000 {
114665a6961SKrishna Manikandan        compatible = "qcom,sc7180-dp";
115687825c4SBjorn Andersson        reg = <0xae90000 0x200>,
116687825c4SBjorn Andersson              <0xae90200 0x200>,
117687825c4SBjorn Andersson              <0xae90400 0xc00>,
118687825c4SBjorn Andersson              <0xae91000 0x400>,
119687825c4SBjorn Andersson              <0xae91400 0x400>;
120665a6961SKrishna Manikandan        interrupt-parent = <&mdss>;
121665a6961SKrishna Manikandan        interrupts = <12>;
122665a6961SKrishna Manikandan        clocks = <&dispcc DISP_CC_MDSS_AHB_CLK>,
123665a6961SKrishna Manikandan                 <&dispcc DISP_CC_MDSS_DP_AUX_CLK>,
124665a6961SKrishna Manikandan                 <&dispcc DISP_CC_MDSS_DP_LINK_CLK>,
125665a6961SKrishna Manikandan                 <&dispcc DISP_CC_MDSS_DP_LINK_INTF_CLK>,
126665a6961SKrishna Manikandan                 <&dispcc DISP_CC_MDSS_DP_PIXEL_CLK>;
127665a6961SKrishna Manikandan        clock-names = "core_iface", "core_aux",
128665a6961SKrishna Manikandan                      "ctrl_link",
129665a6961SKrishna Manikandan                      "ctrl_link_iface", "stream_pixel";
130665a6961SKrishna Manikandan
131665a6961SKrishna Manikandan        assigned-clocks = <&dispcc DISP_CC_MDSS_DP_LINK_CLK_SRC>,
132665a6961SKrishna Manikandan                          <&dispcc DISP_CC_MDSS_DP_PIXEL_CLK_SRC>;
133665a6961SKrishna Manikandan
134665a6961SKrishna Manikandan        assigned-clock-parents = <&dp_phy 0>, <&dp_phy 1>;
135665a6961SKrishna Manikandan
136665a6961SKrishna Manikandan        phys = <&dp_phy>;
137665a6961SKrishna Manikandan        phy-names = "dp";
138665a6961SKrishna Manikandan
139665a6961SKrishna Manikandan        #sound-dai-cells = <0>;
140665a6961SKrishna Manikandan
141665a6961SKrishna Manikandan        power-domains = <&rpmhpd SC7180_CX>;
142665a6961SKrishna Manikandan
143*ce557eafSDouglas Anderson        vdda-0p9-supply = <&vdda_usb_ss_dp_core>;
144*ce557eafSDouglas Anderson        vdda-1p2-supply = <&vdda_usb_ss_dp_1p2>;
145*ce557eafSDouglas Anderson
146665a6961SKrishna Manikandan        ports {
147665a6961SKrishna Manikandan            #address-cells = <1>;
148665a6961SKrishna Manikandan            #size-cells = <0>;
149665a6961SKrishna Manikandan
150665a6961SKrishna Manikandan            port@0 {
151665a6961SKrishna Manikandan                reg = <0>;
152665a6961SKrishna Manikandan                endpoint {
153665a6961SKrishna Manikandan                    remote-endpoint = <&dpu_intf0_out>;
154665a6961SKrishna Manikandan                };
155665a6961SKrishna Manikandan            };
156665a6961SKrishna Manikandan
157665a6961SKrishna Manikandan            port@1 {
158665a6961SKrishna Manikandan                reg = <1>;
159665a6961SKrishna Manikandan                endpoint {
160665a6961SKrishna Manikandan                    remote-endpoint = <&typec>;
161665a6961SKrishna Manikandan                };
162665a6961SKrishna Manikandan            };
163665a6961SKrishna Manikandan        };
164665a6961SKrishna Manikandan    };
165665a6961SKrishna Manikandan...
166