162306a36Sopenharmony_ci# SPDX-License-Identifier: GPL-2.0
262306a36Sopenharmony_ci%YAML 1.2
362306a36Sopenharmony_ci---
462306a36Sopenharmony_ci$id: http://devicetree.org/schemas/display/rockchip/rockchip,analogix-dp.yaml#
562306a36Sopenharmony_ci$schema: http://devicetree.org/meta-schemas/core.yaml#
662306a36Sopenharmony_ci
762306a36Sopenharmony_cititle: Rockchip specific extensions to the Analogix Display Port
862306a36Sopenharmony_ci
962306a36Sopenharmony_cimaintainers:
1062306a36Sopenharmony_ci  - Sandy Huang <hjc@rock-chips.com>
1162306a36Sopenharmony_ci  - Heiko Stuebner <heiko@sntech.de>
1262306a36Sopenharmony_ci
1362306a36Sopenharmony_ciproperties:
1462306a36Sopenharmony_ci  compatible:
1562306a36Sopenharmony_ci    enum:
1662306a36Sopenharmony_ci      - rockchip,rk3288-dp
1762306a36Sopenharmony_ci      - rockchip,rk3399-edp
1862306a36Sopenharmony_ci
1962306a36Sopenharmony_ci  clocks:
2062306a36Sopenharmony_ci    minItems: 2
2162306a36Sopenharmony_ci    maxItems: 3
2262306a36Sopenharmony_ci
2362306a36Sopenharmony_ci  clock-names:
2462306a36Sopenharmony_ci    minItems: 2
2562306a36Sopenharmony_ci    items:
2662306a36Sopenharmony_ci      - const: dp
2762306a36Sopenharmony_ci      - const: pclk
2862306a36Sopenharmony_ci      - const: grf
2962306a36Sopenharmony_ci
3062306a36Sopenharmony_ci  power-domains:
3162306a36Sopenharmony_ci    maxItems: 1
3262306a36Sopenharmony_ci
3362306a36Sopenharmony_ci  resets:
3462306a36Sopenharmony_ci    maxItems: 1
3562306a36Sopenharmony_ci
3662306a36Sopenharmony_ci  reset-names:
3762306a36Sopenharmony_ci    const: dp
3862306a36Sopenharmony_ci
3962306a36Sopenharmony_ci  rockchip,grf:
4062306a36Sopenharmony_ci    $ref: /schemas/types.yaml#/definitions/phandle
4162306a36Sopenharmony_ci    description:
4262306a36Sopenharmony_ci      This SoC makes use of GRF regs.
4362306a36Sopenharmony_ci
4462306a36Sopenharmony_cirequired:
4562306a36Sopenharmony_ci  - compatible
4662306a36Sopenharmony_ci  - clocks
4762306a36Sopenharmony_ci  - clock-names
4862306a36Sopenharmony_ci  - resets
4962306a36Sopenharmony_ci  - reset-names
5062306a36Sopenharmony_ci  - rockchip,grf
5162306a36Sopenharmony_ci
5262306a36Sopenharmony_ciallOf:
5362306a36Sopenharmony_ci  - $ref: /schemas/display/bridge/analogix,dp.yaml#
5462306a36Sopenharmony_ci
5562306a36Sopenharmony_ciunevaluatedProperties: false
5662306a36Sopenharmony_ci
5762306a36Sopenharmony_ciexamples:
5862306a36Sopenharmony_ci  - |
5962306a36Sopenharmony_ci    #include <dt-bindings/clock/rk3288-cru.h>
6062306a36Sopenharmony_ci    #include <dt-bindings/interrupt-controller/arm-gic.h>
6162306a36Sopenharmony_ci    #include <dt-bindings/interrupt-controller/irq.h>
6262306a36Sopenharmony_ci    dp@ff970000 {
6362306a36Sopenharmony_ci      compatible = "rockchip,rk3288-dp";
6462306a36Sopenharmony_ci      reg = <0xff970000 0x4000>;
6562306a36Sopenharmony_ci      interrupts = <GIC_SPI 98 IRQ_TYPE_LEVEL_HIGH>;
6662306a36Sopenharmony_ci      clocks = <&cru SCLK_EDP>, <&cru PCLK_EDP_CTRL>;
6762306a36Sopenharmony_ci      clock-names = "dp", "pclk";
6862306a36Sopenharmony_ci      phys = <&dp_phy>;
6962306a36Sopenharmony_ci      phy-names = "dp";
7062306a36Sopenharmony_ci      resets = <&cru 111>;
7162306a36Sopenharmony_ci      reset-names = "dp";
7262306a36Sopenharmony_ci      rockchip,grf = <&grf>;
7362306a36Sopenharmony_ci      pinctrl-0 = <&edp_hpd>;
7462306a36Sopenharmony_ci      pinctrl-names = "default";
7562306a36Sopenharmony_ci
7662306a36Sopenharmony_ci      ports {
7762306a36Sopenharmony_ci        #address-cells = <1>;
7862306a36Sopenharmony_ci        #size-cells = <0>;
7962306a36Sopenharmony_ci
8062306a36Sopenharmony_ci        edp_in: port@0 {
8162306a36Sopenharmony_ci          reg = <0>;
8262306a36Sopenharmony_ci          #address-cells = <1>;
8362306a36Sopenharmony_ci          #size-cells = <0>;
8462306a36Sopenharmony_ci
8562306a36Sopenharmony_ci          edp_in_vopb: endpoint@0 {
8662306a36Sopenharmony_ci            reg = <0>;
8762306a36Sopenharmony_ci            remote-endpoint = <&vopb_out_edp>;
8862306a36Sopenharmony_ci          };
8962306a36Sopenharmony_ci          edp_in_vopl: endpoint@1 {
9062306a36Sopenharmony_ci            reg = <1>;
9162306a36Sopenharmony_ci            remote-endpoint = <&vopl_out_edp>;
9262306a36Sopenharmony_ci          };
9362306a36Sopenharmony_ci        };
9462306a36Sopenharmony_ci
9562306a36Sopenharmony_ci        edp_out: port@1 {
9662306a36Sopenharmony_ci          reg = <1>;
9762306a36Sopenharmony_ci
9862306a36Sopenharmony_ci          edp_out_panel: endpoint {
9962306a36Sopenharmony_ci            remote-endpoint = <&panel_in_edp>;
10062306a36Sopenharmony_ci          };
10162306a36Sopenharmony_ci        };
10262306a36Sopenharmony_ci      };
10362306a36Sopenharmony_ci    };
104