 c06fb25d1f
			
		
	
	c06fb25d1f
	
	
		
			
	
		
	
	
		
			Some checks failed
		
		
	
	Build Kernel / Build all affected Kernels (push) Has been cancelled
				
			Build all core packages / Build all core packages for selected target (push) Has been cancelled
				
			Build and Push prebuilt tools container / Build and Push all prebuilt containers (push) Has been cancelled
				
			Build Toolchains / Build Toolchains for each target (push) Has been cancelled
				
			Build host tools / Build host tools for linux and macos based systems (push) Has been cancelled
				
			Coverity scan build / Coverity x86/64 build (push) Has been cancelled
				
			
		
			
				
	
	
		
			271 lines
		
	
	
		
			7.5 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			271 lines
		
	
	
		
			7.5 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
| From aa4febf074cbaad81c981a5c6b55324a6f676fb7 Mon Sep 17 00:00:00 2001
 | |
| From: "shengyang.chen" <shengyang.chen@starfivetech.com>
 | |
| Date: Tue, 13 Jun 2023 14:22:29 +0800
 | |
| Subject: [PATCH 089/116] dt-bindings: display: Add yamls for JH7110 display
 | |
|  system and hdmi
 | |
| 
 | |
| StarFive SoCs like the jh7110 use display system based on verisilicon IP, use hdmi
 | |
| base on innosilicon IP. Add bindings for them.
 | |
| 
 | |
| Signed-off-by: Shengyang Chen <shengyang.chen@starfivetech.com>
 | |
| ---
 | |
|  .../display/verisilicon/starfive-hdmi.yaml    |  92 +++++++++++++++
 | |
|  .../display/verisilicon/verisilicon-dc.yaml   | 109 ++++++++++++++++++
 | |
|  .../display/verisilicon/verisilicon-drm.yaml  |  41 +++++++
 | |
|  3 files changed, 242 insertions(+)
 | |
|  create mode 100644 Documentation/devicetree/bindings/display/verisilicon/starfive-hdmi.yaml
 | |
|  create mode 100644 Documentation/devicetree/bindings/display/verisilicon/verisilicon-dc.yaml
 | |
|  create mode 100644 Documentation/devicetree/bindings/display/verisilicon/verisilicon-drm.yaml
 | |
| 
 | |
| --- /dev/null
 | |
| +++ b/Documentation/devicetree/bindings/display/verisilicon/starfive-hdmi.yaml
 | |
| @@ -0,0 +1,92 @@
 | |
| +# SPDX-License-Identifier: GPL-2.0
 | |
| +%YAML 1.2
 | |
| +---
 | |
| +$id: http://devicetree.org/schemas/display/verisilicon/starfive-hdmi.yaml#
 | |
| +$schema: http://devicetree.org/meta-schemas/core.yaml#
 | |
| +
 | |
| +title: StarFive SoC HDMI transmiter
 | |
| +
 | |
| +description:
 | |
| +  The StarFive SoC uses the HDMI signal transmiter based on innosilicon IP 
 | |
| +  to generate HDMI signal from its input and transmit the signal to the screen.
 | |
| +
 | |
| +maintainers:
 | |
| +  - Keith Zhao <keith.zhao@starfivetech.com>
 | |
| +
 | |
| +properties:
 | |
| +  compatible:
 | |
| +    const: starfive,hdmi
 | |
| +
 | |
| +  reg:
 | |
| +    minItems: 1
 | |
| +
 | |
| +  interrupts:
 | |
| +    items:
 | |
| +      - description: The HDMI hot plug detection interrupt.
 | |
| +
 | |
| +  clocks:
 | |
| +    items:
 | |
| +      - description: System clock of HDMI module.
 | |
| +      - description: Mclk clock of HDMI audio.
 | |
| +      - description: Bclk clock of HDMI audio.
 | |
| +      - description: Pixel clock generated by HDMI module.
 | |
| +
 | |
| +  clock-names:
 | |
| +    items:
 | |
| +      - const: sysclk
 | |
| +      - const: mclk
 | |
| +      - const: bclk
 | |
| +      - const: pclk
 | |
| +
 | |
| +  resets:
 | |
| +    items:
 | |
| +      - description: Reset for HDMI module.
 | |
| +
 | |
| +  reset-names:
 | |
| +    items:
 | |
| +      - const: hdmi_tx
 | |
| +
 | |
| +  '#sound-dai-cells':
 | |
| +    const: 0
 | |
| +
 | |
| +  port:
 | |
| +    $ref: /schemas/graph.yaml#/properties/port
 | |
| +    description:
 | |
| +      Port node with one endpoint connected to a display connector node.
 | |
| +
 | |
| +required:
 | |
| +  - compatible
 | |
| +  - reg
 | |
| +  - interrupts
 | |
| +  - clocks
 | |
| +  - clock-names
 | |
| +  - resets
 | |
| +  - reset-names
 | |
| +  - '#sound-dai-cells'
 | |
| +  - port
 | |
| +
 | |
| +additionalProperties: false
 | |
| +
 | |
| +examples:
 | |
| +  - |
 | |
| +    hdmi: hdmi@29590000 {
 | |
| +      compatible = "starfive,hdmi";
 | |
| +      reg = <0x29590000 0x4000>;
 | |
| +      interrupts = <99>;
 | |
| +      clocks = <&voutcrg 17>,
 | |
| +               <&voutcrg 15>,
 | |
| +               <&voutcrg 16>,
 | |
| +               <&hdmitx0_pixelclk>;
 | |
| +      clock-names = "sysclk", "mclk","bclk","pclk";
 | |
| +      resets = <&voutcrg 9>;
 | |
| +      reset-names = "hdmi_tx";
 | |
| +      #sound-dai-cells = <0>;
 | |
| +      hdmi_in: port {
 | |
| +          #address-cells = <1>;
 | |
| +          #size-cells = <0>;
 | |
| +          hdmi_input: endpoint@0 {
 | |
| +            reg = <0>;
 | |
| +            remote-endpoint = <&dc_out_dpi0>;
 | |
| +          };
 | |
| +      };
 | |
| +    };
 | |
| --- /dev/null
 | |
| +++ b/Documentation/devicetree/bindings/display/verisilicon/verisilicon-dc.yaml
 | |
| @@ -0,0 +1,109 @@
 | |
| +# SPDX-License-Identifier: GPL-2.0
 | |
| +%YAML 1.2
 | |
| +---
 | |
| +$id: http://devicetree.org/schemas/display/verisilicon/verisilicon-dc.yaml#
 | |
| +$schema: http://devicetree.org/meta-schemas/core.yaml#
 | |
| +
 | |
| +title: StarFive SoC display controller
 | |
| +
 | |
| +description:
 | |
| +  The StarFive SoC uses the display controller based on Verisilicon IP 
 | |
| +  to transfer the image data from a video memory
 | |
| +  buffer to an external LCD interface.
 | |
| +
 | |
| +maintainers:
 | |
| +  - Keith Zhao <keith.zhao@starfivetech.com>
 | |
| +
 | |
| +properties:
 | |
| +  compatible:
 | |
| +    const: verisilicon,dc8200
 | |
| +
 | |
| +  reg:
 | |
| +    maxItems: 3
 | |
| +
 | |
| +  interrupts:
 | |
| +    items:
 | |
| +      - description: The interrupt will be generated when DC finish one frame
 | |
| +
 | |
| +  clocks:
 | |
| +    items:
 | |
| +      - description: Clock for display system noc bus.
 | |
| +      - description: Pixel clock for display channel 0.
 | |
| +      - description: Pixel clock for display channel 1.
 | |
| +      - description: Clock for axi interface of display controller.
 | |
| +      - description: Core clock for display controller.
 | |
| +      - description: Clock for ahb interface of display controller.
 | |
| +      - description: External HDMI pixel clock.
 | |
| +      - description: Parent clock for pixel clock
 | |
| +
 | |
| +  clock-names:
 | |
| +    items:
 | |
| +      - const: clk_vout_noc_disp
 | |
| +      - const: clk_vout_pix0
 | |
| +      - const: clk_vout_pix1
 | |
| +      - const: clk_vout_axi
 | |
| +      - const: clk_vout_core
 | |
| +      - const: clk_vout_vout_ahb
 | |
| +      - const: hdmitx0_pixel
 | |
| +      - const: clk_vout_dc8200
 | |
| +
 | |
| +  resets:
 | |
| +    items:
 | |
| +      - description: Reset for axi interface of display controller.
 | |
| +      - description: Reset for ahb interface of display controller.
 | |
| +      - description: Core reset of display controller.
 | |
| +
 | |
| +  reset-names:
 | |
| +    items:
 | |
| +      - const: rst_vout_axi
 | |
| +      - const: rst_vout_ahb
 | |
| +      - const: rst_vout_core
 | |
| +
 | |
| +  port:
 | |
| +    $ref: /schemas/graph.yaml#/properties/port
 | |
| +    description:
 | |
| +      Port node with one endpoint connected to a hdmi node.
 | |
| +
 | |
| +required:
 | |
| +  - compatible
 | |
| +  - reg
 | |
| +  - interrupts
 | |
| +  - clocks
 | |
| +  - clock-names
 | |
| +  - resets
 | |
| +  - reset-names
 | |
| +  - port
 | |
| +
 | |
| +additionalProperties: false
 | |
| +
 | |
| +examples:
 | |
| +  - |
 | |
| +    dc8200: dc8200@29400000 {
 | |
| +      compatible = "verisilicon,dc8200";
 | |
| +      reg = <0x29400000 0x100>,
 | |
| +            <0x29400800 0x2000>,
 | |
| +            <0x295B0000 0x90>;
 | |
| +      interrupts = <95>;
 | |
| +      clocks = <&syscrg 60>,
 | |
| +               <&voutcrg 7>,
 | |
| +               <&voutcrg 8>,
 | |
| +               <&voutcrg 4>,
 | |
| +               <&voutcrg 5>,
 | |
| +               <&voutcrg 6>,
 | |
| +               <&hdmitx0_pixelclk>,
 | |
| +               <&voutcrg 1>;
 | |
| +      clock-names = "clk_vout_noc_disp", "clk_vout_pix0", "clk_vout_pix1", "clk_vout_axi",
 | |
| +                    "clk_vout_core", "clk_vout_vout_ahb", "hdmitx0_pixel","clk_vout_dc8200";
 | |
| +      resets = <&voutcrg 0>,
 | |
| +               <&voutcrg 1>,
 | |
| +               <&voutcrg 2>;
 | |
| +      reset-names = "rst_vout_axi","rst_vout_ahb","rst_vout_core";
 | |
| +      dc_out: port {
 | |
| +          #address-cells = <1>;
 | |
| +          #size-cells = <0>;
 | |
| +          dc_out_dpi0: endpoint@0 {
 | |
| +              reg = <0>;
 | |
| +              remote-endpoint = <&hdmi_input>;
 | |
| +          };
 | |
| +      };
 | |
| +    };
 | |
| --- /dev/null
 | |
| +++ b/Documentation/devicetree/bindings/display/verisilicon/verisilicon-drm.yaml
 | |
| @@ -0,0 +1,41 @@
 | |
| +# SPDX-License-Identifier: (GPL-2.0-only)
 | |
| +%YAML 1.2
 | |
| +---
 | |
| +$id: http://devicetree.org/schemas/display/verisilicon/verisilicon-drm.yaml#
 | |
| +$schema: http://devicetree.org/meta-schemas/core.yaml#
 | |
| +
 | |
| +title: Verisilicon DRM master device
 | |
| +
 | |
| +maintainers:
 | |
| +  - Keith Zhao <keith.zhao@starfivetech.com>
 | |
| +
 | |
| +description: |
 | |
| +  The Verisilicon DRM master device is a virtual device needed to list all
 | |
| +  display controller or other display interface nodes that comprise the
 | |
| +  graphics subsystem.
 | |
| +
 | |
| +properties:
 | |
| +  compatible:
 | |
| +    const: verisilicon,display-subsystem
 | |
| +
 | |
| +  ports:
 | |
| +    $ref: /schemas/types.yaml#/definitions/phandle-array
 | |
| +    items:
 | |
| +      maxItems: 1
 | |
| +    description: |
 | |
| +      Should contain a list of phandles pointing to display interface ports
 | |
| +      of display controller devices. Display controller definitions as defined in
 | |
| +      Documentation/devicetree/bindings/display/verisilicon/verisilicon-dc.yaml
 | |
| +
 | |
| +required:
 | |
| +  - compatible
 | |
| +  - ports
 | |
| +
 | |
| +additionalProperties: false
 | |
| +
 | |
| +examples:
 | |
| +  - |
 | |
| +    display-subsystem {
 | |
| +        compatible = "verisilicon,display-subsystem";
 | |
| +        ports = <&dc_out>;
 | |
| +    };
 |