I am used example from the arch/arm64/boot/dts/tegra210-p3448-0000-p3449-0000-b00-hdmi-dsi.dts
/ {
nvidia,dtsfilename = __FILE__;
host1x {
/* DSI mapped to tegradc.1 */
dc@54240000 {
status = "okay";
nvidia,dc-or-node = "/host1x/dsi";
nvidia,dc-connector = <&dsi>;
/* DSI supplies */
avdd_dsi_csi-supply = <&max77620_sd3>;
avdd_lcd-supply = <&battery_reg>;
dvdd_lcd-supply = <&battery_reg>;
vdd_lcd_bl_en-supply = <&battery_reg>;
vdd_lcd_bl-supply = <&battery_reg>;
};
dsi {
nvidia,dsi-controller-vs = <DSI_VS_1>;
status = "okay";
nvidia,active-panel = <&panel_a_wxga_8_0>;
nvidia,dsi-csi-loopback;
panel-a-wxga-8-0 {
status = "okay";
/* Only 2 lanes used on Porg */
nvidia,dsi-n-data-lanes = <2>;
};
};
};
backlight {
compatible = "pwm-backlight";
status = "okay";
panel-a-wxga-8-0-bl {
status = "okay";
pwms = <&tegra_pwm 0 40161>;
};
};
};
Also, this is my panel-a-wxga-8-0.dtsi
#include <dt-bindings/display/tegra-dc.h>
#include <dt-bindings/display/tegra-panel.h>
/ {
host1x {
dsi {
panel_a_wxga_8_0: panel-a-wxga-8-0 {
status = "disabled";
compatible = "a,wxga-8-0";
nvidia,dsi-instance = <DSI_INSTANCE_0>;
nvidia,dsi-n-data-lanes = <2>;
nvidia,dsi-pixel-format = <TEGRA_DSI_PIXEL_FORMAT_24BIT_P>;
nvidia,dsi-refresh-rate = <60>;
nvidia,dsi-video-data-type = <TEGRA_DSI_VIDEO_TYPE_VIDEO_MODE>;
nvidia,dsi-video-clock-mode = <TEGRA_DSI_VIDEO_CLOCK_CONTINUOUS>;
nvidia,dsi-video-burst-mode = <TEGRA_DSI_VIDEO_NONE_BURST_MODE>;
nvidia,dsi-virtual-channel = <TEGRA_DSI_VIRTUAL_CHANNEL_0>;
nvidia,dsi-panel-reset = <TEGRA_DSI_ENABLE>;
nvidia,dsi-power-saving-suspend = <TEGRA_DSI_ENABLE>;
nvidia,dsi-ulpm-not-support = <TEGRA_DSI_ENABLE>;
/*
nvidia,dsi-init-cmd = <TEGRA_DSI_PACKET_VIDEO_VBLANK_CMD DSI_GENERIC_LONG_WRITE 0x3 0x0 0x0 0xf0 0x5a 0x5a 0x0 0x0>,
<TEGRA_DSI_DELAY_MS 5>,
<TEGRA_DSI_PACKET_VIDEO_VBLANK_CMD DSI_DCS_WRITE_0_PARAM DSI_DCS_EXIT_SLEEP_MODE 0x0 0x0 CMD_NOT_CLUBBED>,
<TEGRA_DSI_DELAY_MS 5>,
<TEGRA_DSI_PACKET_VIDEO_VBLANK_CMD DSI_DCS_WRITE_0_PARAM DSI_DCS_SET_DISPLAY_ON 0x0 0x0 CMD_NOT_CLUBBED>,
<TEGRA_DSI_DELAY_MS 10>,
<TEGRA_DSI_PACKET_VIDEO_VBLANK_CMD DSI_GENERIC_LONG_WRITE 0x4 0x0 0x0 0xc3 0x40 0x00 0x28 0x0 0x0>,
<TEGRA_DSI_DELAY_MS 170>;
*/
nvidia,dsi-init-cmd = <TEGRA_DSI_PACKET_CMD DSI_DCS_LONG_WRITE 0xFF 0x77 0x01 0x00 0x00 0x13>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_WRITE_1_PARAM 0xEF 0x08 0x00>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_LONG_WRITE 0xFF 0x77 0x01 0x00 0x00 0x10>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_LONG_WRITE 0xC0 0x3B 0x00>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_LONG_WRITE 0xC1 0x10 0x0C>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_LONG_WRITE 0xC2 0x07 0x0A>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_WRITE_1_PARAM 0xC7 0x00 0x00>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_WRITE_1_PARAM 0xCC 0x10 0x00>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_LONG_WRITE 0xB0 0x05 0x12 0x98 0x0E 0x0F 0x07 0x07 0x09 0x09 0x23 0x05 0x52 0x0F 0x67 0x2C 0x11>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_LONG_WRITE 0xB1 0x0B 0x11 0x97 0x0C 0x12 0x06 0x06 0x08 0x08 0x22 0x03 0x51 0x11 0x66 0x2B 0x0F>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_LONG_WRITE 0xFF 0x77 0x01 0x00 0x00 0x11>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_WRITE_1_PARAM 0xB0 0x5D 0x00>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_WRITE_1_PARAM 0xB1 0x35 0x00>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_WRITE_1_PARAM 0xB2 0x81 0x00>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_WRITE_1_PARAM 0xB3 0x80 0x00>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_WRITE_1_PARAM 0xB5 0x4E 0x00>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_WRITE_1_PARAM 0xB7 0x85 0x00>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_WRITE_1_PARAM 0xB8 0x20 0x00>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_WRITE_1_PARAM 0xC1 0x78 0x00>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_WRITE_1_PARAM 0xC2 0x78 0x00>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_WRITE_1_PARAM 0xD0 0x88 0x00>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_LONG_WRITE 0xE0 0x00 0x00 0x02>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_LONG_WRITE 0xE1 0x06 0x30 0x08 0x30 0x05 0x30 0x07 0x30 0x00 0x33 0x33>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_LONG_WRITE 0xE2 0x11 0x11 0x33 0x33 0xF4 0x00 0x00 0x00 0xF4 0x00 0x00 0x00>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_LONG_WRITE 0xE3 0x00 0x00 0x11 0x11>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_LONG_WRITE 0xE4 0x44 0x44>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_LONG_WRITE 0xE5 0x0D 0xF5 0x30 0xF0 0x0F 0xF7 0x30 0xF0 0x09 0xF1 0x30 0xF0 0x0B 0xF3 0x30 0xF0>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_LONG_WRITE 0xE6 0x00 0x00 0x11 0x11>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_LONG_WRITE 0xE7 0x44 0x44>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_LONG_WRITE 0xE8 0x0C 0xF4 0x30 0xF0 0x0E 0xF6 0x30 0xF0 0x08 0xF0 0x30 0xF0 0x0A 0xF2 0x30 0xF0>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_LONG_WRITE 0xE9 0x36 0x01>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_LONG_WRITE 0xEB 0x00 0x01 0xE4 0xE4 0x44 0x88 0x40>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_LONG_WRITE 0xED 0xFF 0x10 0xBF 0x76 0x54 0x2A 0xFC 0xFF 0xFF 0xCF 0xA2 0x45 0x67 0xFB 0x01 0xFF>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_LONG_WRITE 0xEF 0x08 0x08 0x08 0x45 0x3F 0x54>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_LONG_WRITE 0xFF 0x77 0x01 0x00 0x00 0x00>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_WRITE_1_PARAM 0x11 0x00 0x00>,
<TEGRA_DSI_DELAY_MS 120>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_WRITE_1_PARAM 0x3A 0x66 0x00>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_WRITE_1_PARAM 0x36 0x10 0x00>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_WRITE_1_PARAM 0x35 0x00 0x00>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_WRITE_1_PARAM 0x29 0x00 0x00>;
/*
nvidia,dsi-init-cmd = <TEGRA_DSI_DELAY_MS 200>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_LONG_WRITE 0xFF 0x77 0x01 0x00 0x00 0x10>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_LONG_WRITE 0xB0 0x00 0x11 0x16 0x0E 0x11 0x06 0x05 0x09 0x08 0x21 0x06 0x13 0x10 0x29 0x31 0x18>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_LONG_WRITE 0xB1 0x00 0x11 0x16 0x0E 0x11 0x07 0x05 0x09 0x09 0x21 0x05 0x13 0x11 0x2A 0x31 0x18>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_LONG_WRITE 0xFF 0x77 0x01 0x00 0x00 0x11>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_WRITE_1_PARAM 0xB0 0x6D 0x00>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_WRITE_1_PARAM 0xB1 0x37 0x00>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_WRITE_1_PARAM 0xB2 0x81 0x00>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_WRITE_1_PARAM 0xB3 0x80 0x00>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_WRITE_1_PARAM 0xB5 0x43 0x00>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_WRITE_1_PARAM 0xB7 0x85 0x00>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_WRITE_1_PARAM 0xB8 0x20 0x00>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_WRITE_1_PARAM 0xC1 0x78 0x00>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_WRITE_1_PARAM 0xC2 0x78 0x00>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_WRITE_1_PARAM 0xC3 0x8C 0x00>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_WRITE_1_PARAM 0xD0 0x88 0x00>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_LONG_WRITE 0xE0 0x00 0x00 0x02>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_LONG_WRITE 0xE1 0x03 0xA0 0x00 0x00 0x04>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_LONG_WRITE 0xA0 0x00 0x00 0x00 0x20 0x20>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_LONG_WRITE 0xE2 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_LONG_WRITE 0xE3 0x00 0x00 0x11 0x00>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_WRITE_1_PARAM 0xE4 0x22 0x00>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_LONG_WRITE 0xE5 0x05 0xEC 0xA0 0xA0 0x07 0xEE 0xA0 0xA0 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_LONG_WRITE 0xE6 0x00 0x00 0x11 0x00>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_WRITE_1_PARAM 0xE7 0x22 0x00>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_LONG_WRITE 0xE8 0x06 0xED 0xA0 0xA0 0x08 0xEF 0xA0 0xA0 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_LONG_WRITE 0xEB 0x00 0x00 0x40 0x40 0x00 0x00 0x00>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_LONG_WRITE 0xED 0xFF 0xFF 0xFF 0xBA 0x0A 0xBF 0x45 0xFF 0xFF 0x54 0xFB 0xA0 0xAB 0xFF 0xFF>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_LONG_WRITE 0xEF 0x10 0x0D 0x04 0x08 0x3F 0x1F>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_LONG_WRITE 0xFF 0x77 0x01 0x00 0x00 0x13>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_WRITE_1_PARAM 0xEF 0x08 0x00>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_LONG_WRITE 0xFF 0x77 0x01 0x00 0x00 0x00>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_WRITE_1_PARAM 0x36 0x00 0x00>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_WRITE_1_PARAM 0x3A 0x66 0x00>,
<TEGRA_DSI_DELAY_MS 50>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_WRITE_1_PARAM 0x11 0x00 0x00>,
<TEGRA_DSI_DELAY_MS 50>,
<TEGRA_DSI_PACKET_CMD DSI_DCS_WRITE_1_PARAM 0x29 0x00 0x00>;
*/
nvidia,dsi-n-init-cmd = <41>;
disp-default-out {
nvidia,out-type = <TEGRA_DC_OUT_DSI>;
nvidia,out-width = <107>;
nvidia,out-height = <172>;
nvidia,out-flags = <TEGRA_DC_OUT_CONTINUOUS_MODE>;
nvidia,out-parent-clk = "pll_d_out0";
nvidia,out-xres = <800>;
nvidia,out-yres = <1280>;
};
/*
display-timings {
800x1280-32 {
clock-frequency = <74880000>;
hactive = <800>;
vactive = <1280>;
hfront-porch = <24>;
hback-porch = <132>;
hsync-len = <4>;
vfront-porch = <8>;
vback-porch = <8>;
vsync-len = <4>;
nvidia,h-ref-to-sync = <4>;
nvidia,v-ref-to-sync = <1>;
};
};
*/
display-timings {
800x1280-32 {
clock-frequency = <25000000>;
hactive = <800>;
vactive = <1280>;
hfront-porch = <140>;
hback-porch = <160>;
hsync-len = <8>;
vfront-porch = <20>;
vback-porch = <20>;
vsync-len = <8>;
nvidia,h-ref-to-sync = <4>;
nvidia,v-ref-to-sync = <1>;
};
};
cmu {
nvidia,cmu-csc = < 0x138 0x3ba 0x00d
0x3f5 0x120 0x3e6
0x3fe 0x3f8 0x0e9 >;
nvidia,cmu-lut2 = < 0 1 2 3 4 5 6 6
7 8 9 10 11 11 12 13
13 14 15 15 16 17 17 18
18 19 19 20 20 21 21 22
22 23 23 23 24 24 24 25
25 25 26 26 26 27 27 27
28 28 28 28 29 29 29 29
30 30 30 30 31 31 31 31
32 32 32 32 33 33 33 33
34 34 34 35 35 35 35 36
36 36 37 37 37 37 38 38
38 39 39 39 39 40 40 40
41 41 41 41 42 42 42 43
43 43 43 44 44 44 45 45
45 45 46 46 46 46 47 47
47 47 48 48 48 48 49 49
49 49 50 50 50 50 50 51
51 51 51 52 52 52 52 52
53 53 53 53 53 53 54 54
54 54 54 55 55 55 55 55
55 56 56 56 56 56 56 57
57 57 57 57 57 57 58 58
58 58 58 58 59 59 59 59
59 59 59 60 60 60 60 60
60 60 61 61 61 61 61 61
61 62 62 62 62 62 62 62
63 63 63 63 63 63 63 64
64 64 64 64 64 64 65 65
65 65 65 65 66 66 66 66
66 66 66 67 67 67 67 67
67 68 68 68 68 68 68 69
69 69 69 69 69 70 70 70
70 70 70 71 71 71 71 71
71 72 72 72 72 72 72 73
73 73 73 73 73 74 74 74
74 74 74 74 75 75 75 75
75 75 76 76 76 76 76 76
77 77 77 77 77 77 77 78
78 78 78 78 78 79 79 79
79 79 79 79 80 80 80 80
80 80 80 80 81 81 81 81
81 81 81 82 82 82 82 82
82 82 82 83 83 83 83 83
83 83 83 83 84 84 84 84
84 84 84 84 85 85 85 85
85 85 85 85 85 85 86 86
86 86 86 86 86 86 86 86
87 87 87 87 87 87 87 87
87 87 88 88 88 88 88 88
88 88 88 88 88 88 89 89
89 89 89 89 89 89 89 89
89 89 90 90 90 90 90 90
90 90 90 90 90 90 91 91
91 91 91 91 91 91 91 91
91 91 91 92 92 92 92 92
92 92 92 92 92 92 92 92
93 93 93 93 93 93 93 93
93 93 93 93 93 93 94 94
94 94 94 94 94 94 94 94
94 94 94 94 95 95 95 95
95 95 95 95 95 95 95 95
95 96 96 96 96 96 96 96
96 96 96 96 96 96 97 97
97 97 97 97 97 97 97 97
98 99 99 100 101 101 102 103
103 104 105 105 106 107 107 108
109 110 110 111 112 112 113 114
114 115 115 116 117 117 118 119
119 120 120 121 121 122 123 123
124 124 125 125 126 126 127 128
128 129 129 130 130 131 131 132
132 133 133 134 134 135 135 136
136 137 138 138 139 139 140 140
141 141 142 142 143 143 144 144
144 145 145 146 146 147 147 148
148 149 149 150 150 151 151 152
152 153 153 153 154 154 155 155
156 156 157 157 157 158 158 159
159 160 160 160 161 161 162 162
162 163 163 164 164 164 165 165
165 166 166 167 167 167 168 168
168 169 169 169 170 170 171 171
171 172 172 172 173 173 173 174
174 174 175 175 175 176 176 176
177 177 177 178 178 178 179 179
179 180 180 180 181 181 181 182
182 182 183 183 183 184 184 184
185 185 185 185 186 186 186 187
187 187 188 188 188 189 189 189
190 190 190 191 191 191 191 192
192 192 193 193 193 194 194 194
195 195 195 195 196 196 196 197
197 197 198 198 198 199 199 199
199 200 200 200 201 201 201 202
202 202 203 203 203 203 204 204
204 205 205 205 206 206 206 207
207 207 208 208 208 208 209 209
209 210 210 210 211 211 211 212
212 212 213 213 213 214 214 214
215 215 215 215 216 216 216 217
217 217 218 218 218 219 219 219
220 220 220 220 221 221 221 222
222 222 222 223 223 223 224 224
224 224 225 225 225 226 226 226
226 227 227 227 227 228 228 228
229 229 229 229 230 230 230 230
230 231 231 231 231 232 232 232
232 233 233 233 233 234 234 234
234 234 235 235 235 235 236 236
236 236 236 237 237 237 237 238
238 238 238 238 239 239 239 239
239 240 240 240 240 240 241 241
241 241 241 242 242 242 242 243
243 243 243 243 244 244 244 244
244 245 245 245 245 245 246 246
246 246 246 247 247 247 247 248
248 248 248 248 249 249 249 249
250 250 250 250 251 251 251 251
251 252 252 252 253 253 253 253
254 254 254 254 255 255 255 255 >;
};
};
};
};
backlight {
panel_a_wxga_8_0_bl: panel-a-wxga-8-0-bl {
status = "disabled";
compatible = "a,wxga-8-0-bl";
pwms = <&tegra_pwm 1 1000000>;
max-brightness = <255>;
default-brightness = <224>;
bl-measured = < 0 0 1 2 3 4 5 6
7 8 9 9 10 11 12 13
13 14 15 16 17 17 18 19
20 21 22 22 23 24 25 26
27 27 28 29 30 31 32 32
33 34 35 36 37 37 38 39
40 41 42 42 43 44 45 46
47 48 48 49 50 51 52 53
54 55 56 57 57 58 59 60
61 62 63 64 65 66 67 68
69 70 71 71 72 73 74 75
76 77 77 78 79 80 81 82
83 84 85 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 115 116
117 118 119 120 121 122 123 124
125 126 127 128 129 130 131 132
133 134 135 136 137 138 139 141
142 143 144 146 147 148 149 151
152 153 154 155 156 157 158 158
159 160 161 162 163 165 166 167
168 169 170 171 172 173 174 176
177 178 179 180 182 183 184 185
186 187 188 189 190 191 192 194
195 196 197 198 199 200 201 202
203 204 205 206 207 208 209 210
211 212 213 214 215 216 217 219
220 221 222 224 225 226 227 229
230 231 232 233 234 235 236 238
239 240 241 242 243 244 245 246
247 248 249 250 251 252 253 255 >;
};
};
};
I only changed the display settings and initialization commands