mediatek,disp.txt 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203
  1. Mediatek display subsystem
  2. ==========================
  3. The Mediatek display subsystem consists of various DISP function blocks in the
  4. MMSYS register space. The connections between them can be configured by output
  5. and input selectors in the MMSYS_CONFIG register space. Pixel clock and start
  6. of frame signal are distributed to the other function blocks by a DISP_MUTEX
  7. function block.
  8. All DISP device tree nodes must be siblings to the central MMSYS_CONFIG node.
  9. For a description of the MMSYS_CONFIG binding, see
  10. Documentation/devicetree/bindings/arm/mediatek/mediatek,mmsys.txt.
  11. DISP function blocks
  12. ====================
  13. A display stream starts at a source function block that reads pixel data from
  14. memory and ends with a sink function block that drives pixels on a display
  15. interface, or writes pixels back to memory. All DISP function blocks have
  16. their own register space, interrupt, and clock gate. The blocks that can
  17. access memory additionally have to list the IOMMU and local arbiter they are
  18. connected to.
  19. For a description of the display interface sink function blocks, see
  20. Documentation/devicetree/bindings/display/mediatek/mediatek,dsi.txt and
  21. Documentation/devicetree/bindings/display/mediatek/mediatek,dpi.txt.
  22. Required properties (all function blocks):
  23. - compatible: "mediatek,<chip>-disp-<function>", one of
  24. "mediatek,<chip>-disp-ovl" - overlay (4 layers, blending, csc)
  25. "mediatek,<chip>-disp-rdma" - read DMA / line buffer
  26. "mediatek,<chip>-disp-wdma" - write DMA
  27. "mediatek,<chip>-disp-color" - color processor
  28. "mediatek,<chip>-disp-aal" - adaptive ambient light controller
  29. "mediatek,<chip>-disp-gamma" - gamma correction
  30. "mediatek,<chip>-disp-merge" - merge streams from two RDMA sources
  31. "mediatek,<chip>-disp-split" - split stream to two encoders
  32. "mediatek,<chip>-disp-ufoe" - data compression engine
  33. "mediatek,<chip>-dsi" - DSI controller, see mediatek,dsi.txt
  34. "mediatek,<chip>-dpi" - DPI controller, see mediatek,dpi.txt
  35. "mediatek,<chip>-disp-mutex" - display mutex
  36. "mediatek,<chip>-disp-od" - overdrive
  37. - reg: Physical base address and length of the function block register space
  38. - interrupts: The interrupt signal from the function block (required, except for
  39. merge and split function blocks).
  40. - clocks: device clocks
  41. See Documentation/devicetree/bindings/clock/clock-bindings.txt for details.
  42. For most function blocks this is just a single clock input. Only the DSI and
  43. DPI controller nodes have multiple clock inputs. These are documented in
  44. mediatek,dsi.txt and mediatek,dpi.txt, respectively.
  45. Required properties (DMA function blocks):
  46. - compatible: Should be one of
  47. "mediatek,<chip>-disp-ovl"
  48. "mediatek,<chip>-disp-rdma"
  49. "mediatek,<chip>-disp-wdma"
  50. - larb: Should contain a phandle pointing to the local arbiter device as defined
  51. in Documentation/devicetree/bindings/soc/mediatek/mediatek,smi-larb.txt
  52. - iommus: Should point to the respective IOMMU block with master port as
  53. argument, see Documentation/devicetree/bindings/iommu/mediatek,iommu.txt
  54. for details.
  55. Examples:
  56. mmsys: clock-controller@14000000 {
  57. compatible = "mediatek,mt8173-mmsys", "syscon";
  58. reg = <0 0x14000000 0 0x1000>;
  59. power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
  60. #clock-cells = <1>;
  61. };
  62. ovl0: ovl@1400c000 {
  63. compatible = "mediatek,mt8173-disp-ovl";
  64. reg = <0 0x1400c000 0 0x1000>;
  65. interrupts = <GIC_SPI 180 IRQ_TYPE_LEVEL_LOW>;
  66. power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
  67. clocks = <&mmsys CLK_MM_DISP_OVL0>;
  68. iommus = <&iommu M4U_PORT_DISP_OVL0>;
  69. mediatek,larb = <&larb0>;
  70. };
  71. ovl1: ovl@1400d000 {
  72. compatible = "mediatek,mt8173-disp-ovl";
  73. reg = <0 0x1400d000 0 0x1000>;
  74. interrupts = <GIC_SPI 181 IRQ_TYPE_LEVEL_LOW>;
  75. power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
  76. clocks = <&mmsys CLK_MM_DISP_OVL1>;
  77. iommus = <&iommu M4U_PORT_DISP_OVL1>;
  78. mediatek,larb = <&larb4>;
  79. };
  80. rdma0: rdma@1400e000 {
  81. compatible = "mediatek,mt8173-disp-rdma";
  82. reg = <0 0x1400e000 0 0x1000>;
  83. interrupts = <GIC_SPI 182 IRQ_TYPE_LEVEL_LOW>;
  84. power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
  85. clocks = <&mmsys CLK_MM_DISP_RDMA0>;
  86. iommus = <&iommu M4U_PORT_DISP_RDMA0>;
  87. mediatek,larb = <&larb0>;
  88. };
  89. rdma1: rdma@1400f000 {
  90. compatible = "mediatek,mt8173-disp-rdma";
  91. reg = <0 0x1400f000 0 0x1000>;
  92. interrupts = <GIC_SPI 183 IRQ_TYPE_LEVEL_LOW>;
  93. power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
  94. clocks = <&mmsys CLK_MM_DISP_RDMA1>;
  95. iommus = <&iommu M4U_PORT_DISP_RDMA1>;
  96. mediatek,larb = <&larb4>;
  97. };
  98. rdma2: rdma@14010000 {
  99. compatible = "mediatek,mt8173-disp-rdma";
  100. reg = <0 0x14010000 0 0x1000>;
  101. interrupts = <GIC_SPI 184 IRQ_TYPE_LEVEL_LOW>;
  102. power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
  103. clocks = <&mmsys CLK_MM_DISP_RDMA2>;
  104. iommus = <&iommu M4U_PORT_DISP_RDMA2>;
  105. mediatek,larb = <&larb4>;
  106. };
  107. wdma0: wdma@14011000 {
  108. compatible = "mediatek,mt8173-disp-wdma";
  109. reg = <0 0x14011000 0 0x1000>;
  110. interrupts = <GIC_SPI 185 IRQ_TYPE_LEVEL_LOW>;
  111. power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
  112. clocks = <&mmsys CLK_MM_DISP_WDMA0>;
  113. iommus = <&iommu M4U_PORT_DISP_WDMA0>;
  114. mediatek,larb = <&larb0>;
  115. };
  116. wdma1: wdma@14012000 {
  117. compatible = "mediatek,mt8173-disp-wdma";
  118. reg = <0 0x14012000 0 0x1000>;
  119. interrupts = <GIC_SPI 186 IRQ_TYPE_LEVEL_LOW>;
  120. power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
  121. clocks = <&mmsys CLK_MM_DISP_WDMA1>;
  122. iommus = <&iommu M4U_PORT_DISP_WDMA1>;
  123. mediatek,larb = <&larb4>;
  124. };
  125. color0: color@14013000 {
  126. compatible = "mediatek,mt8173-disp-color";
  127. reg = <0 0x14013000 0 0x1000>;
  128. interrupts = <GIC_SPI 187 IRQ_TYPE_LEVEL_LOW>;
  129. power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
  130. clocks = <&mmsys CLK_MM_DISP_COLOR0>;
  131. };
  132. color1: color@14014000 {
  133. compatible = "mediatek,mt8173-disp-color";
  134. reg = <0 0x14014000 0 0x1000>;
  135. interrupts = <GIC_SPI 188 IRQ_TYPE_LEVEL_LOW>;
  136. power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
  137. clocks = <&mmsys CLK_MM_DISP_COLOR1>;
  138. };
  139. aal@14015000 {
  140. compatible = "mediatek,mt8173-disp-aal";
  141. reg = <0 0x14015000 0 0x1000>;
  142. interrupts = <GIC_SPI 189 IRQ_TYPE_LEVEL_LOW>;
  143. power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
  144. clocks = <&mmsys CLK_MM_DISP_AAL>;
  145. };
  146. gamma@14016000 {
  147. compatible = "mediatek,mt8173-disp-gamma";
  148. reg = <0 0x14016000 0 0x1000>;
  149. interrupts = <GIC_SPI 190 IRQ_TYPE_LEVEL_LOW>;
  150. power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
  151. clocks = <&mmsys CLK_MM_DISP_GAMMA>;
  152. };
  153. ufoe@1401a000 {
  154. compatible = "mediatek,mt8173-disp-ufoe";
  155. reg = <0 0x1401a000 0 0x1000>;
  156. interrupts = <GIC_SPI 191 IRQ_TYPE_LEVEL_LOW>;
  157. power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
  158. clocks = <&mmsys CLK_MM_DISP_UFOE>;
  159. };
  160. dsi0: dsi@1401b000 {
  161. /* See mediatek,dsi.txt for details */
  162. };
  163. dpi0: dpi@1401d000 {
  164. /* See mediatek,dpi.txt for details */
  165. };
  166. mutex: mutex@14020000 {
  167. compatible = "mediatek,mt8173-disp-mutex";
  168. reg = <0 0x14020000 0 0x1000>;
  169. interrupts = <GIC_SPI 169 IRQ_TYPE_LEVEL_LOW>;
  170. power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
  171. clocks = <&mmsys CLK_MM_MUTEX_32K>;
  172. };
  173. od@14023000 {
  174. compatible = "mediatek,mt8173-disp-od";
  175. reg = <0 0x14023000 0 0x1000>;
  176. power-domains = <&scpsys MT8173_POWER_DOMAIN_MM>;
  177. clocks = <&mmsys CLK_MM_DISP_OD>;
  178. };