blob: aaf494c23951e54a73a4dd7c7eabfc0b56301072 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
|
// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
/*
* Copyright 2025 Uros Majstorovic
*/
// adapted from: https://git.toradex.com/cgit/device-tree-overlays.git/tree/overlays/verdin-imx8mp_panel-cap-touch-10inch-lvds_overlay.dts?h=toradex_6.6-2.2.x-imx
// Verdin iMX8M Plus single-channel LVDS
/dts-v1/;
/plugin/;
#include <dt-bindings/gpio/gpio.h>
#include <dt-bindings/interrupt-controller/irq.h>
#include <dt-bindings/pwm/pwm.h>
#include "freescale/imx8mp-pinfunc.h"
/ {
compatible = "toradex,verdin-imx8mp";
};
&{/} {
backlight_lvds: backlight-lvds {
compatible = "pwm-backlight";
pinctrl-names = "default";
brightness-levels = <0 45 63 88 119 158 203 255>;
default-brightness-level = <0>;
/* Verdin PWM_1 (SODIMM 15) */
pwms = <&pwm1 0 6666667 0>;
};
lvds0_panel: panel-lvds-focuslcds {
compatible = "panel-lvds";
backlight = <&backlight_lvds>;
data-mapping = "vesa-24";
width-mm = <62>;
height-mm = <110>;
panel-timing {
clock-frequency = <26250000>;
hfront-porch = <8>;
hsync-len = <4>;
hback-porch = <8>;
hactive = <480>;
vfront-porch = <7>;
vsync-len = <7>;
vback-porch = <7>;
vactive = <854>;
hsync-active = <0>;
vsync-active = <0>;
de-active = <1>;
// pixelclk-active = <0>;
};
port {
panel_lvds_in: endpoint {
remote-endpoint = <&lvds_out>;
};
};
};
dmux {
compatible = "mikrophone,dmux";
dmux-gpio = <&gpio1 1 0>;
ctp-dev-name = "3-005d";
status = "okay";
};
};
/* Verdin I2C_1 */
&i2c4 {
#address-cells = <1>;
#size-cells = <0>;
status = "okay";
gt911@5d {
compatible = "goodix,gt911";
reg = <0x5d>;
interrupts = <5 IRQ_TYPE_LEVEL_LOW>;
interrupt-parent = <&gpio1>;
irq-gpio = <&gpio1 5 0>;
reset-gpio = <&gpio1 6 0>;
defer-init;
status = "okay";
};
};
&lcdif2 {
status = "okay";
};
&ldb {
#address-cells = <1>;
#size-cells = <0>;
status = "okay";
lvds-channel@0 {
#address-cells = <1>;
#size-cells = <0>;
reg = <0>;
fsl,data-mapping = "spwg";
fsl,data-width = <24>;
status = "okay";
port@1 {
reg = <1>;
lvds_out: endpoint {
remote-endpoint = <&panel_lvds_in>;
};
};
};
};
&ldb_phy {
status = "okay";
};
&pwm1 {
status = "okay";
};
/*
&media_blk_ctrl {
assigned-clock-rates = <500000000>, <200000000>,
<0>, <0>, <183750000>;
};
*/
|