1// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
2/*
3 * Copyright (c) 2022 Rockchip Electronics Co., Ltd.
4 *
5 */
6
7/dts-v1/;
8
9#include "rk3399-evb-rev3.dtsi"
10#include "rk3399-android.dtsi"
11
12/ {
13	model = "Rockchip RK3399 Evaluation Board v3 (Android)";
14	compatible = "rockchip,android", "rockchip,rk3399-evb-rev3", "rockchip,rk3399";
15
16	edp_panel: edp-panel {
17		compatible = "lg,lp079qx1-sp0v", "panel-simple";
18		backlight = <&backlight1>;
19		power-supply = <&vcc3v3_s0>;
20
21		ports {
22			panel_in_edp: endpoint {
23				remote-endpoint = <&edp_out_panel>;
24			};
25		};
26
27		disp_timings: display-timings {
28			native-mode = <&F402>;
29
30			F402: timing0 {
31				clock-frequency = <200000000>;
32				hactive = <1536>;
33				vactive = <2048>;
34				hfront-porch = <12>;
35				hsync-len = <16>;
36				hback-porch = <48>;
37				vfront-porch = <8>;
38				vsync-len = <4>;
39				vback-porch = <8>;
40				hsync-active = <0>;
41				vsync-active = <0>;
42				de-active = <0>;
43				pixelclk-active = <0>;
44			};
45		};
46	};
47
48	backlight1: backlight1 {
49		compatible = "pwm-backlight";
50		pwms = <&pwm1 0 25000 0>;
51		brightness-levels = <
52			  0   1   2   3   4   5   6   7
53			  8   9  10  11  12  13  14  15
54			 16  17  18  19  20  21  22  23
55			 24  25  26  27  28  29  30  31
56			 32  33  34  35  36  37  38  39
57			 40  41  42  43  44  45  46  47
58			 48  49  50  51  52  53  54  55
59			 56  57  58  59  60  61  62  63
60			 64  65  66  67  68  69  70  71
61			 72  73  74  75  76  77  78  79
62			 80  81  82  83  84  85  86  87
63			 88  89  90  91  92  93  94  95
64			 96  97  98  99 100 101 102 103
65			104 105 106 107 108 109 110 111
66			112 113 114 115 116 117 118 119
67			120 121 122 123 124 125 126 127
68			128 129 130 131 132 133 134 135
69			136 137 138 139 140 141 142 143
70			144 145 146 147 148 149 150 151
71			152 153 154 155 156 157 158 159
72			160 161 162 163 164 165 166 167
73			168 169 170 171 172 173 174 175
74			176 177 178 179 180 181 182 183
75			184 185 186 187 188 189 190 191
76			192 193 194 195 196 197 198 199
77			200 201 202 203 204 205 206 207
78			208 209 210 211 212 213 214 215
79			216 217 218 219 220 221 222 223
80			224 225 226 227 228 229 230 231
81			232 233 234 235 236 237 238 239
82			240 241 242 243 244 245 246 247
83			248 249 250 251 252 253 254 255>;
84		default-brightness-level = <200>;
85	};
86};
87
88&pwm1 {
89	status = "okay";
90};
91
92&backlight1 {
93	status = "okay";
94};
95
96&dsi_in_vopl {
97	status = "disabled";
98};
99
100&dsi_in_vopb {
101	status = "okay";
102};
103
104&edp_in_vopl {
105	status = "okay";
106};
107
108&edp_in_vopb {
109	status = "disabled";
110};
111
112&dsi {
113	status = "okay";
114
115	panel@0 {
116		compatible ="simple-panel-dsi";
117		reg = <0>;
118		backlight = <&backlight>;
119		enable-gpios = <&gpio1 13 GPIO_ACTIVE_HIGH>;
120
121		dsi,flags = <(MIPI_DSI_MODE_VIDEO | MIPI_DSI_MODE_VIDEO_BURST)>;
122		dsi,format = <MIPI_DSI_FMT_RGB888>;
123		dsi,lanes = <4>;
124
125		display-timings {
126			native-mode = <&timing0>;
127
128			timing0: timing0 {
129				clock-frequency = <160000000>;
130				hactive = <1200>;
131				vactive = <1920>;
132				hback-porch = <21>;
133				hfront-porch = <120>;
134				vback-porch = <18>;
135				vfront-porch = <21>;
136				hsync-len = <20>;
137				vsync-len = <3>;
138				hsync-active = <0>;
139				vsync-active = <0>;
140				de-active = <0>;
141				pixelclk-active = <0>;
142			};
143		};
144
145		dsp_lut: dsp-lut {
146			gamma-lut = <
147			0x00000000 0x00010101 0x00020202 0x00030303 0x00040404 0x00050505 0x00060606 0x00070707
148			0x00080808 0x00090909 0x000a0a0a 0x000b0b0b 0x000c0c0c 0x000d0d0d 0x000e0e0e 0x000f0f0f
149			0x00101010 0x00111111 0x00121212 0x00131313 0x00141414 0x00151515 0x00161616 0x00171717
150			0x00181818 0x00191919 0x001a1a1a 0x001b1b1b 0x001c1c1c 0x001d1d1d 0x001e1e1e 0x001f1f1f
151			0x00202020 0x00212121 0x00222222 0x00232323 0x00242424 0x00252525 0x00262626 0x00272727
152			0x00282828 0x00292929 0x002a2a2a 0x002b2b2b 0x002c2c2c 0x002d2d2d 0x002e2e2e 0x002f2f2f
153			0x00303030 0x00313131 0x00323232 0x00333333 0x00343434 0x00353535 0x00363636 0x00373737
154			0x00383838 0x00393939 0x003a3a3a 0x003b3b3b 0x003c3c3c 0x003d3d3d 0x003e3e3e 0x003f3f3f
155			0x00404040 0x00414141 0x00424242 0x00434343 0x00444444 0x00454545 0x00464646 0x00474747
156			0x00484848 0x00494949 0x004a4a4a 0x004b4b4b 0x004c4c4c 0x004d4d4d 0x004e4e4e 0x004f4f4f
157			0x00505050 0x00515151 0x00525252 0x00535353 0x00545454 0x00555555 0x00565656 0x00575757
158			0x00585858 0x00595959 0x005a5a5a 0x005b5b5b 0x005c5c5c 0x005d5d5d 0x005e5e5e 0x005f5f5f
159			0x00606060 0x00616161 0x00626262 0x00636363 0x00646464 0x00656565 0x00666666 0x00676767
160			0x00686868 0x00696969 0x006a6a6a 0x006b6b6b 0x006c6c6c 0x006d6d6d 0x006e6e6e 0x006f6f6f
161			0x00707070 0x00717171 0x00727272 0x00737373 0x00747474 0x00757575 0x00767676 0x00777777
162			0x00787878 0x00797979 0x007a7a7a 0x007b7b7b 0x007c7c7c 0x007d7d7d 0x007e7e7e 0x007f7f7f
163			0x00808080 0x00818181 0x00828282 0x00838383 0x00848484 0x00858585 0x00868686 0x00878787
164			0x00888888 0x00898989 0x008a8a8a 0x008b8b8b 0x008c8c8c 0x008d8d8d 0x008e8e8e 0x008f8f8f
165			0x00909090 0x00919191 0x00929292 0x00939393 0x00949494 0x00959595 0x00969696 0x00979797
166			0x00989898 0x00999999 0x009a9a9a 0x009b9b9b 0x009c9c9c 0x009d9d9d 0x009e9e9e 0x009f9f9f
167			0x00a0a0a0 0x00a1a1a1 0x00a2a2a2 0x00a3a3a3 0x00a4a4a4 0x00a5a5a5 0x00a6a6a6 0x00a7a7a7
168			0x00a8a8a8 0x00a9a9a9 0x00aaaaaa 0x00ababab 0x00acacac 0x00adadad 0x00aeaeae 0x00afafaf
169			0x00b0b0b0 0x00b1b1b1 0x00b2b2b2 0x00b3b3b3 0x00b4b4b4 0x00b5b5b5 0x00b6b6b6 0x00b7b7b7
170			0x00b8b8b8 0x00b9b9b9 0x00bababa 0x00bbbbbb 0x00bcbcbc 0x00bdbdbd 0x00bebebe 0x00bfbfbf
171			0x00c0c0c0 0x00c1c1c1 0x00c2c2c2 0x00c3c3c3 0x00c4c4c4 0x00c5c5c5 0x00c6c6c6 0x00c7c7c7
172			0x00c8c8c8 0x00c9c9c9 0x00cacaca 0x00cbcbcb 0x00cccccc 0x00cdcdcd 0x00cecece 0x00cfcfcf
173			0x00d0d0d0 0x00d1d1d1 0x00d2d2d2 0x00d3d3d3 0x00d4d4d4 0x00d5d5d5 0x00d6d6d6 0x00d7d7d7
174			0x00d8d8d8 0x00d9d9d9 0x00dadada 0x00dbdbdb 0x00dcdcdc 0x00dddddd 0x00dedede 0x00dfdfdf
175			0x00e0e0e0 0x00e1e1e1 0x00e2e2e2 0x00e3e3e3 0x00e4e4e4 0x00e5e5e5 0x00e6e6e6 0x00e7e7e7
176			0x00e8e8e8 0x00e9e9e9 0x00eaeaea 0x00ebebeb 0x00ececec 0x00ededed 0x00eeeeee 0x00efefef
177			0x00f0f0f0 0x00f1f1f1 0x00f2f2f2 0x00f3f3f3 0x00f4f4f4 0x00f5f5f5 0x00f6f6f6 0x00f7f7f7
178			0x00f8f8f8 0x00f9f9f9 0x00fafafa 0x00fbfbfb 0x00fcfcfc 0x00fdfdfd 0x00fefefe 0x00ffffff>;
179		};
180
181		ports {
182			#address-cells = <1>;
183			#size-cells = <0>;
184
185			port@0 {
186				reg = <0>;
187				panel_in_dsi: endpoint {
188					remote-endpoint = <&dsi_out_panel>;
189				};
190			};
191		};
192	};
193
194	ports {
195		#address-cells = <1>;
196		#size-cells = <0>;
197
198		port@1 {
199			reg = <1>;
200			dsi_out_panel: endpoint {
201				remote-endpoint = <&panel_in_dsi>;
202			};
203		};
204	};
205};
206
207&cdn_dp {
208	extcon = <&fusb0>, <&fusb1>;
209	status = "okay";
210};
211
212&route_dsi {
213	status = "okay";
214	connect = <&vopb_out_dsi>;
215};
216
217&edp {
218	status = "okay";
219	pinctrl-names = "default";
220	pinctrl-0 = <&edp_hpd>;
221
222	ports {
223		edp_out: port@1 {
224			reg = <1>;
225			#address-cells = <1>;
226			#size-cells = <0>;
227
228			edp_out_panel: endpoint@0 {
229				reg = <0>;
230				remote-endpoint = <&panel_in_edp>;
231			};
232		};
233	};
234};
235
236&route_edp {
237	status = "okay";
238	connect = <&vopl_out_edp>;
239};
240
241&firmware_android {
242	compatible = "android,firmware";
243	fstab {
244		compatible = "android,fstab";
245		system {
246			compatible = "android,system";
247			dev = "/dev/block/by-name/system";
248			type = "ext4";
249			mnt_flags = "ro,barrier=1,inode_readahead_blks=8";
250			fsmgr_flags = "wait,verify";
251		};
252		vendor {
253			compatible = "android,vendor";
254			dev = "/dev/block/by-name/vendor";
255			type = "ext4";
256			mnt_flags = "ro,barrier=1,inode_readahead_blks=8";
257			fsmgr_flags = "wait,verify";
258		};
259	};
260};
261
262&gt9xx {
263	status = "disabled";
264};
265