qcom,mdss.yaml 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226
  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,mdss.yaml#
  5. $schema: http://devicetree.org/meta-schemas/core.yaml#
  6. title: Qualcomm Mobile Display SubSystem (MDSS)
  7. maintainers:
  8. - Dmitry Baryshkov <dmitry.baryshkov@linaro.org>
  9. - Rob Clark <robdclark@gmail.com>
  10. description:
  11. This is the bindings documentation for the Mobile Display Subsystem(MDSS) that
  12. encapsulates sub-blocks like MDP5, DSI, HDMI, eDP, etc.
  13. properties:
  14. $nodename:
  15. pattern: "^display-subsystem@[0-9a-f]+$"
  16. compatible:
  17. enum:
  18. - qcom,mdss
  19. reg:
  20. minItems: 2
  21. maxItems: 3
  22. reg-names:
  23. minItems: 2
  24. items:
  25. - const: mdss_phys
  26. - const: vbif_phys
  27. - const: vbif_nrt_phys
  28. interrupts:
  29. maxItems: 1
  30. interrupt-controller: true
  31. "#interrupt-cells":
  32. const: 1
  33. power-domains:
  34. maxItems: 1
  35. description: |
  36. The MDSS power domain provided by GCC
  37. clocks:
  38. oneOf:
  39. - minItems: 3
  40. items:
  41. - description: Display abh clock
  42. - description: Display axi clock
  43. - description: Display vsync clock
  44. - description: Display core clock
  45. - minItems: 1
  46. items:
  47. - description: Display abh clock
  48. - description: Display core clock
  49. clock-names:
  50. oneOf:
  51. - minItems: 3
  52. items:
  53. - const: iface
  54. - const: bus
  55. - const: vsync
  56. - const: core
  57. - minItems: 1
  58. items:
  59. - const: iface
  60. - const: core
  61. "#address-cells":
  62. const: 1
  63. "#size-cells":
  64. const: 1
  65. ranges: true
  66. resets:
  67. items:
  68. - description: MDSS_CORE reset
  69. interconnects:
  70. minItems: 1
  71. items:
  72. - description: Interconnect path from mdp0 (or a single mdp) port to the data bus
  73. - description: Interconnect path from CPU to the reg bus
  74. interconnect-names:
  75. minItems: 1
  76. items:
  77. - const: mdp0-mem
  78. - const: cpu-cfg
  79. required:
  80. - compatible
  81. - reg
  82. - reg-names
  83. - interrupts
  84. - interrupt-controller
  85. - "#interrupt-cells"
  86. - power-domains
  87. - clocks
  88. - clock-names
  89. - "#address-cells"
  90. - "#size-cells"
  91. - ranges
  92. patternProperties:
  93. "^display-controller@[1-9a-f][0-9a-f]*$":
  94. type: object
  95. additionalProperties: true
  96. properties:
  97. compatible:
  98. contains:
  99. const: qcom,mdp5
  100. "^dsi@[1-9a-f][0-9a-f]*$":
  101. type: object
  102. additionalProperties: true
  103. properties:
  104. compatible:
  105. contains:
  106. const: qcom,mdss-dsi-ctrl
  107. "^phy@[1-9a-f][0-9a-f]*$":
  108. type: object
  109. additionalProperties: true
  110. properties:
  111. compatible:
  112. enum:
  113. - qcom,dsi-phy-14nm
  114. - qcom,dsi-phy-14nm-660
  115. - qcom,dsi-phy-14nm-8953
  116. - qcom,dsi-phy-20nm
  117. - qcom,dsi-phy-28nm-8226
  118. - qcom,dsi-phy-28nm-8937
  119. - qcom,dsi-phy-28nm-hpm
  120. - qcom,dsi-phy-28nm-hpm-fam-b
  121. - qcom,dsi-phy-28nm-lp
  122. - qcom,hdmi-phy-8084
  123. - qcom,hdmi-phy-8660
  124. - qcom,hdmi-phy-8960
  125. - qcom,hdmi-phy-8974
  126. - qcom,hdmi-phy-8996
  127. "^hdmi-tx@[1-9a-f][0-9a-f]*$":
  128. type: object
  129. additionalProperties: true
  130. properties:
  131. compatible:
  132. enum:
  133. - qcom,hdmi-tx-8084
  134. - qcom,hdmi-tx-8660
  135. - qcom,hdmi-tx-8960
  136. - qcom,hdmi-tx-8974
  137. - qcom,hdmi-tx-8994
  138. - qcom,hdmi-tx-8996
  139. additionalProperties: false
  140. examples:
  141. - |
  142. #include <dt-bindings/clock/qcom,gcc-msm8916.h>
  143. #include <dt-bindings/interrupt-controller/arm-gic.h>
  144. display-subsystem@1a00000 {
  145. compatible = "qcom,mdss";
  146. reg = <0x1a00000 0x1000>,
  147. <0x1ac8000 0x3000>;
  148. reg-names = "mdss_phys", "vbif_phys";
  149. power-domains = <&gcc MDSS_GDSC>;
  150. clocks = <&gcc GCC_MDSS_AHB_CLK>,
  151. <&gcc GCC_MDSS_AXI_CLK>,
  152. <&gcc GCC_MDSS_VSYNC_CLK>;
  153. clock-names = "iface",
  154. "bus",
  155. "vsync";
  156. interrupts = <GIC_SPI 72 IRQ_TYPE_LEVEL_HIGH>;
  157. interrupt-controller;
  158. #interrupt-cells = <1>;
  159. #address-cells = <1>;
  160. #size-cells = <1>;
  161. ranges;
  162. display-controller@1a01000 {
  163. compatible = "qcom,msm8916-mdp5", "qcom,mdp5";
  164. reg = <0x01a01000 0x89000>;
  165. reg-names = "mdp_phys";
  166. interrupt-parent = <&mdss>;
  167. interrupts = <0>;
  168. clocks = <&gcc GCC_MDSS_AHB_CLK>,
  169. <&gcc GCC_MDSS_AXI_CLK>,
  170. <&gcc GCC_MDSS_MDP_CLK>,
  171. <&gcc GCC_MDSS_VSYNC_CLK>;
  172. clock-names = "iface",
  173. "bus",
  174. "core",
  175. "vsync";
  176. iommus = <&apps_iommu 4>;
  177. ports {
  178. #address-cells = <1>;
  179. #size-cells = <0>;
  180. port@0 {
  181. reg = <0>;
  182. mdp5_intf1_out: endpoint {
  183. remote-endpoint = <&dsi0_in>;
  184. };
  185. };
  186. };
  187. };
  188. };
  189. ...