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,lvds.yaml#
562306a36Sopenharmony_ci$schema: http://devicetree.org/meta-schemas/core.yaml#
662306a36Sopenharmony_ci
762306a36Sopenharmony_cititle: Rockchip low-voltage differential signal (LVDS) transmitter
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,px30-lvds
1762306a36Sopenharmony_ci      - rockchip,rk3288-lvds
1862306a36Sopenharmony_ci
1962306a36Sopenharmony_ci  reg:
2062306a36Sopenharmony_ci    maxItems: 1
2162306a36Sopenharmony_ci
2262306a36Sopenharmony_ci  clocks:
2362306a36Sopenharmony_ci    maxItems: 1
2462306a36Sopenharmony_ci
2562306a36Sopenharmony_ci  clock-names:
2662306a36Sopenharmony_ci    const: pclk_lvds
2762306a36Sopenharmony_ci
2862306a36Sopenharmony_ci  avdd1v0-supply:
2962306a36Sopenharmony_ci    description: 1.0V analog power.
3062306a36Sopenharmony_ci
3162306a36Sopenharmony_ci  avdd1v8-supply:
3262306a36Sopenharmony_ci    description: 1.8V analog power.
3362306a36Sopenharmony_ci
3462306a36Sopenharmony_ci  avdd3v3-supply:
3562306a36Sopenharmony_ci    description: 3.3V analog power.
3662306a36Sopenharmony_ci
3762306a36Sopenharmony_ci  rockchip,grf:
3862306a36Sopenharmony_ci    $ref: /schemas/types.yaml#/definitions/phandle
3962306a36Sopenharmony_ci    description: Phandle to the general register files syscon.
4062306a36Sopenharmony_ci
4162306a36Sopenharmony_ci  rockchip,output:
4262306a36Sopenharmony_ci    $ref: /schemas/types.yaml#/definitions/string
4362306a36Sopenharmony_ci    enum: [rgb, lvds, duallvds]
4462306a36Sopenharmony_ci    description: This describes the output interface.
4562306a36Sopenharmony_ci
4662306a36Sopenharmony_ci  phys:
4762306a36Sopenharmony_ci    maxItems: 1
4862306a36Sopenharmony_ci
4962306a36Sopenharmony_ci  phy-names:
5062306a36Sopenharmony_ci    const: dphy
5162306a36Sopenharmony_ci
5262306a36Sopenharmony_ci  pinctrl-names:
5362306a36Sopenharmony_ci    const: lcdc
5462306a36Sopenharmony_ci
5562306a36Sopenharmony_ci  pinctrl-0: true
5662306a36Sopenharmony_ci
5762306a36Sopenharmony_ci  power-domains:
5862306a36Sopenharmony_ci    maxItems: 1
5962306a36Sopenharmony_ci
6062306a36Sopenharmony_ci  ports:
6162306a36Sopenharmony_ci    $ref: /schemas/graph.yaml#/properties/ports
6262306a36Sopenharmony_ci
6362306a36Sopenharmony_ci    properties:
6462306a36Sopenharmony_ci      port@0:
6562306a36Sopenharmony_ci        $ref: /schemas/graph.yaml#/properties/port
6662306a36Sopenharmony_ci        description:
6762306a36Sopenharmony_ci          Video port 0 for the VOP input.
6862306a36Sopenharmony_ci          The remote endpoint maybe vopb or vopl.
6962306a36Sopenharmony_ci
7062306a36Sopenharmony_ci      port@1:
7162306a36Sopenharmony_ci        $ref: /schemas/graph.yaml#/properties/port
7262306a36Sopenharmony_ci        description:
7362306a36Sopenharmony_ci          Video port 1 for either a panel or subsequent encoder.
7462306a36Sopenharmony_ci
7562306a36Sopenharmony_ci    required:
7662306a36Sopenharmony_ci      - port@0
7762306a36Sopenharmony_ci      - port@1
7862306a36Sopenharmony_ci
7962306a36Sopenharmony_cirequired:
8062306a36Sopenharmony_ci  - compatible
8162306a36Sopenharmony_ci  - rockchip,grf
8262306a36Sopenharmony_ci  - rockchip,output
8362306a36Sopenharmony_ci  - ports
8462306a36Sopenharmony_ci
8562306a36Sopenharmony_ciallOf:
8662306a36Sopenharmony_ci  - if:
8762306a36Sopenharmony_ci      properties:
8862306a36Sopenharmony_ci        compatible:
8962306a36Sopenharmony_ci          contains:
9062306a36Sopenharmony_ci            const: rockchip,px30-lvds
9162306a36Sopenharmony_ci
9262306a36Sopenharmony_ci    then:
9362306a36Sopenharmony_ci      properties:
9462306a36Sopenharmony_ci        reg: false
9562306a36Sopenharmony_ci        clocks: false
9662306a36Sopenharmony_ci        clock-names: false
9762306a36Sopenharmony_ci        avdd1v0-supply: false
9862306a36Sopenharmony_ci        avdd1v8-supply: false
9962306a36Sopenharmony_ci        avdd3v3-supply: false
10062306a36Sopenharmony_ci
10162306a36Sopenharmony_ci      required:
10262306a36Sopenharmony_ci        - phys
10362306a36Sopenharmony_ci        - phy-names
10462306a36Sopenharmony_ci
10562306a36Sopenharmony_ci  - if:
10662306a36Sopenharmony_ci      properties:
10762306a36Sopenharmony_ci        compatible:
10862306a36Sopenharmony_ci          contains:
10962306a36Sopenharmony_ci            const: rockchip,rk3288-lvds
11062306a36Sopenharmony_ci
11162306a36Sopenharmony_ci    then:
11262306a36Sopenharmony_ci      properties:
11362306a36Sopenharmony_ci        phys: false
11462306a36Sopenharmony_ci        phy-names: false
11562306a36Sopenharmony_ci
11662306a36Sopenharmony_ci      required:
11762306a36Sopenharmony_ci        - reg
11862306a36Sopenharmony_ci        - clocks
11962306a36Sopenharmony_ci        - clock-names
12062306a36Sopenharmony_ci        - avdd1v0-supply
12162306a36Sopenharmony_ci        - avdd1v8-supply
12262306a36Sopenharmony_ci        - avdd3v3-supply
12362306a36Sopenharmony_ci
12462306a36Sopenharmony_ciadditionalProperties: false
12562306a36Sopenharmony_ci
12662306a36Sopenharmony_ciexamples:
12762306a36Sopenharmony_ci  - |
12862306a36Sopenharmony_ci    #include <dt-bindings/clock/rk3288-cru.h>
12962306a36Sopenharmony_ci
13062306a36Sopenharmony_ci    lvds: lvds@ff96c000 {
13162306a36Sopenharmony_ci      compatible = "rockchip,rk3288-lvds";
13262306a36Sopenharmony_ci      reg = <0xff96c000 0x4000>;
13362306a36Sopenharmony_ci      clocks = <&cru PCLK_LVDS_PHY>;
13462306a36Sopenharmony_ci      clock-names = "pclk_lvds";
13562306a36Sopenharmony_ci      avdd1v0-supply = <&vdd10_lcd>;
13662306a36Sopenharmony_ci      avdd1v8-supply = <&vcc18_lcd>;
13762306a36Sopenharmony_ci      avdd3v3-supply = <&vcca_33>;
13862306a36Sopenharmony_ci      pinctrl-names = "lcdc";
13962306a36Sopenharmony_ci      pinctrl-0 = <&lcdc_ctl>;
14062306a36Sopenharmony_ci      rockchip,grf = <&grf>;
14162306a36Sopenharmony_ci      rockchip,output = "rgb";
14262306a36Sopenharmony_ci
14362306a36Sopenharmony_ci      ports {
14462306a36Sopenharmony_ci        #address-cells = <1>;
14562306a36Sopenharmony_ci        #size-cells = <0>;
14662306a36Sopenharmony_ci
14762306a36Sopenharmony_ci        lvds_in: port@0 {
14862306a36Sopenharmony_ci          reg = <0>;
14962306a36Sopenharmony_ci          #address-cells = <1>;
15062306a36Sopenharmony_ci          #size-cells = <0>;
15162306a36Sopenharmony_ci
15262306a36Sopenharmony_ci          lvds_in_vopb: endpoint@0 {
15362306a36Sopenharmony_ci            reg = <0>;
15462306a36Sopenharmony_ci            remote-endpoint = <&vopb_out_lvds>;
15562306a36Sopenharmony_ci          };
15662306a36Sopenharmony_ci          lvds_in_vopl: endpoint@1 {
15762306a36Sopenharmony_ci            reg = <1>;
15862306a36Sopenharmony_ci            remote-endpoint = <&vopl_out_lvds>;
15962306a36Sopenharmony_ci          };
16062306a36Sopenharmony_ci        };
16162306a36Sopenharmony_ci
16262306a36Sopenharmony_ci        lvds_out: port@1 {
16362306a36Sopenharmony_ci          reg = <1>;
16462306a36Sopenharmony_ci
16562306a36Sopenharmony_ci          lvds_out_panel: endpoint {
16662306a36Sopenharmony_ci            remote-endpoint = <&panel_in_lvds>;
16762306a36Sopenharmony_ci          };
16862306a36Sopenharmony_ci        };
16962306a36Sopenharmony_ci      };
17062306a36Sopenharmony_ci    };
171