Mention branches and keyring.
[releases.git] / bindings / display / msm / qcom,sc8280xp-mdss.yaml
1 # SPDX-License-Identifier: GPL-2.0-only OR BSD-2-Clause
2 %YAML 1.2
3 ---
4 $id: http://devicetree.org/schemas/display/msm/qcom,sc8280xp-mdss.yaml#
5 $schema: http://devicetree.org/meta-schemas/core.yaml#
6
7 title: Qualcomm SC8280XP Mobile Display Subsystem
8
9 maintainers:
10   - Bjorn Andersson <andersson@kernel.org>
11
12 description:
13   Device tree bindings for MSM Mobile Display Subsystem (MDSS) that encapsulates
14   sub-blocks like DPU display controller, DSI and DP interfaces etc.
15
16 $ref: /schemas/display/msm/mdss-common.yaml#
17
18 properties:
19   compatible:
20     const: qcom,sc8280xp-mdss
21
22   clocks:
23     items:
24       - description: Display AHB clock from gcc
25       - description: Display AHB clock from dispcc
26       - description: Display core clock
27
28   clock-names:
29     items:
30       - const: iface
31       - const: ahb
32       - const: core
33
34 patternProperties:
35   "^display-controller@[0-9a-f]+$":
36     type: object
37     additionalProperties: true
38
39     properties:
40       compatible:
41         const: qcom,sc8280xp-dpu
42
43   "^displayport-controller@[0-9a-f]+$":
44     type: object
45     additionalProperties: true
46
47     properties:
48       compatible:
49         enum:
50           - qcom,sc8280xp-dp
51           - qcom,sc8280xp-edp
52
53 unevaluatedProperties: false
54
55 examples:
56   - |
57     #include <dt-bindings/clock/qcom,dispcc-sc8280xp.h>
58     #include <dt-bindings/clock/qcom,gcc-sc8280xp.h>
59     #include <dt-bindings/interrupt-controller/arm-gic.h>
60     #include <dt-bindings/interconnect/qcom,sc8280xp.h>
61     #include <dt-bindings/power/qcom-rpmpd.h>
62
63     display-subsystem@ae00000 {
64         compatible = "qcom,sc8280xp-mdss";
65         reg = <0x0ae00000 0x1000>;
66         reg-names = "mdss";
67
68         power-domains = <&dispcc0 MDSS_GDSC>;
69
70         clocks = <&gcc GCC_DISP_AHB_CLK>,
71                  <&dispcc0 DISP_CC_MDSS_AHB_CLK>,
72                  <&dispcc0 DISP_CC_MDSS_MDP_CLK>;
73         clock-names = "iface",
74                       "ahb",
75                       "core";
76
77         resets = <&dispcc0 DISP_CC_MDSS_CORE_BCR>;
78
79         interrupts = <GIC_SPI 83 IRQ_TYPE_LEVEL_HIGH>;
80         interrupt-controller;
81         #interrupt-cells = <1>;
82
83         interconnects = <&mmss_noc MASTER_MDP0 0 &mc_virt SLAVE_EBI1 0>,
84                         <&mmss_noc MASTER_MDP1 0 &mc_virt SLAVE_EBI1 0>;
85         interconnect-names = "mdp0-mem", "mdp1-mem";
86
87         iommus = <&apps_smmu 0x1000 0x402>;
88
89         #address-cells = <1>;
90         #size-cells = <1>;
91         ranges;
92
93         display-controller@ae01000 {
94             compatible = "qcom,sc8280xp-dpu";
95             reg = <0x0ae01000 0x8f000>,
96             <0x0aeb0000 0x2008>;
97             reg-names = "mdp", "vbif";
98
99             clocks = <&gcc GCC_DISP_HF_AXI_CLK>,
100                      <&gcc GCC_DISP_SF_AXI_CLK>,
101                      <&dispcc0 DISP_CC_MDSS_AHB_CLK>,
102                      <&dispcc0 DISP_CC_MDSS_MDP_LUT_CLK>,
103                      <&dispcc0 DISP_CC_MDSS_MDP_CLK>,
104                      <&dispcc0 DISP_CC_MDSS_VSYNC_CLK>;
105             clock-names = "bus",
106                           "nrt_bus",
107                           "iface",
108                           "lut",
109                           "core",
110                           "vsync";
111
112             assigned-clocks = <&dispcc0 DISP_CC_MDSS_VSYNC_CLK>;
113             assigned-clock-rates = <19200000>;
114
115             operating-points-v2 = <&mdss0_mdp_opp_table>;
116             power-domains = <&rpmhpd SC8280XP_MMCX>;
117
118             interrupt-parent = <&mdss0>;
119             interrupts = <0>;
120
121             ports {
122                 #address-cells = <1>;
123                 #size-cells = <0>;
124
125                 port@0 {
126                     reg = <0>;
127                     endpoint {
128                         remote-endpoint = <&mdss0_dp0_in>;
129                     };
130                 };
131
132                 port@4 {
133                     reg = <4>;
134                     endpoint {
135                         remote-endpoint = <&mdss0_dp1_in>;
136                     };
137                 };
138
139                 port@5 {
140                     reg = <5>;
141                     endpoint {
142                         remote-endpoint = <&mdss0_dp3_in>;
143                     };
144                 };
145
146                 port@6 {
147                     reg = <6>;
148                     endpoint {
149                         remote-endpoint = <&mdss0_dp2_in>;
150                     };
151                 };
152             };
153         };
154     };
155 ...