162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0
262306a36Sopenharmony_ci//
362306a36Sopenharmony_ci// Copyright (C) 2019 Logic PD, Inc.
462306a36Sopenharmony_ci
562306a36Sopenharmony_ci/dts-v1/;
662306a36Sopenharmony_ci#include "imx6q.dtsi"
762306a36Sopenharmony_ci#include "imx6-logicpd-som.dtsi"
862306a36Sopenharmony_ci#include "imx6-logicpd-baseboard.dtsi"
962306a36Sopenharmony_ci
1062306a36Sopenharmony_ci/ {
1162306a36Sopenharmony_ci	model = "Logic PD i.MX6QD SOM-M3";
1262306a36Sopenharmony_ci	compatible = "logicpd,imx6q-logicpd", "fsl,imx6q";
1362306a36Sopenharmony_ci
1462306a36Sopenharmony_ci	backlight: backlight-lvds {
1562306a36Sopenharmony_ci		compatible = "pwm-backlight";
1662306a36Sopenharmony_ci		pwms = <&pwm3 0 20000 0>;
1762306a36Sopenharmony_ci		brightness-levels = <0 4 8 16 32 64 128 255>;
1862306a36Sopenharmony_ci		default-brightness-level = <6>;
1962306a36Sopenharmony_ci		power-supply = <&reg_lcd>;
2062306a36Sopenharmony_ci	};
2162306a36Sopenharmony_ci
2262306a36Sopenharmony_ci	panel-lvds0 {
2362306a36Sopenharmony_ci		compatible = "okaya,rs800480t-7x0gp";
2462306a36Sopenharmony_ci		power-supply = <&reg_lcd_reset>;
2562306a36Sopenharmony_ci		backlight = <&backlight>;
2662306a36Sopenharmony_ci
2762306a36Sopenharmony_ci		port {
2862306a36Sopenharmony_ci			panel_in_lvds0: endpoint {
2962306a36Sopenharmony_ci				remote-endpoint = <&lvds0_out>;
3062306a36Sopenharmony_ci			};
3162306a36Sopenharmony_ci		};
3262306a36Sopenharmony_ci	};
3362306a36Sopenharmony_ci
3462306a36Sopenharmony_ci	reg_lcd: regulator-lcd {
3562306a36Sopenharmony_ci		pinctrl-names = "default";
3662306a36Sopenharmony_ci		pinctrl-0 = <&pinctrl_lcd_reg>;
3762306a36Sopenharmony_ci		compatible = "regulator-fixed";
3862306a36Sopenharmony_ci		regulator-name = "lcd_panel_pwr";
3962306a36Sopenharmony_ci		regulator-min-microvolt = <3300000>;
4062306a36Sopenharmony_ci		regulator-max-microvolt = <3300000>;
4162306a36Sopenharmony_ci		gpio = <&gpio4 17 GPIO_ACTIVE_HIGH>;
4262306a36Sopenharmony_ci		enable-active-high;
4362306a36Sopenharmony_ci		vin-supply = <&reg_3v3>;
4462306a36Sopenharmony_ci		startup-delay-us = <500000>;
4562306a36Sopenharmony_ci	};
4662306a36Sopenharmony_ci
4762306a36Sopenharmony_ci	reg_lcd_reset: regulator-lcd-reset {
4862306a36Sopenharmony_ci		pinctrl-names = "default";
4962306a36Sopenharmony_ci		pinctrl-0 = <&pinctrl_lcd_reset>;
5062306a36Sopenharmony_ci		compatible = "regulator-fixed";
5162306a36Sopenharmony_ci		regulator-name = "nLCD_RESET";
5262306a36Sopenharmony_ci		regulator-min-microvolt = <3300000>;
5362306a36Sopenharmony_ci		regulator-max-microvolt = <3300000>;
5462306a36Sopenharmony_ci		gpio = <&gpio5 2 GPIO_ACTIVE_HIGH>;
5562306a36Sopenharmony_ci		enable-active-high;
5662306a36Sopenharmony_ci		vin-supply = <&reg_lcd>;
5762306a36Sopenharmony_ci	};
5862306a36Sopenharmony_ci};
5962306a36Sopenharmony_ci
6062306a36Sopenharmony_ci&clks {
6162306a36Sopenharmony_ci	assigned-clocks = <&clks IMX6QDL_CLK_LDB_DI0_SEL>,
6262306a36Sopenharmony_ci			  <&clks IMX6QDL_CLK_LDB_DI1_SEL>,
6362306a36Sopenharmony_ci			  <&clks IMX6QDL_CLK_IPU1_DI0_PRE_SEL>,
6462306a36Sopenharmony_ci			  <&clks IMX6QDL_CLK_IPU2_DI0_PRE_SEL>;
6562306a36Sopenharmony_ci	assigned-clock-parents = <&clks IMX6QDL_CLK_PLL5_VIDEO_DIV>,
6662306a36Sopenharmony_ci				 <&clks IMX6QDL_CLK_PLL5_VIDEO_DIV>,
6762306a36Sopenharmony_ci				 <&clks IMX6QDL_CLK_PLL2_PFD2_396M>,
6862306a36Sopenharmony_ci				 <&clks IMX6QDL_CLK_PLL2_PFD2_396M>;
6962306a36Sopenharmony_ci};
7062306a36Sopenharmony_ci
7162306a36Sopenharmony_ci&hdmi {
7262306a36Sopenharmony_ci	ddc-i2c-bus = <&i2c3>;
7362306a36Sopenharmony_ci	status = "okay";
7462306a36Sopenharmony_ci};
7562306a36Sopenharmony_ci
7662306a36Sopenharmony_ci&i2c1 {
7762306a36Sopenharmony_ci	touchscreen@26 {
7862306a36Sopenharmony_ci		compatible = "ilitek,ili2117";
7962306a36Sopenharmony_ci		reg = <0x26>;
8062306a36Sopenharmony_ci		pinctrl-names = "default";
8162306a36Sopenharmony_ci		pinctrl-0 = <&pinctrl_touchscreen>;
8262306a36Sopenharmony_ci		interrupts-extended = <&gpio1 6 IRQ_TYPE_EDGE_RISING>;
8362306a36Sopenharmony_ci	};
8462306a36Sopenharmony_ci};
8562306a36Sopenharmony_ci
8662306a36Sopenharmony_ci&ldb {
8762306a36Sopenharmony_ci	status = "okay";
8862306a36Sopenharmony_ci
8962306a36Sopenharmony_ci	lvds-channel@0 {
9062306a36Sopenharmony_ci		fsl,data-mapping = "spwg";
9162306a36Sopenharmony_ci		fsl,data-width = <24>;
9262306a36Sopenharmony_ci		status = "okay";
9362306a36Sopenharmony_ci
9462306a36Sopenharmony_ci		port@4 {
9562306a36Sopenharmony_ci			reg = <4>;
9662306a36Sopenharmony_ci			lvds0_out: endpoint {
9762306a36Sopenharmony_ci				remote-endpoint = <&panel_in_lvds0>;
9862306a36Sopenharmony_ci			};
9962306a36Sopenharmony_ci		};
10062306a36Sopenharmony_ci	};
10162306a36Sopenharmony_ci
10262306a36Sopenharmony_ci};
10362306a36Sopenharmony_ci
10462306a36Sopenharmony_ci&pwm3 {
10562306a36Sopenharmony_ci	status = "okay";
10662306a36Sopenharmony_ci};
10762306a36Sopenharmony_ci
10862306a36Sopenharmony_ci&reg_hdmi {
10962306a36Sopenharmony_ci	regulator-always-on;	/* Without this, the level shifter on HDMI doesn't turn on */
11062306a36Sopenharmony_ci};
11162306a36Sopenharmony_ci
11262306a36Sopenharmony_ci&iomuxc {
11362306a36Sopenharmony_ci	pinctrl_lcd_reg: lcdreg {
11462306a36Sopenharmony_ci		fsl,pins = <
11562306a36Sopenharmony_ci			MX6QDL_PAD_DI0_PIN15__GPIO4_IO17	0x100b0	/* R_LCD_PANEL_PWR */
11662306a36Sopenharmony_ci		>;
11762306a36Sopenharmony_ci	};
11862306a36Sopenharmony_ci
11962306a36Sopenharmony_ci	pinctrl_lcd_reset: lcdreset {
12062306a36Sopenharmony_ci		fsl,pins = <
12162306a36Sopenharmony_ci			MX6QDL_PAD_EIM_A25__GPIO5_IO02	0x100b0	/* LCD_nRESET */
12262306a36Sopenharmony_ci		>;
12362306a36Sopenharmony_ci	};
12462306a36Sopenharmony_ci
12562306a36Sopenharmony_ci	pinctrl_touchscreen: touchscreengrp {
12662306a36Sopenharmony_ci		fsl,pins = <
12762306a36Sopenharmony_ci			MX6QDL_PAD_GPIO_6__GPIO1_IO06	0x1b0b0	/* TOUCH_nPINTDAV */
12862306a36Sopenharmony_ci		>;
12962306a36Sopenharmony_ci	};
13062306a36Sopenharmony_ci};
131