mirror of
git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-09-04 20:19:47 +08:00
dt-bindings: display/msm: convert MDP5 schema to YAML format
Convert the mdp5.txt into the yaml format. Changes to the existing (txt) schema: - MSM8996 has additional "iommu" clock, define it separately - Add new properties used on some of platforms: - interconnects, interconnect-names - iommus - power-domains - operating-points-v2, opp-table Reviewed-by: Rob Herring <robh@kernel.org> Signed-off-by: Dmitry Baryshkov <dmitry.baryshkov@linaro.org> Patchwork: https://patchwork.freedesktop.org/patch/518815/ Link: https://lore.kernel.org/r/20230118041243.1720520-2-dmitry.baryshkov@linaro.org Signed-off-by: Dmitry Baryshkov <dmitry.baryshkov@linaro.org>
This commit is contained in:
parent
643b7d0869
commit
385c8ac763
@ -1,132 +0,0 @@
|
|||||||
Qualcomm adreno/snapdragon MDP5 display controller
|
|
||||||
|
|
||||||
Description:
|
|
||||||
|
|
||||||
This is the bindings documentation for the MDP5 display
|
|
||||||
controller found in SoCs like MSM8974, APQ8084, MSM8916, MSM8994 and MSM8996.
|
|
||||||
|
|
||||||
MDP5:
|
|
||||||
Required properties:
|
|
||||||
- compatible:
|
|
||||||
* "qcom,mdp5" - MDP5
|
|
||||||
- reg: Physical base address and length of the controller's registers.
|
|
||||||
- reg-names: The names of register regions. The following regions are required:
|
|
||||||
* "mdp_phys"
|
|
||||||
- interrupts: Interrupt line from MDP5 to MDSS interrupt controller.
|
|
||||||
- clocks: device clocks. See ../clocks/clock-bindings.txt for details.
|
|
||||||
- clock-names: the following clocks are required.
|
|
||||||
- * "bus"
|
|
||||||
- * "iface"
|
|
||||||
- * "core"
|
|
||||||
- * "vsync"
|
|
||||||
- ports: contains the list of output ports from MDP. These connect to interfaces
|
|
||||||
that are external to the MDP hardware, such as HDMI, DSI, EDP etc (LVDS is a
|
|
||||||
special case since it is a part of the MDP block itself).
|
|
||||||
|
|
||||||
Each output port contains an endpoint that describes how it is connected to an
|
|
||||||
external interface. These are described by the standard properties documented
|
|
||||||
here:
|
|
||||||
Documentation/devicetree/bindings/graph.txt
|
|
||||||
Documentation/devicetree/bindings/media/video-interfaces.txt
|
|
||||||
|
|
||||||
The availability of output ports can vary across SoC revisions:
|
|
||||||
|
|
||||||
For MSM8974 and APQ8084:
|
|
||||||
Port 0 -> MDP_INTF0 (eDP)
|
|
||||||
Port 1 -> MDP_INTF1 (DSI1)
|
|
||||||
Port 2 -> MDP_INTF2 (DSI2)
|
|
||||||
Port 3 -> MDP_INTF3 (HDMI)
|
|
||||||
|
|
||||||
For MSM8916:
|
|
||||||
Port 0 -> MDP_INTF1 (DSI1)
|
|
||||||
|
|
||||||
For MSM8994 and MSM8996:
|
|
||||||
Port 0 -> MDP_INTF1 (DSI1)
|
|
||||||
Port 1 -> MDP_INTF2 (DSI2)
|
|
||||||
Port 2 -> MDP_INTF3 (HDMI)
|
|
||||||
|
|
||||||
Optional properties:
|
|
||||||
- clock-names: the following clocks are optional:
|
|
||||||
* "lut"
|
|
||||||
* "tbu"
|
|
||||||
* "tbu_rt"
|
|
||||||
|
|
||||||
Example:
|
|
||||||
|
|
||||||
/ {
|
|
||||||
...
|
|
||||||
|
|
||||||
mdss: mdss@1a00000 {
|
|
||||||
compatible = "qcom,mdss";
|
|
||||||
reg = <0x1a00000 0x1000>,
|
|
||||||
<0x1ac8000 0x3000>;
|
|
||||||
reg-names = "mdss_phys", "vbif_phys";
|
|
||||||
|
|
||||||
power-domains = <&gcc MDSS_GDSC>;
|
|
||||||
|
|
||||||
clocks = <&gcc GCC_MDSS_AHB_CLK>,
|
|
||||||
<&gcc GCC_MDSS_AXI_CLK>,
|
|
||||||
<&gcc GCC_MDSS_VSYNC_CLK>;
|
|
||||||
clock-names = "iface",
|
|
||||||
"bus",
|
|
||||||
"vsync"
|
|
||||||
|
|
||||||
interrupts = <0 72 0>;
|
|
||||||
|
|
||||||
interrupt-controller;
|
|
||||||
#interrupt-cells = <1>;
|
|
||||||
|
|
||||||
#address-cells = <1>;
|
|
||||||
#size-cells = <1>;
|
|
||||||
ranges;
|
|
||||||
|
|
||||||
mdp: mdp@1a01000 {
|
|
||||||
compatible = "qcom,mdp5";
|
|
||||||
reg = <0x1a01000 0x90000>;
|
|
||||||
reg-names = "mdp_phys";
|
|
||||||
|
|
||||||
interrupt-parent = <&mdss>;
|
|
||||||
interrupts = <0 0>;
|
|
||||||
|
|
||||||
clocks = <&gcc GCC_MDSS_AHB_CLK>,
|
|
||||||
<&gcc GCC_MDSS_AXI_CLK>,
|
|
||||||
<&gcc GCC_MDSS_MDP_CLK>,
|
|
||||||
<&gcc GCC_MDSS_VSYNC_CLK>;
|
|
||||||
clock-names = "iface",
|
|
||||||
"bus",
|
|
||||||
"core",
|
|
||||||
"vsync";
|
|
||||||
|
|
||||||
ports {
|
|
||||||
#address-cells = <1>;
|
|
||||||
#size-cells = <0>;
|
|
||||||
|
|
||||||
port@0 {
|
|
||||||
reg = <0>;
|
|
||||||
mdp5_intf1_out: endpoint {
|
|
||||||
remote-endpoint = <&dsi0_in>;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
dsi0: dsi@1a98000 {
|
|
||||||
...
|
|
||||||
ports {
|
|
||||||
...
|
|
||||||
port@0 {
|
|
||||||
reg = <0>;
|
|
||||||
dsi0_in: endpoint {
|
|
||||||
remote-endpoint = <&mdp5_intf1_out>;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
...
|
|
||||||
};
|
|
||||||
...
|
|
||||||
};
|
|
||||||
|
|
||||||
dsi_phy0: dsi-phy@1a98300 {
|
|
||||||
...
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
138
Documentation/devicetree/bindings/display/msm/qcom,mdp5.yaml
Normal file
138
Documentation/devicetree/bindings/display/msm/qcom,mdp5.yaml
Normal file
@ -0,0 +1,138 @@
|
|||||||
|
# SPDX-License-Identifier: GPL-2.0-only or BSD-2-Clause
|
||||||
|
%YAML 1.2
|
||||||
|
---
|
||||||
|
$id: http://devicetree.org/schemas/display/msm/qcom,mdp5.yaml#
|
||||||
|
$schema: http://devicetree.org/meta-schemas/core.yaml#
|
||||||
|
|
||||||
|
title: Qualcomm Adreno/Snapdragon Mobile Display controller (MDP5)
|
||||||
|
|
||||||
|
description:
|
||||||
|
MDP5 display controller found in SoCs like MSM8974, APQ8084, MSM8916, MSM8994
|
||||||
|
and MSM8996.
|
||||||
|
|
||||||
|
maintainers:
|
||||||
|
- Dmitry Baryshkov <dmitry.baryshkov@linaro.org>
|
||||||
|
- Rob Clark <robdclark@gmail.com>
|
||||||
|
|
||||||
|
properties:
|
||||||
|
compatible:
|
||||||
|
const: qcom,mdp5
|
||||||
|
|
||||||
|
reg:
|
||||||
|
maxItems: 1
|
||||||
|
|
||||||
|
reg-names:
|
||||||
|
items:
|
||||||
|
- const: mdp_phys
|
||||||
|
|
||||||
|
interrupts:
|
||||||
|
maxItems: 1
|
||||||
|
|
||||||
|
clocks:
|
||||||
|
minItems: 4
|
||||||
|
maxItems: 7
|
||||||
|
|
||||||
|
clock-names:
|
||||||
|
oneOf:
|
||||||
|
- minItems: 4
|
||||||
|
items:
|
||||||
|
- const: iface
|
||||||
|
- const: bus
|
||||||
|
- const: core
|
||||||
|
- const: vsync
|
||||||
|
- const: lut
|
||||||
|
- const: tbu
|
||||||
|
- const: tbu_rt
|
||||||
|
#MSM8996 has additional iommu clock
|
||||||
|
- items:
|
||||||
|
- const: iface
|
||||||
|
- const: bus
|
||||||
|
- const: core
|
||||||
|
- const: iommu
|
||||||
|
- const: vsync
|
||||||
|
|
||||||
|
interconnects:
|
||||||
|
minItems: 1
|
||||||
|
items:
|
||||||
|
- description: Interconnect path from mdp0 (or a single mdp) port to the data bus
|
||||||
|
- description: Interconnect path from mdp1 port to the data bus
|
||||||
|
- description: Interconnect path from rotator port to the data bus
|
||||||
|
|
||||||
|
interconnect-names:
|
||||||
|
minItems: 1
|
||||||
|
items:
|
||||||
|
- const: mdp0-mem
|
||||||
|
- const: mdp1-mem
|
||||||
|
- const: rotator-mem
|
||||||
|
|
||||||
|
iommus:
|
||||||
|
items:
|
||||||
|
- description: apps SMMU with the Stream-ID mask for Hard-Fail port0
|
||||||
|
|
||||||
|
power-domains:
|
||||||
|
maxItems: 1
|
||||||
|
|
||||||
|
operating-points-v2: true
|
||||||
|
opp-table:
|
||||||
|
type: object
|
||||||
|
|
||||||
|
ports:
|
||||||
|
$ref: /schemas/graph.yaml#/properties/ports
|
||||||
|
description: >
|
||||||
|
Contains the list of output ports from DPU device. These ports
|
||||||
|
connect to interfaces that are external to the DPU hardware,
|
||||||
|
such as DSI, DP etc. MDP5 devices support up to 4 ports:
|
||||||
|
one or two DSI ports, HDMI and eDP.
|
||||||
|
|
||||||
|
patternProperties:
|
||||||
|
"^port@[0-3]+$":
|
||||||
|
$ref: /schemas/graph.yaml#/properties/port
|
||||||
|
|
||||||
|
# at least one port is required
|
||||||
|
required:
|
||||||
|
- port@0
|
||||||
|
|
||||||
|
required:
|
||||||
|
- compatible
|
||||||
|
- reg
|
||||||
|
- reg-names
|
||||||
|
- clocks
|
||||||
|
- clock-names
|
||||||
|
- ports
|
||||||
|
|
||||||
|
additionalProperties: false
|
||||||
|
|
||||||
|
examples:
|
||||||
|
- |
|
||||||
|
#include <dt-bindings/clock/qcom,gcc-msm8916.h>
|
||||||
|
#include <dt-bindings/interrupt-controller/arm-gic.h>
|
||||||
|
display-controller@1a01000 {
|
||||||
|
compatible = "qcom,mdp5";
|
||||||
|
reg = <0x1a01000 0x90000>;
|
||||||
|
reg-names = "mdp_phys";
|
||||||
|
|
||||||
|
interrupt-parent = <&mdss>;
|
||||||
|
interrupts = <0>;
|
||||||
|
|
||||||
|
clocks = <&gcc GCC_MDSS_AHB_CLK>,
|
||||||
|
<&gcc GCC_MDSS_AXI_CLK>,
|
||||||
|
<&gcc GCC_MDSS_MDP_CLK>,
|
||||||
|
<&gcc GCC_MDSS_VSYNC_CLK>;
|
||||||
|
clock-names = "iface",
|
||||||
|
"bus",
|
||||||
|
"core",
|
||||||
|
"vsync";
|
||||||
|
|
||||||
|
ports {
|
||||||
|
#address-cells = <1>;
|
||||||
|
#size-cells = <0>;
|
||||||
|
|
||||||
|
port@0 {
|
||||||
|
reg = <0>;
|
||||||
|
endpoint {
|
||||||
|
remote-endpoint = <&dsi0_in>;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
...
|
Loading…
Reference in New Issue
Block a user