162306a36Sopenharmony_ci# SPDX-License-Identifier: GPL-2.0-only
262306a36Sopenharmony_ci%YAML 1.2
362306a36Sopenharmony_ci---
462306a36Sopenharmony_ci$id: http://devicetree.org/schemas/display/samsung/samsung,exynos-hdmi.yaml#
562306a36Sopenharmony_ci$schema: http://devicetree.org/meta-schemas/core.yaml#
662306a36Sopenharmony_ci
762306a36Sopenharmony_cititle: Samsung Exynos SoC HDMI
862306a36Sopenharmony_ci
962306a36Sopenharmony_cimaintainers:
1062306a36Sopenharmony_ci  - Inki Dae <inki.dae@samsung.com>
1162306a36Sopenharmony_ci  - Seung-Woo Kim <sw0312.kim@samsung.com>
1262306a36Sopenharmony_ci  - Kyungmin Park <kyungmin.park@samsung.com>
1362306a36Sopenharmony_ci  - Krzysztof Kozlowski <krzk@kernel.org>
1462306a36Sopenharmony_ci
1562306a36Sopenharmony_ciproperties:
1662306a36Sopenharmony_ci  compatible:
1762306a36Sopenharmony_ci    enum:
1862306a36Sopenharmony_ci      - samsung,exynos4210-hdmi
1962306a36Sopenharmony_ci      - samsung,exynos4212-hdmi
2062306a36Sopenharmony_ci      - samsung,exynos5420-hdmi
2162306a36Sopenharmony_ci      - samsung,exynos5433-hdmi
2262306a36Sopenharmony_ci
2362306a36Sopenharmony_ci  clocks:
2462306a36Sopenharmony_ci    minItems: 5
2562306a36Sopenharmony_ci    maxItems: 10
2662306a36Sopenharmony_ci
2762306a36Sopenharmony_ci  clock-names:
2862306a36Sopenharmony_ci    minItems: 5
2962306a36Sopenharmony_ci    maxItems: 10
3062306a36Sopenharmony_ci
3162306a36Sopenharmony_ci  ddc:
3262306a36Sopenharmony_ci    $ref: /schemas/types.yaml#/definitions/phandle
3362306a36Sopenharmony_ci    description:
3462306a36Sopenharmony_ci      Phandle to the HDMI DDC node.
3562306a36Sopenharmony_ci
3662306a36Sopenharmony_ci  hdmi-en-supply:
3762306a36Sopenharmony_ci    description:
3862306a36Sopenharmony_ci      Provides voltage source for DCC lines available on HDMI connector. When
3962306a36Sopenharmony_ci      there is no power provided for DDC epprom, some TV-sets do not pulls up
4062306a36Sopenharmony_ci      HPD (hot plug detect) line, what causes HDMI block to stay turned off.
4162306a36Sopenharmony_ci      When provided, the regulator allows TV-set correctly signal HPD event.
4262306a36Sopenharmony_ci
4362306a36Sopenharmony_ci  hpd-gpios:
4462306a36Sopenharmony_ci    maxItems: 1
4562306a36Sopenharmony_ci    description:
4662306a36Sopenharmony_ci      A GPIO line connected to HPD
4762306a36Sopenharmony_ci
4862306a36Sopenharmony_ci  interrupts:
4962306a36Sopenharmony_ci    maxItems: 1
5062306a36Sopenharmony_ci
5162306a36Sopenharmony_ci  phy:
5262306a36Sopenharmony_ci    $ref: /schemas/types.yaml#/definitions/phandle
5362306a36Sopenharmony_ci    description: Phandle to the HDMI PHY node.
5462306a36Sopenharmony_ci
5562306a36Sopenharmony_ci  ports:
5662306a36Sopenharmony_ci    $ref: /schemas/graph.yaml#/properties/ports
5762306a36Sopenharmony_ci    description:
5862306a36Sopenharmony_ci      Contains a port which is connected to mic node.
5962306a36Sopenharmony_ci
6062306a36Sopenharmony_ci  power-domains:
6162306a36Sopenharmony_ci    maxItems: 1
6262306a36Sopenharmony_ci
6362306a36Sopenharmony_ci  reg:
6462306a36Sopenharmony_ci    maxItems: 1
6562306a36Sopenharmony_ci
6662306a36Sopenharmony_ci  samsung,syscon-phandle:
6762306a36Sopenharmony_ci    $ref: /schemas/types.yaml#/definitions/phandle
6862306a36Sopenharmony_ci    description:
6962306a36Sopenharmony_ci      Phandle to the PMU system controller node.
7062306a36Sopenharmony_ci
7162306a36Sopenharmony_ci  samsung,sysreg-phandle:
7262306a36Sopenharmony_ci    $ref: /schemas/types.yaml#/definitions/phandle
7362306a36Sopenharmony_ci    description:
7462306a36Sopenharmony_ci      Phandle to DISP system controller interface.
7562306a36Sopenharmony_ci
7662306a36Sopenharmony_ci  '#sound-dai-cells':
7762306a36Sopenharmony_ci    const: 0
7862306a36Sopenharmony_ci
7962306a36Sopenharmony_ci  vdd-supply:
8062306a36Sopenharmony_ci    description:
8162306a36Sopenharmony_ci      VDD 1.0V HDMI TX.
8262306a36Sopenharmony_ci
8362306a36Sopenharmony_ci  vdd_osc-supply:
8462306a36Sopenharmony_ci    description:
8562306a36Sopenharmony_ci      VDD 1.8V HDMI OSC.
8662306a36Sopenharmony_ci
8762306a36Sopenharmony_ci  vdd_pll-supply:
8862306a36Sopenharmony_ci    description:
8962306a36Sopenharmony_ci      VDD 1.0V HDMI PLL.
9062306a36Sopenharmony_ci
9162306a36Sopenharmony_cirequired:
9262306a36Sopenharmony_ci  - compatible
9362306a36Sopenharmony_ci  - clocks
9462306a36Sopenharmony_ci  - clock-names
9562306a36Sopenharmony_ci  - ddc
9662306a36Sopenharmony_ci  - hpd-gpios
9762306a36Sopenharmony_ci  - interrupts
9862306a36Sopenharmony_ci  - phy
9962306a36Sopenharmony_ci  - reg
10062306a36Sopenharmony_ci  - samsung,syscon-phandle
10162306a36Sopenharmony_ci  - '#sound-dai-cells'
10262306a36Sopenharmony_ci  - vdd-supply
10362306a36Sopenharmony_ci  - vdd_osc-supply
10462306a36Sopenharmony_ci  - vdd_pll-supply
10562306a36Sopenharmony_ci
10662306a36Sopenharmony_ciallOf:
10762306a36Sopenharmony_ci  - if:
10862306a36Sopenharmony_ci      properties:
10962306a36Sopenharmony_ci        compatible:
11062306a36Sopenharmony_ci          contains:
11162306a36Sopenharmony_ci            const: samsung,exynos5433-hdmi
11262306a36Sopenharmony_ci    then:
11362306a36Sopenharmony_ci      properties:
11462306a36Sopenharmony_ci        clocks:
11562306a36Sopenharmony_ci          items:
11662306a36Sopenharmony_ci            - description: Gate of HDMI IP APB bus.
11762306a36Sopenharmony_ci            - description: Gate of HDMI-PHY IP APB bus.
11862306a36Sopenharmony_ci            - description: Gate of HDMI TMDS clock.
11962306a36Sopenharmony_ci            - description: Gate of HDMI pixel clock.
12062306a36Sopenharmony_ci            - description: TMDS clock generated by HDMI-PHY.
12162306a36Sopenharmony_ci            - description: MUX used to switch between oscclk and tmds_clko,
12262306a36Sopenharmony_ci                respectively if HDMI-PHY is off and operational.
12362306a36Sopenharmony_ci            - description: Pixel clock generated by HDMI-PHY.
12462306a36Sopenharmony_ci            - description: MUX used to switch between oscclk and pixel_clko,
12562306a36Sopenharmony_ci                respectively if HDMI-PHY is off and operational.
12662306a36Sopenharmony_ci            - description: Oscillator clock, used as parent of following *_user
12762306a36Sopenharmony_ci                clocks in case HDMI-PHY is not operational.
12862306a36Sopenharmony_ci            - description: Gate of HDMI SPDIF clock.
12962306a36Sopenharmony_ci        clock-names:
13062306a36Sopenharmony_ci          items:
13162306a36Sopenharmony_ci            - const: hdmi_pclk
13262306a36Sopenharmony_ci            - const: hdmi_i_pclk
13362306a36Sopenharmony_ci            - const: i_tmds_clk
13462306a36Sopenharmony_ci            - const: i_pixel_clk
13562306a36Sopenharmony_ci            - const: tmds_clko
13662306a36Sopenharmony_ci            - const: tmds_clko_user
13762306a36Sopenharmony_ci            - const: pixel_clko
13862306a36Sopenharmony_ci            - const: pixel_clko_user
13962306a36Sopenharmony_ci            - const: oscclk
14062306a36Sopenharmony_ci            - const: i_spdif_clk
14162306a36Sopenharmony_ci      required:
14262306a36Sopenharmony_ci        - samsung,sysreg-phandle
14362306a36Sopenharmony_ci    else:
14462306a36Sopenharmony_ci      properties:
14562306a36Sopenharmony_ci        clocks:
14662306a36Sopenharmony_ci          items:
14762306a36Sopenharmony_ci            - description: Gate of HDMI IP bus clock.
14862306a36Sopenharmony_ci            - description: Gate of HDMI special clock.
14962306a36Sopenharmony_ci            - description: Pixel special clock, one of the two possible inputs
15062306a36Sopenharmony_ci                of HDMI clock mux.
15162306a36Sopenharmony_ci            - description: HDMI PHY clock output, one of two possible inputs of
15262306a36Sopenharmony_ci                HDMI clock mux.
15362306a36Sopenharmony_ci            - description: It is required by the driver to switch between the 2
15462306a36Sopenharmony_ci                parents i.e. sclk_pixel and sclk_hdmiphy. If hdmiphy is stable
15562306a36Sopenharmony_ci                after configuration, parent is set to sclk_hdmiphy else
15662306a36Sopenharmony_ci                sclk_pixel.
15762306a36Sopenharmony_ci        clock-names:
15862306a36Sopenharmony_ci          items:
15962306a36Sopenharmony_ci            - const: hdmi
16062306a36Sopenharmony_ci            - const: sclk_hdmi
16162306a36Sopenharmony_ci            - const: sclk_pixel
16262306a36Sopenharmony_ci            - const: sclk_hdmiphy
16362306a36Sopenharmony_ci            - const: mout_hdmi
16462306a36Sopenharmony_ci
16562306a36Sopenharmony_ciadditionalProperties: false
16662306a36Sopenharmony_ci
16762306a36Sopenharmony_ciexamples:
16862306a36Sopenharmony_ci  - |
16962306a36Sopenharmony_ci    #include <dt-bindings/clock/exynos5433.h>
17062306a36Sopenharmony_ci    #include <dt-bindings/gpio/gpio.h>
17162306a36Sopenharmony_ci    #include <dt-bindings/interrupt-controller/arm-gic.h>
17262306a36Sopenharmony_ci
17362306a36Sopenharmony_ci    hdmi@13970000 {
17462306a36Sopenharmony_ci        compatible = "samsung,exynos5433-hdmi";
17562306a36Sopenharmony_ci        reg = <0x13970000 0x70000>;
17662306a36Sopenharmony_ci        interrupts = <GIC_SPI 208 IRQ_TYPE_LEVEL_HIGH>;
17762306a36Sopenharmony_ci        clocks = <&cmu_disp CLK_PCLK_HDMI>,
17862306a36Sopenharmony_ci                 <&cmu_disp CLK_PCLK_HDMIPHY>,
17962306a36Sopenharmony_ci                 <&cmu_disp CLK_PHYCLK_HDMIPHY_TMDS_CLKO>,
18062306a36Sopenharmony_ci                 <&cmu_disp CLK_PHYCLK_HDMI_PIXEL>,
18162306a36Sopenharmony_ci                 <&cmu_disp CLK_PHYCLK_HDMIPHY_TMDS_CLKO_PHY>,
18262306a36Sopenharmony_ci                 <&cmu_disp CLK_MOUT_PHYCLK_HDMIPHY_TMDS_CLKO_USER>,
18362306a36Sopenharmony_ci                 <&cmu_disp CLK_PHYCLK_HDMIPHY_PIXEL_CLKO_PHY>,
18462306a36Sopenharmony_ci                 <&cmu_disp CLK_MOUT_PHYCLK_HDMIPHY_PIXEL_CLKO_USER>,
18562306a36Sopenharmony_ci                 <&xxti>,
18662306a36Sopenharmony_ci                 <&cmu_disp CLK_SCLK_HDMI_SPDIF>;
18762306a36Sopenharmony_ci        clock-names = "hdmi_pclk",
18862306a36Sopenharmony_ci                      "hdmi_i_pclk",
18962306a36Sopenharmony_ci                      "i_tmds_clk",
19062306a36Sopenharmony_ci                      "i_pixel_clk",
19162306a36Sopenharmony_ci                      "tmds_clko",
19262306a36Sopenharmony_ci                      "tmds_clko_user",
19362306a36Sopenharmony_ci                      "pixel_clko",
19462306a36Sopenharmony_ci                      "pixel_clko_user",
19562306a36Sopenharmony_ci                      "oscclk",
19662306a36Sopenharmony_ci                      "i_spdif_clk";
19762306a36Sopenharmony_ci        phy = <&hdmiphy>;
19862306a36Sopenharmony_ci        ddc = <&hsi2c_11>;
19962306a36Sopenharmony_ci        samsung,syscon-phandle = <&pmu_system_controller>;
20062306a36Sopenharmony_ci        samsung,sysreg-phandle = <&syscon_disp>;
20162306a36Sopenharmony_ci        #sound-dai-cells = <0>;
20262306a36Sopenharmony_ci
20362306a36Sopenharmony_ci        hpd-gpios = <&gpa3 0 GPIO_ACTIVE_HIGH>;
20462306a36Sopenharmony_ci        vdd-supply = <&ldo6_reg>;
20562306a36Sopenharmony_ci        vdd_osc-supply = <&ldo7_reg>;
20662306a36Sopenharmony_ci        vdd_pll-supply = <&ldo6_reg>;
20762306a36Sopenharmony_ci
20862306a36Sopenharmony_ci        ports {
20962306a36Sopenharmony_ci            #address-cells = <1>;
21062306a36Sopenharmony_ci            #size-cells = <0>;
21162306a36Sopenharmony_ci
21262306a36Sopenharmony_ci            port@0 {
21362306a36Sopenharmony_ci                reg = <0>;
21462306a36Sopenharmony_ci                hdmi_to_tv: endpoint {
21562306a36Sopenharmony_ci                    remote-endpoint = <&tv_to_hdmi>;
21662306a36Sopenharmony_ci                };
21762306a36Sopenharmony_ci            };
21862306a36Sopenharmony_ci
21962306a36Sopenharmony_ci            port@1 {
22062306a36Sopenharmony_ci                reg = <1>;
22162306a36Sopenharmony_ci                hdmi_to_mhl: endpoint {
22262306a36Sopenharmony_ci                    remote-endpoint = <&mhl_to_hdmi>;
22362306a36Sopenharmony_ci                };
22462306a36Sopenharmony_ci            };
22562306a36Sopenharmony_ci        };
22662306a36Sopenharmony_ci    };
227