~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/Documentation/devicetree/bindings/display/mediatek/mediatek,ethdr.yaml

Version: ~ [ linux-6.12-rc7 ] ~ [ linux-6.11.7 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.60 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.116 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.171 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.229 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.285 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.323 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.12 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

  1 # SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
  2 %YAML 1.2
  3 ---
  4 $id: http://devicetree.org/schemas/display/mediatek/mediatek,ethdr.yaml#
  5 $schema: http://devicetree.org/meta-schemas/core.yaml#
  6 
  7 title: MediaTek Ethdr Device
  8 
  9 maintainers:
 10   - Chun-Kuang Hu <chunkuang.hu@kernel.org>
 11   - Philipp Zabel <p.zabel@pengutronix.de>
 12 
 13 description:
 14   ETHDR (ET High Dynamic Range) is a MediaTek internal HDR engine and is
 15   designed for HDR video and graphics conversion in the external display path.
 16   It handles multiple HDR input types and performs tone mapping, color
 17   space/color format conversion, and then combine different layers,
 18   output the required HDR or SDR signal to the subsequent display path.
 19   This engine is composed of two video frontends, two graphic frontends,
 20   one video backend and a mixer. ETHDR has two DMA function blocks, DS and ADL.
 21   These two function blocks read the pre-programmed registers from DRAM and
 22   set them to HW in the v-blanking period.
 23 
 24 properties:
 25   compatible:
 26     oneOf:
 27       - const: mediatek,mt8195-disp-ethdr
 28       - items:
 29           - const: mediatek,mt8188-disp-ethdr
 30           - const: mediatek,mt8195-disp-ethdr
 31 
 32   reg:
 33     maxItems: 7
 34 
 35   reg-names:
 36     items:
 37       - const: mixer
 38       - const: vdo_fe0
 39       - const: vdo_fe1
 40       - const: gfx_fe0
 41       - const: gfx_fe1
 42       - const: vdo_be
 43       - const: adl_ds
 44 
 45   interrupts:
 46     maxItems: 1
 47 
 48   iommus:
 49     minItems: 1
 50     maxItems: 2
 51 
 52   clocks:
 53     items:
 54       - description: mixer clock
 55       - description: video frontend 0 clock
 56       - description: video frontend 1 clock
 57       - description: graphic frontend 0 clock
 58       - description: graphic frontend 1 clock
 59       - description: video backend clock
 60       - description: autodownload and menuload clock
 61       - description: video frontend 0 async clock
 62       - description: video frontend 1 async clock
 63       - description: graphic frontend 0 async clock
 64       - description: graphic frontend 1 async clock
 65       - description: video backend async clock
 66       - description: ethdr top clock
 67 
 68   clock-names:
 69     items:
 70       - const: mixer
 71       - const: vdo_fe0
 72       - const: vdo_fe1
 73       - const: gfx_fe0
 74       - const: gfx_fe1
 75       - const: vdo_be
 76       - const: adl_ds
 77       - const: vdo_fe0_async
 78       - const: vdo_fe1_async
 79       - const: gfx_fe0_async
 80       - const: gfx_fe1_async
 81       - const: vdo_be_async
 82       - const: ethdr_top
 83 
 84   power-domains:
 85     maxItems: 1
 86 
 87   resets:
 88     items:
 89       - description: video frontend 0 async reset
 90       - description: video frontend 1 async reset
 91       - description: graphic frontend 0 async reset
 92       - description: graphic frontend 1 async reset
 93       - description: video backend async reset
 94 
 95   reset-names:
 96     items:
 97       - const: vdo_fe0_async
 98       - const: vdo_fe1_async
 99       - const: gfx_fe0_async
100       - const: gfx_fe1_async
101       - const: vdo_be_async
102 
103   mediatek,gce-client-reg:
104     $ref: /schemas/types.yaml#/definitions/phandle-array
105     minItems: 1
106     maxItems: 7
107     description: The register of display function block to be set by gce.
108       There are 4 arguments in this property, gce node, subsys id, offset and
109       register size. The subsys id is defined in the gce header of each chips
110       include/dt-bindings/gce/<chip>-gce.h, mapping to the register of display
111       function block.
112 
113 required:
114   - compatible
115   - reg
116   - clocks
117   - clock-names
118   - interrupts
119   - power-domains
120   - resets
121   - mediatek,gce-client-reg
122 
123 additionalProperties: false
124 
125 examples:
126   - |
127     #include <dt-bindings/interrupt-controller/arm-gic.h>
128     #include <dt-bindings/clock/mt8195-clk.h>
129     #include <dt-bindings/gce/mt8195-gce.h>
130     #include <dt-bindings/memory/mt8195-memory-port.h>
131     #include <dt-bindings/power/mt8195-power.h>
132     #include <dt-bindings/reset/mt8195-resets.h>
133 
134     soc {
135         #address-cells = <2>;
136         #size-cells = <2>;
137 
138         hdr-engine@1c114000 {
139                 compatible = "mediatek,mt8195-disp-ethdr";
140                 reg = <0 0x1c114000 0 0x1000>,
141                       <0 0x1c115000 0 0x1000>,
142                       <0 0x1c117000 0 0x1000>,
143                       <0 0x1c119000 0 0x1000>,
144                       <0 0x1c11a000 0 0x1000>,
145                       <0 0x1c11b000 0 0x1000>,
146                       <0 0x1c11c000 0 0x1000>;
147                 reg-names = "mixer", "vdo_fe0", "vdo_fe1", "gfx_fe0", "gfx_fe1",
148                             "vdo_be", "adl_ds";
149                 mediatek,gce-client-reg = <&gce0 SUBSYS_1c11XXXX 0x4000 0x1000>,
150                                           <&gce0 SUBSYS_1c11XXXX 0x5000 0x1000>,
151                                           <&gce0 SUBSYS_1c11XXXX 0x7000 0x1000>,
152                                           <&gce0 SUBSYS_1c11XXXX 0x9000 0x1000>,
153                                           <&gce0 SUBSYS_1c11XXXX 0xa000 0x1000>,
154                                           <&gce0 SUBSYS_1c11XXXX 0xb000 0x1000>,
155                                           <&gce0 SUBSYS_1c11XXXX 0xc000 0x1000>;
156                 clocks = <&vdosys1 CLK_VDO1_DISP_MIXER>,
157                          <&vdosys1 CLK_VDO1_HDR_VDO_FE0>,
158                          <&vdosys1 CLK_VDO1_HDR_VDO_FE1>,
159                          <&vdosys1 CLK_VDO1_HDR_GFX_FE0>,
160                          <&vdosys1 CLK_VDO1_HDR_GFX_FE1>,
161                          <&vdosys1 CLK_VDO1_HDR_VDO_BE>,
162                          <&vdosys1 CLK_VDO1_26M_SLOW>,
163                          <&vdosys1 CLK_VDO1_HDR_VDO_FE0_DL_ASYNC>,
164                          <&vdosys1 CLK_VDO1_HDR_VDO_FE1_DL_ASYNC>,
165                          <&vdosys1 CLK_VDO1_HDR_GFX_FE0_DL_ASYNC>,
166                          <&vdosys1 CLK_VDO1_HDR_GFX_FE1_DL_ASYNC>,
167                          <&vdosys1 CLK_VDO1_HDR_VDO_BE_DL_ASYNC>,
168                          <&topckgen CLK_TOP_ETHDR>;
169                 clock-names = "mixer", "vdo_fe0", "vdo_fe1", "gfx_fe0", "gfx_fe1",
170                               "vdo_be", "adl_ds", "vdo_fe0_async", "vdo_fe1_async",
171                               "gfx_fe0_async", "gfx_fe1_async","vdo_be_async",
172                               "ethdr_top";
173                 power-domains = <&spm MT8195_POWER_DOMAIN_VDOSYS1>;
174                 iommus = <&iommu_vpp M4U_PORT_L3_HDR_DS>,
175                          <&iommu_vpp M4U_PORT_L3_HDR_ADL>;
176                 interrupts = <GIC_SPI 517 IRQ_TYPE_LEVEL_HIGH 0>; /* disp mixer */
177                 resets = <&vdosys1 MT8195_VDOSYS1_SW1_RST_B_HDR_VDO_FE0_DL_ASYNC>,
178                          <&vdosys1 MT8195_VDOSYS1_SW1_RST_B_HDR_VDO_FE1_DL_ASYNC>,
179                          <&vdosys1 MT8195_VDOSYS1_SW1_RST_B_HDR_GFX_FE0_DL_ASYNC>,
180                          <&vdosys1 MT8195_VDOSYS1_SW1_RST_B_HDR_GFX_FE1_DL_ASYNC>,
181                          <&vdosys1 MT8195_VDOSYS1_SW1_RST_B_HDR_VDO_BE_DL_ASYNC>;
182                 reset-names = "vdo_fe0_async", "vdo_fe1_async", "gfx_fe0_async",
183                               "gfx_fe1_async", "vdo_be_async";
184         };
185     };
186 ...

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php