2014-01-21 09:12:12 +00:00
|
|
|
Texas Instruments OMAP Display Subsystem
|
|
|
|
========================================
|
|
|
|
|
|
|
|
Generic Description
|
|
|
|
-------------------
|
|
|
|
|
|
|
|
This document is a generic description of the OMAP Display Subsystem bindings.
|
|
|
|
Binding details for each OMAP SoC version are described in respective binding
|
|
|
|
documentation.
|
|
|
|
|
|
|
|
The OMAP Display Subsystem (DSS) hardware consists of DSS Core, DISPC module and
|
|
|
|
a number of encoder modules. All DSS versions contain DSS Core and DISPC, but
|
|
|
|
the encoder modules vary.
|
|
|
|
|
|
|
|
The DSS Core is the parent of the other DSS modules, and manages clock routing,
|
|
|
|
integration to the SoC, etc.
|
|
|
|
|
|
|
|
DISPC is the display controller, which reads pixels from the memory and outputs
|
|
|
|
a RGB pixel stream to encoders.
|
|
|
|
|
|
|
|
The encoder modules encode the received RGB pixel stream to a video output like
|
|
|
|
HDMI, MIPI DPI, etc.
|
|
|
|
|
|
|
|
Video Ports
|
|
|
|
-----------
|
|
|
|
|
|
|
|
The DSS Core and the encoders have video port outputs. The structure of the
|
2015-03-07 16:08:03 +00:00
|
|
|
video ports is described in Documentation/devicetree/bindings/graph.txt,
|
|
|
|
and the properties for the ports and endpoints for each encoder are
|
2014-01-21 09:12:12 +00:00
|
|
|
described in the SoC's DSS binding documentation.
|
|
|
|
|
|
|
|
The video ports are used to describe the connections to external hardware, like
|
|
|
|
panels or external encoders.
|
|
|
|
|
|
|
|
Aliases
|
|
|
|
-------
|
|
|
|
|
|
|
|
The board dts file may define aliases for displays to assign "displayX" style
|
|
|
|
name for each display. If no aliases are defined, a semi-random number is used
|
|
|
|
for the display.
|
|
|
|
|
|
|
|
Example
|
|
|
|
-------
|
|
|
|
|
|
|
|
A shortened example of the DSS description for OMAP4, with non-relevant parts
|
|
|
|
removed, defined in omap4.dtsi:
|
|
|
|
|
|
|
|
dss: dss@58000000 {
|
|
|
|
compatible = "ti,omap4-dss";
|
|
|
|
reg = <0x58000000 0x80>;
|
|
|
|
status = "disabled";
|
|
|
|
ti,hwmods = "dss_core";
|
|
|
|
clocks = <&dss_dss_clk>;
|
|
|
|
clock-names = "fck";
|
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <1>;
|
|
|
|
ranges;
|
|
|
|
|
|
|
|
dispc@58001000 {
|
|
|
|
compatible = "ti,omap4-dispc";
|
|
|
|
reg = <0x58001000 0x1000>;
|
|
|
|
interrupts = <GIC_SPI 25 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
ti,hwmods = "dss_dispc";
|
|
|
|
clocks = <&dss_dss_clk>;
|
|
|
|
clock-names = "fck";
|
|
|
|
};
|
|
|
|
|
|
|
|
hdmi: encoder@58006000 {
|
|
|
|
compatible = "ti,omap4-hdmi";
|
|
|
|
reg = <0x58006000 0x200>,
|
|
|
|
<0x58006200 0x100>,
|
|
|
|
<0x58006300 0x100>,
|
|
|
|
<0x58006400 0x1000>;
|
|
|
|
reg-names = "wp", "pll", "phy", "core";
|
|
|
|
interrupts = <GIC_SPI 101 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
status = "disabled";
|
|
|
|
ti,hwmods = "dss_hdmi";
|
|
|
|
clocks = <&dss_48mhz_clk>, <&dss_sys_clk>;
|
|
|
|
clock-names = "fck", "sys_clk";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
A shortened example of the board description for OMAP4 Panda board, defined in
|
|
|
|
omap4-panda.dts.
|
|
|
|
|
|
|
|
The Panda board has a DVI and a HDMI connector, and the board contains a TFP410
|
|
|
|
chip (MIPI DPI to DVI encoder) and a TPD12S015 chip (HDMI ESD protection & level
|
|
|
|
shifter). The video pipelines for the connectors are formed as follows:
|
|
|
|
|
|
|
|
DSS Core --(MIPI DPI)--> TFP410 --(DVI)--> DVI Connector
|
|
|
|
OMAP HDMI --(HDMI)--> TPD12S015 --(HDMI)--> HDMI Connector
|
|
|
|
|
|
|
|
/ {
|
|
|
|
aliases {
|
|
|
|
display0 = &dvi0;
|
|
|
|
display1 = &hdmi0;
|
|
|
|
};
|
|
|
|
|
|
|
|
tfp410: encoder@0 {
|
|
|
|
compatible = "ti,tfp410";
|
|
|
|
gpios = <&gpio1 0 GPIO_ACTIVE_LOW>; /* 0, power-down */
|
|
|
|
|
|
|
|
pinctrl-names = "default";
|
|
|
|
pinctrl-0 = <&tfp410_pins>;
|
|
|
|
|
|
|
|
ports {
|
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <0>;
|
|
|
|
|
|
|
|
port@0 {
|
|
|
|
reg = <0>;
|
|
|
|
|
|
|
|
tfp410_in: endpoint@0 {
|
|
|
|
remote-endpoint = <&dpi_out>;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
port@1 {
|
|
|
|
reg = <1>;
|
|
|
|
|
|
|
|
tfp410_out: endpoint@0 {
|
|
|
|
remote-endpoint = <&dvi_connector_in>;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
dvi0: connector@0 {
|
|
|
|
compatible = "dvi-connector";
|
|
|
|
label = "dvi";
|
|
|
|
|
|
|
|
i2c-bus = <&i2c3>;
|
|
|
|
|
|
|
|
port {
|
|
|
|
dvi_connector_in: endpoint {
|
|
|
|
remote-endpoint = <&tfp410_out>;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
tpd12s015: encoder@1 {
|
|
|
|
compatible = "ti,tpd12s015";
|
|
|
|
|
|
|
|
pinctrl-names = "default";
|
|
|
|
pinctrl-0 = <&tpd12s015_pins>;
|
|
|
|
|
|
|
|
gpios = <&gpio2 28 GPIO_ACTIVE_HIGH>, /* 60, CT CP HPD */
|
|
|
|
<&gpio2 9 GPIO_ACTIVE_HIGH>, /* 41, LS OE */
|
|
|
|
<&gpio2 31 GPIO_ACTIVE_HIGH>; /* 63, HPD */
|
|
|
|
|
|
|
|
ports {
|
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <0>;
|
|
|
|
|
|
|
|
port@0 {
|
|
|
|
reg = <0>;
|
|
|
|
|
|
|
|
tpd12s015_in: endpoint@0 {
|
|
|
|
remote-endpoint = <&hdmi_out>;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
port@1 {
|
|
|
|
reg = <1>;
|
|
|
|
|
|
|
|
tpd12s015_out: endpoint@0 {
|
|
|
|
remote-endpoint = <&hdmi_connector_in>;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
hdmi0: connector@1 {
|
|
|
|
compatible = "hdmi-connector";
|
|
|
|
label = "hdmi";
|
|
|
|
|
|
|
|
port {
|
|
|
|
hdmi_connector_in: endpoint {
|
|
|
|
remote-endpoint = <&tpd12s015_out>;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
&dss {
|
|
|
|
status = "ok";
|
|
|
|
|
|
|
|
pinctrl-names = "default";
|
|
|
|
pinctrl-0 = <&dss_dpi_pins>;
|
|
|
|
|
|
|
|
port {
|
|
|
|
dpi_out: endpoint {
|
|
|
|
remote-endpoint = <&tfp410_in>;
|
|
|
|
data-lines = <24>;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
&hdmi {
|
|
|
|
status = "ok";
|
|
|
|
vdda-supply = <&vdac>;
|
|
|
|
|
|
|
|
pinctrl-names = "default";
|
|
|
|
pinctrl-0 = <&dss_hdmi_pins>;
|
|
|
|
|
|
|
|
port {
|
|
|
|
hdmi_out: endpoint {
|
|
|
|
remote-endpoint = <&tpd12s015_in>;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|