summaryrefslogtreecommitdiffstats
path: root/Documentation/devicetree/bindings/display/mediatek/mediatek,ethdr.yaml
blob: 131eed5eeeb7c7648869d93741b49e1d2081b518 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
%YAML 1.2
---
$id: http://devicetree.org/schemas/display/mediatek/mediatek,ethdr.yaml#
$schema: http://devicetree.org/meta-schemas/core.yaml#

title: Mediatek Ethdr Device Tree Bindings

maintainers:
  - Chun-Kuang Hu <chunkuang.hu@kernel.org>
  - Philipp Zabel <p.zabel@pengutronix.de>

description: |
  ETHDR is designed for HDR video and graphics conversion in the external display path.
  It handles multiple HDR input types and performs tone mapping, color space/color
  format conversion, and then combine different layers, output the required HDR or
  SDR signal to the subsequent display path. This engine is composed of two video
  frontends, two graphic frontends, one video backend and a mixer. ETHDR has two
  DMA function blocks, DS and ADL. These two function blocks read the pre-programmed
  registers from DRAM and set them to HW in the v-blanking period.

properties:
  compatible:
    items:
      - const: mediatek,mt8195-disp-ethdr
  reg:
    maxItems: 7
  reg-names:
    items:
      - const: mixer
      - const: vdo_fe0
      - const: vdo_fe1
      - const: gfx_fe0
      - const: gfx_fe1
      - const: vdo_be
      - const: adl_ds
  interrupts:
    minItems: 1
  iommus:
    description: The compatible property is DMA function blocks.
      Should point to the respective IOMMU block with master port as argument,
      see Documentation/devicetree/bindings/iommu/mediatek,iommu.yaml for
      details.
    minItems: 1
    maxItems: 2
  clocks:
    items:
      - description: mixer clock
      - description: video frontend 0 clock
      - description: video frontend 1 clock
      - description: graphic frontend 0 clock
      - description: graphic frontend 1 clock
      - description: video backend clock
      - description: autodownload and menuload clock
      - description: video frontend 0 async clock
      - description: video frontend 1 async clock
      - description: graphic frontend 0 async clock
      - description: graphic frontend 1 async clock
      - description: video backend async clock
      - description: ethdr top clock
  clock-names:
    items:
      - const: mixer
      - const: vdo_fe0
      - const: vdo_fe1
      - const: gfx_fe0
      - const: gfx_fe1
      - const: vdo_be
      - const: adl_ds
      - const: vdo_fe0_async
      - const: vdo_fe1_async
      - const: gfx_fe0_async
      - const: gfx_fe1_async
      - const: vdo_be_async
      - const: ethdr_top
  power-domains:
    maxItems: 1
  resets:
    maxItems: 5
  mediatek,gce-client-reg:
    $ref: /schemas/types.yaml#/definitions/phandle-array
    description: The register of display function block to be set by gce.
      There are 4 arguments in this property, gce node, subsys id, offset and
      register size. The subsys id is defined in the gce header of each chips
      include/include/dt-bindings/gce/<chip>-gce.h, mapping to the register of
      display function block.

required:
  - compatible
  - reg
  - clocks
  - clock-names
  - interrupts
  - power-domains

additionalProperties: false

examples:
  - |

    disp_ethdr@1c114000 {
            compatible = "mediatek,mt8195-disp-ethdr";
            reg = <0 0x1c114000 0 0x1000>,
                  <0 0x1c115000 0 0x1000>,
                  <0 0x1c117000 0 0x1000>,
                  <0 0x1c119000 0 0x1000>,
                  <0 0x1c11A000 0 0x1000>,
                  <0 0x1c11B000 0 0x1000>,
                  <0 0x1c11C000 0 0x1000>;
            reg-names = "mixer", "vdo_fe0", "vdo_fe1", "gfx_fe0", "gfx_fe1",
                        "vdo_be", "adl_ds";
            mediatek,gce-client-reg = <&gce0 SUBSYS_1c11XXXX 0x4000 0x1000>,
                                      <&gce0 SUBSYS_1c11XXXX 0x5000 0x1000>,
                                      <&gce0 SUBSYS_1c11XXXX 0x7000 0x1000>,
                                      <&gce0 SUBSYS_1c11XXXX 0x9000 0x1000>,
                                      <&gce0 SUBSYS_1c11XXXX 0xA000 0x1000>,
                                      <&gce0 SUBSYS_1c11XXXX 0xB000 0x1000>,
                                      <&gce0 SUBSYS_1c11XXXX 0xC000 0x1000>;
            clocks = <&vdosys1 CLK_VDO1_DISP_MIXER>,
                     <&vdosys1 CLK_VDO1_HDR_VDO_FE0>,
                     <&vdosys1 CLK_VDO1_HDR_VDO_FE1>,
                     <&vdosys1 CLK_VDO1_HDR_GFX_FE0>,
                     <&vdosys1 CLK_VDO1_HDR_GFX_FE1>,
                     <&vdosys1 CLK_VDO1_HDR_VDO_BE>,
                     <&vdosys1 CLK_VDO1_26M_SLOW>,
                     <&vdosys1 CLK_VDO1_HDR_VDO_FE0_DL_ASYNC>,
                     <&vdosys1 CLK_VDO1_HDR_VDO_FE1_DL_ASYNC>,
                     <&vdosys1 CLK_VDO1_HDR_GFX_FE0_DL_ASYNC>,
                     <&vdosys1 CLK_VDO1_HDR_GFX_FE1_DL_ASYNC>,
                     <&vdosys1 CLK_VDO1_HDR_VDO_BE_DL_ASYNC>,
                     <&topckgen CLK_TOP_ETHDR_SEL>;
            clock-names = "mixer", "vdo_fe0", "vdo_fe1", "gfx_fe0", "gfx_fe1",
                          "vdo_be", "adl_ds", "vdo_fe0_async", "vdo_fe1_async",
                          "gfx_fe0_async", "gfx_fe1_async","vdo_be_async",
                          "ethdr_top";
            power-domains = <&spm MT8195_POWER_DOMAIN_VDOSYS1>;
            iommus = <&iommu_vpp M4U_PORT_L3_HDR_DS>,
                     <&iommu_vpp M4U_PORT_L3_HDR_ADL>;
            interrupts = <GIC_SPI 517 IRQ_TYPE_LEVEL_HIGH 0>; /* disp mixer */
            resets = <&vdosys1 MT8195_VDOSYS1_SW1_RST_B_HDR_VDO_FE0_DL_ASYNC>,
                     <&vdosys1 MT8195_VDOSYS1_SW1_RST_B_HDR_VDO_FE1_DL_ASYNC>,
                     <&vdosys1 MT8195_VDOSYS1_SW1_RST_B_HDR_GFX_FE0_DL_ASYNC>,
                     <&vdosys1 MT8195_VDOSYS1_SW1_RST_B_HDR_GFX_FE1_DL_ASYNC>,
                     <&vdosys1 MT8195_VDOSYS1_SW1_RST_B_HDR_VDO_BE_DL_ASYNC>;
    };

...