mirror of
https://github.com/openwrt/openwrt.git
synced 2024-12-21 14:37:57 +00:00
e2e2fc3cd0
Add updated patches for 6.6. DMA/cache-handling patches have been reworked / backported from upstream. Signed-off-by: Zoltan HERPAI <wigyori@uid0.hu>
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>;
|
|
+ };
|