MX8 Display: Difference between revisions

From Variscite Wiki
(Created page with "<!-- Set release according to "release" parameter in URL and use RELEASE_SUMO_V1.0_VAR-SOM-MX8X as default --> {{#vardefine:RELEASE_PARAM|{{#urlget:release}}}} <!-- --> {{#lst...")
 
No edit summary
 
(26 intermediate revisions by 5 users not shown)
Line 1: Line 1:
<!-- Set release according to "release" parameter in URL and use RELEASE_SUMO_V1.0_VAR-SOM-MX8X as default
<!-- Set release according to "release" parameter in URL and use RELEASE_SUMO_V1.0_VAR-SOM-MX8X as default
--> {{#vardefine:RELEASE_PARAM|{{#urlget:release}}}} <!--
--> {{INIT_RELEASE_PARAM|RELEASE_SUMO_V1.0_VAR-SOM-MX8X}} <!--
--> {{#lst:Yocto_Platform_Customization|{{#var:RELEASE_PARAM|RELEASE_SUMO_V1.0_VAR-SOM-MX8X}}}} <!--
--> {{#lst:Yocto_Platform_Customization|{{#var:RELEASE_PARAM}}}} <!--
--> {{PageHeader|{{#var:HARDWARE_NAME}} Display}} {{DocImage|category1=Yocto|category2=VAR-SOM-MX8X}}[[Category:VAR-SOM-MX8]]__toc__
--> {{#lst:Debian_Platform_Customization|{{#var:RELEASE_PARAM}}}} <!--
= Introduction =
--> {{PageHeader|{{#var:HARDWARE_NAME}} Display}} {{DocImage|category1=Yocto|category2=Debian}} [[Category:{{#var:HARDWARE_NAME}}]] __toc__
== LVDS  ==
{{#var:HARDWARE_NAME}} supports 2 LVDS interfaces.<br>
Variscite Symphony carrier board comes with 2 LVDS connectors, one connector per interface.<br>
By default Variscite panel is connected in LVDS#A connector.<br>


= Adding custom LVDS panel =
{{#ifeq: {{#var:HARDWARE_NAME}}|VAR-SOM-MX8|
{{#var:HARDWARE_NAME}} evaluation kit comes with 800x480 LCD panel. {{#var:HARDWARE_NAME}} DTS file was created with this panel in mind.
To support your custom LVDS panel, you should make several modifications


== Referencing custom LVDS panel in the DTS file ==
{{#varexists:DTB_PREFIX | | {{#vardefine:DTB_PREFIX|fsl-imx8qm-var-som}} }}
The following code references Variscite panel in {{#ifeq: {{#var:HARDWARE_NAME}}|VAR-SOM-MX8X|fsl-imx8qxp-var-som-common.dtsi|fsl-imx8qm-var-som.dts}} under kernel source tree
{{#varexists:DTB_PREFIX_SP8 | | {{#vardefine:DTB_PREFIX_SP8|fsl-imx8qm-var-spear}} }}
 
<!-- Create device trees for QP -->
{{#vardefine:DTB_PREFIX_QP|{{#replace:{{#var:DTB_PREFIX}}|imx8qm|imx8qp}}}}
{{#vardefine:DTB_PREFIX_SP8_QP|{{#replace:{{#var:DTB_PREFIX_SP8}}|imx8qm|imx8qp}}}}
 
= Selecting display type =
VAR-SOM-MX8 and SPEAR-MX8 support DP, HDMI and LVDS displays. To use DP and HDMI on VAR-SOM-MX8 carrier board one should attach Variscite extension boards VAR-EXT-DP and VAR-EXT-HDMI respectively.<br>
Selecting display configuration is a matter of selecting an appropriate dtb file.<br>
 
On VAR-SOM-MX8 /boot/{{#var:DTB_PREFIX}}.dtb is a symbolic link to the active dtb file. By default it points to LVDS dtb.<br>
To select HDMI display, run the following commands:
 
# cd /boot
# ln -fs {{#var:DTB_PREFIX}}-hdmi.dtb {{#var:DTB_PREFIX}}.dtb
# ln -fs {{#var:DTB_PREFIX_QP}}-hdmi.dtb {{#var:DTB_PREFIX_QP}}.dtb (For i.MX8QP SoC)
 
To select DP display, run the following commands:
 
# cd /boot
# ln -fs {{#var:DTB_PREFIX}}-dp.dtb {{#var:DTB_PREFIX}}.dtb
# ln -fs {{#var:DTB_PREFIX_QP}}-dp.dtb {{#var:DTB_PREFIX_QP}}.dtb (For i.MX8QP SoC)
 
On SPEAR-MX8 /boot/{{#var:DTB_PREFIX_SP8}}.dtb is a symbolic link to the active dtb file. By default it points to LVDS dtb.<br>
To select HDMI display, run the following commands:
 
# cd /boot
# ln -fs {{#var:DTB_PREFIX_SP8}}-hdmi.dtb {{#var:DTB_PREFIX_SP8}}.dtb
# ln -fs {{#var:DTB_PREFIX_SP8_QP}}-hdmi.dtb {{#var:DTB_PREFIX_SP8_QP}}.dtb (For i.MX8QP SoC)
 
To select DP display, run the following commands:
 
# cd /boot
# ln -fs {{#var:DTB_PREFIX_SP8}}-dp.dtb {{#var:DTB_PREFIX_SP8}}.dtb
# ln -fs {{#var:DTB_PREFIX_SP8_QP}}-dp.dtb {{#var:DTB_PREFIX_SP8_QP}}.dtb (For i.MX8QP SoC)
 
The change will be effective after reboot.<br>
 
= Loading HDMI and DP firmware =
HDMI and DP displays require appropriate firmware to be loaded by U-Boot. The firmware files are installed under /boot.<br>
The HDMI display firmware blob is hdmitxfw.bin, the DP firmware blob is dpfw.bin. U-Boot environment variable hdp_file selects the blob.<br>
By default HDMI firmware is being loaded. To switch to DP firmware, run the following command:
 
# fw_setenv hdp_file dpfw.bin
 
The change will be effective after reboot.<br>
 
{{Note|Both firmware blob and dtb file should be set before rebooting the system, otherwise the boot process will get stuck.}}
 
= Setting HDMI and DP resolution =
 
By default the maximum resolution supported by HDMI/DP display is being used.<br>
To check the current resolution, run fbset command.
<pre>
# fbset
 
mode "3840x2160"
    geometry 3840 2160 3840 2160 16
    timings 0 0 0 0 0 0 0
    accel true
    rgba 5/11,6/5,5/0,0/0
endmode
</pre>
 
To configure specific resolution use fw_setenv command to set video= kernel command line argument.<br>
For example, to set 1080P@60fps resolution on HDMI display, run the following command:
# fw_setenv kernelargs video=HDMI-A-1:1920x1080-32@60
 
To set 1080P@60fps resolution on DP display, run the following command:
# fw_setenv kernelargs video=DP-1:1920x1080-32@60
 
The settings will be effective after reboot.
}}
 
= LVDS =
{{#var:HARDWARE_NAME}} supports one dual-channel LVDS interface.<br>
{{#var:HARDWARE_NAME}} evaluation kit comes with two LVDS connectors, one connector per LVDS channel.<br>
By default Variscite panel is attached to LVDS#A connector.<br>
 
== Adding custom LVDS panel ==
{{#var:HARDWARE_NAME}} evaluation kit comes with 800x480 LVDS panel. <br>
{{#var:HARDWARE_NAME}} DTS file was created with this panel in mind. <br>
To support different LVDS panel, several modifications may be required.


{{#ifeq: {{#var:HARDWARE_NAME}}|VAR-SOM-MX8X|
{{#ifeq: {{#var:HARDWARE_NAME}}|VAR-SOM-MX8X|
The following code configures LVDS panel in arch/arm64/boot/dts/freescale/fsl-imx8qxp-var-som-common.dtsi under kernel source tree:
<pre>
<pre>
&ldb1_phy {
&ldb1_phy {
Line 50: Line 129:
</pre>
</pre>
|
|
On VAR-SOM-MX8 LVDS panel is configured in arch/arm64/boot/dts/freescale/{{#var:DTB_PREFIX}}-lvds.dtsi <br>
On SPEAR-MX8 LVDS panel is configured in arch/arm64/boot/dts/freescale/{{#var:DTB_PREFIX_SP8}}-lvds.dtsi
<pre>
<pre>
&ldb1_phy {
&ldb1_phy {
Line 86: Line 167:
You may need to modify "fsl,data-mapping", "fsl,data-width" and "display-timings" properties to match your panel specification.<br>
You may need to modify "fsl,data-mapping", "fsl,data-width" and "display-timings" properties to match your panel specification.<br>
For more information see Documentation/devicetree/bindings/display/imx/ldb.txt in the kernel source tree.
For more information see Documentation/devicetree/bindings/display/imx/ldb.txt in the kernel source tree.
= Setting Weston Desktop Resolution =
The default Weston uses maximum resolution supported by display.<br>
To modify Weston resolution, edit /etc/xdg/weston/weston.ini and set size parameter in shell section.<br>
For example:
[shell]
size=3840x2160
For new settings to take effect restart weston by running
# systemctl restart weston
= Rotating the Weston display =
{{WESTON_DISPLAY_ROTATE}}

Latest revision as of 21:47, 26 September 2024

Warning: This page is designed to be used with a 'release' URL parameter.

This page is using the default release RELEASE_SUMO_V1.0_VAR-SOM-MX8X.
To view this page for a specific Variscite SoM and software release, please follow these steps:

  1. Visit variwiki.com
  2. Select your SoM
  3. Select the software release
VAR-SOM-MX8X Display


LVDS

VAR-SOM-MX8X supports one dual-channel LVDS interface.
VAR-SOM-MX8X evaluation kit comes with two LVDS connectors, one connector per LVDS channel.
By default Variscite panel is attached to LVDS#A connector.

Adding custom LVDS panel

VAR-SOM-MX8X evaluation kit comes with 800x480 LVDS panel.
VAR-SOM-MX8X DTS file was created with this panel in mind.
To support different LVDS panel, several modifications may be required.

The following code configures LVDS panel in arch/arm64/boot/dts/freescale/fsl-imx8qxp-var-som-common.dtsi under kernel source tree:

&ldb1_phy {
	status = "ok";
};

&ldb1 {
	status = "ok";
	lvds-channel@0 {
		fsl,data-mapping = "jeida";
		fsl,data-width = <24>;
		status = "ok";

		display-timings {
			lvds {
				clock-frequency = <29232000>;
				hactive = <800>;
				vactive = <480>;
				hback-porch = <40>;
				hfront-porch = <40>;
				vback-porch = <29>;
				vfront-porch = <13>;
				hsync-len = <48>;
				vsync-len = <3>;
				hsync-active = <0>;
				vsync-active = <0>;
				de-active = <1>;
				pixelclk-active = <0>;
			};
		};
	};
};

You may need to modify "fsl,data-mapping", "fsl,data-width" and "display-timings" properties to match your panel specification.
For more information see Documentation/devicetree/bindings/display/imx/ldb.txt in the kernel source tree.

Setting Weston Desktop Resolution

The default Weston uses maximum resolution supported by display.
To modify Weston resolution, edit /etc/xdg/weston/weston.ini and set size parameter in shell section.
For example:

[shell]
size=3840x2160

For new settings to take effect restart weston by running

# systemctl restart weston


Rotating the Weston display

To rotate the Weston display, edit /etc/xdg/weston/weston.ini.

For example, rotate the display 90 degrees:

[output]
name=DSI-1
transform=90

For more information, see the weston man pages: