1# SPDX-License-Identifier: (GPL-2.0 OR BSD-2-Clause) 2# Copyright 2019 NXP 3%YAML 1.2 4--- 5$id: "http://devicetree.org/schemas/display/imx/nxp,imx8mq-dcss.yaml#" 6$schema: "http://devicetree.org/meta-schemas/core.yaml#" 7 8title: iMX8MQ Display Controller Subsystem (DCSS) 9 10maintainers: 11 - Laurentiu Palcu <laurentiu.palcu@nxp.com> 12 13description: 14 15 The DCSS (display controller sub system) is used to source up to three 16 display buffers, compose them, and drive a display using HDMI 2.0a(with HDCP 17 2.2) or MIPI-DSI. The DCSS is intended to support up to 4kp60 displays. HDR10 18 image processing capabilities are included to provide a solution capable of 19 driving next generation high dynamic range displays. 20 21properties: 22 compatible: 23 const: nxp,imx8mq-dcss 24 25 reg: 26 items: 27 - description: DCSS base address and size, up to IRQ steer start 28 - description: DCSS BLKCTL base address and size 29 30 interrupts: 31 items: 32 - description: Context loader completion and error interrupt 33 - description: DTG interrupt used to signal context loader trigger time 34 - description: DTG interrupt for Vblank 35 36 interrupt-names: 37 items: 38 - const: ctxld 39 - const: ctxld_kick 40 - const: vblank 41 42 clocks: 43 items: 44 - description: Display APB clock for all peripheral PIO access interfaces 45 - description: Display AXI clock needed by DPR, Scaler, RTRAM_CTRL 46 - description: RTRAM clock 47 - description: Pixel clock, can be driven either by HDMI phy clock or MIPI 48 - description: DTRC clock, needed by video decompressor 49 50 clock-names: 51 items: 52 - const: apb 53 - const: axi 54 - const: rtrm 55 - const: pix 56 - const: dtrc 57 58 assigned-clocks: 59 items: 60 - description: Phandle and clock specifier of IMX8MQ_CLK_DISP_AXI_ROOT 61 - description: Phandle and clock specifier of IMX8MQ_CLK_DISP_RTRM 62 - description: Phandle and clock specifier of either IMX8MQ_VIDEO2_PLL1_REF_SEL or 63 IMX8MQ_VIDEO_PLL1_REF_SEL 64 65 assigned-clock-parents: 66 items: 67 - description: Phandle and clock specifier of IMX8MQ_SYS1_PLL_800M 68 - description: Phandle and clock specifier of IMX8MQ_SYS1_PLL_800M 69 - description: Phandle and clock specifier of IMX8MQ_CLK_27M 70 71 assigned-clock-rates: 72 items: 73 - description: Must be 800 MHz 74 - description: Must be 400 MHz 75 76 port: 77 $ref: /schemas/graph.yaml#/properties/port 78 description: 79 A port node pointing to the input port of a HDMI/DP or MIPI display bridge. 80 81additionalProperties: false 82 83examples: 84 - | 85 #include <dt-bindings/clock/imx8mq-clock.h> 86 dcss: display-controller@32e00000 { 87 compatible = "nxp,imx8mq-dcss"; 88 reg = <0x32e00000 0x2d000>, <0x32e2f000 0x1000>; 89 interrupts = <6>, <8>, <9>; 90 interrupt-names = "ctxld", "ctxld_kick", "vblank"; 91 interrupt-parent = <&irqsteer>; 92 clocks = <&clk IMX8MQ_CLK_DISP_APB_ROOT>, <&clk IMX8MQ_CLK_DISP_AXI_ROOT>, 93 <&clk IMX8MQ_CLK_DISP_RTRM_ROOT>, <&clk IMX8MQ_VIDEO2_PLL_OUT>, 94 <&clk IMX8MQ_CLK_DISP_DTRC>; 95 clock-names = "apb", "axi", "rtrm", "pix", "dtrc"; 96 assigned-clocks = <&clk IMX8MQ_CLK_DISP_AXI>, <&clk IMX8MQ_CLK_DISP_RTRM>, 97 <&clk IMX8MQ_VIDEO2_PLL1_REF_SEL>; 98 assigned-clock-parents = <&clk IMX8MQ_SYS1_PLL_800M>, <&clk IMX8MQ_SYS1_PLL_800M>, 99 <&clk IMX8MQ_CLK_27M>; 100 assigned-clock-rates = <800000000>, 101 <400000000>; 102 port { 103 dcss_out: endpoint { 104 remote-endpoint = <&hdmi_in>; 105 }; 106 }; 107 }; 108 109