1*4882a593Smuzhiyun /*
2*4882a593Smuzhiyun * LCD: Formike, TFT 4.3", 480x800, RGB24, KWH043ST20-F01, DriverIC NT35510-16
3*4882a593Smuzhiyun * LCD initialization via SPI
4*4882a593Smuzhiyun *
5*4882a593Smuzhiyun * SPDX-License-Identifier: GPL-2.0
6*4882a593Smuzhiyun * Based on:
7*4882a593Smuzhiyun *
8*4882a593Smuzhiyun */
9*4882a593Smuzhiyun #include <common.h>
10*4882a593Smuzhiyun #include <errno.h>
11*4882a593Smuzhiyun #include <spi.h>
12*4882a593Smuzhiyun
13*4882a593Smuzhiyun #define TAG_READ 0x80
14*4882a593Smuzhiyun #define TAG_WRITE 0x00
15*4882a593Smuzhiyun
16*4882a593Smuzhiyun #define TAG_DATA 0x40
17*4882a593Smuzhiyun #define TAG_COMMAND 0x00
18*4882a593Smuzhiyun
19*4882a593Smuzhiyun #define TAG_ADDR_H 0x20
20*4882a593Smuzhiyun #define TAG_ADDR_L 0x00
21*4882a593Smuzhiyun
spi_write_tag_val(struct spi_slave * spi,unsigned char tag,unsigned char val)22*4882a593Smuzhiyun static int spi_write_tag_val(struct spi_slave *spi, unsigned char tag,
23*4882a593Smuzhiyun unsigned char val)
24*4882a593Smuzhiyun {
25*4882a593Smuzhiyun unsigned long flags = SPI_XFER_BEGIN;
26*4882a593Smuzhiyun u8 buf[2];
27*4882a593Smuzhiyun int ret;
28*4882a593Smuzhiyun
29*4882a593Smuzhiyun buf[0] = tag;
30*4882a593Smuzhiyun ret = spi_xfer(spi, 8, buf, NULL, flags);
31*4882a593Smuzhiyun buf[0] = val;
32*4882a593Smuzhiyun flags = SPI_XFER_END;
33*4882a593Smuzhiyun ret = spi_xfer(spi, 8, buf, NULL, flags);
34*4882a593Smuzhiyun
35*4882a593Smuzhiyun #ifdef KWH043ST20_F01_SPI_DEBUG
36*4882a593Smuzhiyun printf("spi_write_tag_val: tag=%02X, val=%02X ret: %d\n",
37*4882a593Smuzhiyun tag, val, ret);
38*4882a593Smuzhiyun #endif /* KWH043ST20_F01_SPI_DEBUG */
39*4882a593Smuzhiyun if (ret)
40*4882a593Smuzhiyun debug("%s: Failed to send: %d\n", __func__, ret);
41*4882a593Smuzhiyun
42*4882a593Smuzhiyun return ret;
43*4882a593Smuzhiyun }
44*4882a593Smuzhiyun
spi_write_dat(struct spi_slave * spi,unsigned int val)45*4882a593Smuzhiyun static void spi_write_dat(struct spi_slave *spi, unsigned int val)
46*4882a593Smuzhiyun {
47*4882a593Smuzhiyun spi_write_tag_val(spi, TAG_WRITE|TAG_DATA, val);
48*4882a593Smuzhiyun }
49*4882a593Smuzhiyun
spi_write_com(struct spi_slave * spi,unsigned int addr)50*4882a593Smuzhiyun static void spi_write_com(struct spi_slave *spi, unsigned int addr)
51*4882a593Smuzhiyun {
52*4882a593Smuzhiyun spi_write_tag_val(spi, TAG_WRITE|TAG_COMMAND|TAG_ADDR_H,
53*4882a593Smuzhiyun (addr & 0xff00) >> 8);
54*4882a593Smuzhiyun spi_write_tag_val(spi, TAG_WRITE|TAG_COMMAND|TAG_ADDR_L,
55*4882a593Smuzhiyun (addr & 0x00ff) >> 0);
56*4882a593Smuzhiyun }
57*4882a593Smuzhiyun
kwh043st20_f01_spi_startup(unsigned int bus,unsigned int cs,unsigned int max_hz,unsigned int spi_mode)58*4882a593Smuzhiyun int kwh043st20_f01_spi_startup(unsigned int bus, unsigned int cs,
59*4882a593Smuzhiyun unsigned int max_hz, unsigned int spi_mode)
60*4882a593Smuzhiyun {
61*4882a593Smuzhiyun struct spi_slave *spi;
62*4882a593Smuzhiyun int ret;
63*4882a593Smuzhiyun
64*4882a593Smuzhiyun spi = spi_setup_slave(bus, cs, max_hz, spi_mode);
65*4882a593Smuzhiyun if (!spi) {
66*4882a593Smuzhiyun debug("%s: Failed to set up slave\n", __func__);
67*4882a593Smuzhiyun return -1;
68*4882a593Smuzhiyun }
69*4882a593Smuzhiyun
70*4882a593Smuzhiyun ret = spi_claim_bus(spi);
71*4882a593Smuzhiyun if (ret) {
72*4882a593Smuzhiyun debug("%s: Failed to claim SPI bus: %d\n", __func__, ret);
73*4882a593Smuzhiyun goto err_claim_bus;
74*4882a593Smuzhiyun }
75*4882a593Smuzhiyun
76*4882a593Smuzhiyun
77*4882a593Smuzhiyun /* LV2 Page 1 enable */
78*4882a593Smuzhiyun spi_write_com(spi, 0xF000); spi_write_dat(spi, 0x55);
79*4882a593Smuzhiyun spi_write_com(spi, 0xF001); spi_write_dat(spi, 0xAA);
80*4882a593Smuzhiyun spi_write_com(spi, 0xF002); spi_write_dat(spi, 0x52);
81*4882a593Smuzhiyun spi_write_com(spi, 0xF003); spi_write_dat(spi, 0x08);
82*4882a593Smuzhiyun spi_write_com(spi, 0xF004); spi_write_dat(spi, 0x01);
83*4882a593Smuzhiyun
84*4882a593Smuzhiyun /* AVDD Set AVDD 5.2V */
85*4882a593Smuzhiyun spi_write_com(spi, 0xB000); spi_write_dat(spi, 0x0D);
86*4882a593Smuzhiyun spi_write_com(spi, 0xB001); spi_write_dat(spi, 0x0D);
87*4882a593Smuzhiyun spi_write_com(spi, 0xB002); spi_write_dat(spi, 0x0D);
88*4882a593Smuzhiyun
89*4882a593Smuzhiyun /* AVDD ratio */
90*4882a593Smuzhiyun spi_write_com(spi, 0xB600); spi_write_dat(spi, 0x34);
91*4882a593Smuzhiyun spi_write_com(spi, 0xB601); spi_write_dat(spi, 0x34);
92*4882a593Smuzhiyun spi_write_com(spi, 0xB602); spi_write_dat(spi, 0x34);
93*4882a593Smuzhiyun
94*4882a593Smuzhiyun /* AVEE -5.2V */
95*4882a593Smuzhiyun spi_write_com(spi, 0xB100); spi_write_dat(spi, 0x0D);
96*4882a593Smuzhiyun spi_write_com(spi, 0xB101); spi_write_dat(spi, 0x0D);
97*4882a593Smuzhiyun spi_write_com(spi, 0xB102); spi_write_dat(spi, 0x0D);
98*4882a593Smuzhiyun
99*4882a593Smuzhiyun /* AVEE ratio */
100*4882a593Smuzhiyun spi_write_com(spi, 0xB700); spi_write_dat(spi, 0x35);
101*4882a593Smuzhiyun spi_write_com(spi, 0xB701); spi_write_dat(spi, 0x35);
102*4882a593Smuzhiyun spi_write_com(spi, 0xB702); spi_write_dat(spi, 0x35);
103*4882a593Smuzhiyun
104*4882a593Smuzhiyun /* VCL -2.5V */
105*4882a593Smuzhiyun spi_write_com(spi, 0xB200); spi_write_dat(spi, 0x00);
106*4882a593Smuzhiyun spi_write_com(spi, 0xB201); spi_write_dat(spi, 0x00);
107*4882a593Smuzhiyun spi_write_com(spi, 0xB202); spi_write_dat(spi, 0x00);
108*4882a593Smuzhiyun
109*4882a593Smuzhiyun /* VCL ratio */
110*4882a593Smuzhiyun spi_write_com(spi, 0xB800); spi_write_dat(spi, 0x24);
111*4882a593Smuzhiyun spi_write_com(spi, 0xB801); spi_write_dat(spi, 0x24);
112*4882a593Smuzhiyun spi_write_com(spi, 0xB802); spi_write_dat(spi, 0x24);
113*4882a593Smuzhiyun
114*4882a593Smuzhiyun /* VGH 15V */
115*4882a593Smuzhiyun spi_write_com(spi, 0xBF00); spi_write_dat(spi, 0x01);
116*4882a593Smuzhiyun spi_write_com(spi, 0xB300); spi_write_dat(spi, 0x08);
117*4882a593Smuzhiyun spi_write_com(spi, 0xB301); spi_write_dat(spi, 0x08);
118*4882a593Smuzhiyun spi_write_com(spi, 0xB302); spi_write_dat(spi, 0x08);
119*4882a593Smuzhiyun
120*4882a593Smuzhiyun /* VGH ratio */
121*4882a593Smuzhiyun spi_write_com(spi, 0xB900); spi_write_dat(spi, 0x34);
122*4882a593Smuzhiyun spi_write_com(spi, 0xB901); spi_write_dat(spi, 0x34);
123*4882a593Smuzhiyun spi_write_com(spi, 0xB902); spi_write_dat(spi, 0x34);
124*4882a593Smuzhiyun
125*4882a593Smuzhiyun /* VGLX ratio */
126*4882a593Smuzhiyun spi_write_com(spi, 0xBA00); spi_write_dat(spi, 0x24);
127*4882a593Smuzhiyun spi_write_com(spi, 0xBA01); spi_write_dat(spi, 0x24);
128*4882a593Smuzhiyun spi_write_com(spi, 0xBA02); spi_write_dat(spi, 0x24);
129*4882a593Smuzhiyun
130*4882a593Smuzhiyun /* VGMP/VGSP 4.7V/0V */
131*4882a593Smuzhiyun spi_write_com(spi, 0xBC00); spi_write_dat(spi, 0x00);
132*4882a593Smuzhiyun spi_write_com(spi, 0xBC01); spi_write_dat(spi, 0x88);
133*4882a593Smuzhiyun spi_write_com(spi, 0xBC02); spi_write_dat(spi, 0x00);
134*4882a593Smuzhiyun
135*4882a593Smuzhiyun /* VGMN/VGSN -4.7V/0V */
136*4882a593Smuzhiyun spi_write_com(spi, 0xBD00); spi_write_dat(spi, 0x00);
137*4882a593Smuzhiyun spi_write_com(spi, 0xBD01); spi_write_dat(spi, 0x88);
138*4882a593Smuzhiyun spi_write_com(spi, 0xBD02); spi_write_dat(spi, 0x00);
139*4882a593Smuzhiyun
140*4882a593Smuzhiyun /* VCOM 1.525V */
141*4882a593Smuzhiyun spi_write_com(spi, 0xBE00); spi_write_dat(spi, 0x00);
142*4882a593Smuzhiyun spi_write_com(spi, 0xBE01); spi_write_dat(spi, 0x7A);
143*4882a593Smuzhiyun
144*4882a593Smuzhiyun /* Gamma Setting */
145*4882a593Smuzhiyun spi_write_com(spi, 0xD100); spi_write_dat(spi, 0x00);
146*4882a593Smuzhiyun spi_write_com(spi, 0xD101); spi_write_dat(spi, 0x05);
147*4882a593Smuzhiyun spi_write_com(spi, 0xD102); spi_write_dat(spi, 0x00);
148*4882a593Smuzhiyun spi_write_com(spi, 0xD103); spi_write_dat(spi, 0x15);
149*4882a593Smuzhiyun spi_write_com(spi, 0xD104); spi_write_dat(spi, 0x00);
150*4882a593Smuzhiyun spi_write_com(spi, 0xD105); spi_write_dat(spi, 0x30);
151*4882a593Smuzhiyun spi_write_com(spi, 0xD106); spi_write_dat(spi, 0x00);
152*4882a593Smuzhiyun spi_write_com(spi, 0xD107); spi_write_dat(spi, 0x47);
153*4882a593Smuzhiyun spi_write_com(spi, 0xD108); spi_write_dat(spi, 0x00);
154*4882a593Smuzhiyun spi_write_com(spi, 0xD109); spi_write_dat(spi, 0x5B);
155*4882a593Smuzhiyun spi_write_com(spi, 0xD10A); spi_write_dat(spi, 0x00);
156*4882a593Smuzhiyun spi_write_com(spi, 0xD10B); spi_write_dat(spi, 0x7D);
157*4882a593Smuzhiyun spi_write_com(spi, 0xD10C); spi_write_dat(spi, 0x00);
158*4882a593Smuzhiyun spi_write_com(spi, 0xD10D); spi_write_dat(spi, 0x9D);
159*4882a593Smuzhiyun spi_write_com(spi, 0xD10E); spi_write_dat(spi, 0x00);
160*4882a593Smuzhiyun spi_write_com(spi, 0xD10F); spi_write_dat(spi, 0xCC);
161*4882a593Smuzhiyun spi_write_com(spi, 0xD110); spi_write_dat(spi, 0x00);
162*4882a593Smuzhiyun spi_write_com(spi, 0xD111); spi_write_dat(spi, 0xF3);
163*4882a593Smuzhiyun spi_write_com(spi, 0xD112); spi_write_dat(spi, 0x01);
164*4882a593Smuzhiyun spi_write_com(spi, 0xD113); spi_write_dat(spi, 0x32);
165*4882a593Smuzhiyun spi_write_com(spi, 0xD114); spi_write_dat(spi, 0x01);
166*4882a593Smuzhiyun spi_write_com(spi, 0xD115); spi_write_dat(spi, 0x63);
167*4882a593Smuzhiyun spi_write_com(spi, 0xD116); spi_write_dat(spi, 0x01);
168*4882a593Smuzhiyun spi_write_com(spi, 0xD117); spi_write_dat(spi, 0xB1);
169*4882a593Smuzhiyun spi_write_com(spi, 0xD118); spi_write_dat(spi, 0x01);
170*4882a593Smuzhiyun spi_write_com(spi, 0xD119); spi_write_dat(spi, 0xF0);
171*4882a593Smuzhiyun spi_write_com(spi, 0xD11A); spi_write_dat(spi, 0x01);
172*4882a593Smuzhiyun spi_write_com(spi, 0xD11B); spi_write_dat(spi, 0xF2);
173*4882a593Smuzhiyun spi_write_com(spi, 0xD11C); spi_write_dat(spi, 0x02);
174*4882a593Smuzhiyun spi_write_com(spi, 0xD11D); spi_write_dat(spi, 0x2A);
175*4882a593Smuzhiyun spi_write_com(spi, 0xD11E); spi_write_dat(spi, 0x02);
176*4882a593Smuzhiyun spi_write_com(spi, 0xD11F); spi_write_dat(spi, 0x67);
177*4882a593Smuzhiyun spi_write_com(spi, 0xD120); spi_write_dat(spi, 0x02);
178*4882a593Smuzhiyun spi_write_com(spi, 0xD121); spi_write_dat(spi, 0x90);
179*4882a593Smuzhiyun spi_write_com(spi, 0xD122); spi_write_dat(spi, 0x02);
180*4882a593Smuzhiyun spi_write_com(spi, 0xD123); spi_write_dat(spi, 0xCB);
181*4882a593Smuzhiyun spi_write_com(spi, 0xD124); spi_write_dat(spi, 0x02);
182*4882a593Smuzhiyun spi_write_com(spi, 0xD125); spi_write_dat(spi, 0xF2);
183*4882a593Smuzhiyun spi_write_com(spi, 0xD126); spi_write_dat(spi, 0x03);
184*4882a593Smuzhiyun spi_write_com(spi, 0xD127); spi_write_dat(spi, 0x2A);
185*4882a593Smuzhiyun spi_write_com(spi, 0xD128); spi_write_dat(spi, 0x03);
186*4882a593Smuzhiyun spi_write_com(spi, 0xD129); spi_write_dat(spi, 0x51);
187*4882a593Smuzhiyun spi_write_com(spi, 0xD12A); spi_write_dat(spi, 0x03);
188*4882a593Smuzhiyun spi_write_com(spi, 0xD12B); spi_write_dat(spi, 0x80);
189*4882a593Smuzhiyun spi_write_com(spi, 0xD12C); spi_write_dat(spi, 0x03);
190*4882a593Smuzhiyun spi_write_com(spi, 0xD12D); spi_write_dat(spi, 0x9F);
191*4882a593Smuzhiyun spi_write_com(spi, 0xD12E); spi_write_dat(spi, 0x03);
192*4882a593Smuzhiyun spi_write_com(spi, 0xD12F); spi_write_dat(spi, 0xBE);
193*4882a593Smuzhiyun spi_write_com(spi, 0xD130); spi_write_dat(spi, 0x03);
194*4882a593Smuzhiyun spi_write_com(spi, 0xD131); spi_write_dat(spi, 0xF9);
195*4882a593Smuzhiyun spi_write_com(spi, 0xD132); spi_write_dat(spi, 0x03);
196*4882a593Smuzhiyun spi_write_com(spi, 0xD133); spi_write_dat(spi, 0xFF);
197*4882a593Smuzhiyun
198*4882a593Smuzhiyun spi_write_com(spi, 0xD200); spi_write_dat(spi, 0x00);
199*4882a593Smuzhiyun spi_write_com(spi, 0xD201); spi_write_dat(spi, 0x05);
200*4882a593Smuzhiyun spi_write_com(spi, 0xD202); spi_write_dat(spi, 0x00);
201*4882a593Smuzhiyun spi_write_com(spi, 0xD203); spi_write_dat(spi, 0x15);
202*4882a593Smuzhiyun spi_write_com(spi, 0xD204); spi_write_dat(spi, 0x00);
203*4882a593Smuzhiyun spi_write_com(spi, 0xD205); spi_write_dat(spi, 0x30);
204*4882a593Smuzhiyun spi_write_com(spi, 0xD206); spi_write_dat(spi, 0x00);
205*4882a593Smuzhiyun spi_write_com(spi, 0xD207); spi_write_dat(spi, 0x47);
206*4882a593Smuzhiyun spi_write_com(spi, 0xD208); spi_write_dat(spi, 0x00);
207*4882a593Smuzhiyun spi_write_com(spi, 0xD209); spi_write_dat(spi, 0x5B);
208*4882a593Smuzhiyun spi_write_com(spi, 0xD20A); spi_write_dat(spi, 0x00);
209*4882a593Smuzhiyun spi_write_com(spi, 0xD20B); spi_write_dat(spi, 0x7D);
210*4882a593Smuzhiyun spi_write_com(spi, 0xD20C); spi_write_dat(spi, 0x00);
211*4882a593Smuzhiyun spi_write_com(spi, 0xD20D); spi_write_dat(spi, 0x9D);
212*4882a593Smuzhiyun spi_write_com(spi, 0xD20E); spi_write_dat(spi, 0x00);
213*4882a593Smuzhiyun spi_write_com(spi, 0xD20F); spi_write_dat(spi, 0xCC);
214*4882a593Smuzhiyun spi_write_com(spi, 0xD210); spi_write_dat(spi, 0x00);
215*4882a593Smuzhiyun spi_write_com(spi, 0xD211); spi_write_dat(spi, 0xF3);
216*4882a593Smuzhiyun spi_write_com(spi, 0xD212); spi_write_dat(spi, 0x01);
217*4882a593Smuzhiyun spi_write_com(spi, 0xD213); spi_write_dat(spi, 0x32);
218*4882a593Smuzhiyun spi_write_com(spi, 0xD214); spi_write_dat(spi, 0x01);
219*4882a593Smuzhiyun spi_write_com(spi, 0xD215); spi_write_dat(spi, 0x63);
220*4882a593Smuzhiyun spi_write_com(spi, 0xD216); spi_write_dat(spi, 0x01);
221*4882a593Smuzhiyun spi_write_com(spi, 0xD217); spi_write_dat(spi, 0xB1);
222*4882a593Smuzhiyun spi_write_com(spi, 0xD218); spi_write_dat(spi, 0x01);
223*4882a593Smuzhiyun spi_write_com(spi, 0xD219); spi_write_dat(spi, 0xF0);
224*4882a593Smuzhiyun spi_write_com(spi, 0xD21A); spi_write_dat(spi, 0x01);
225*4882a593Smuzhiyun spi_write_com(spi, 0xD21B); spi_write_dat(spi, 0xF2);
226*4882a593Smuzhiyun spi_write_com(spi, 0xD21C); spi_write_dat(spi, 0x02);
227*4882a593Smuzhiyun spi_write_com(spi, 0xD21D); spi_write_dat(spi, 0x2A);
228*4882a593Smuzhiyun spi_write_com(spi, 0xD21E); spi_write_dat(spi, 0x02);
229*4882a593Smuzhiyun spi_write_com(spi, 0xD21F); spi_write_dat(spi, 0x67);
230*4882a593Smuzhiyun spi_write_com(spi, 0xD220); spi_write_dat(spi, 0x02);
231*4882a593Smuzhiyun spi_write_com(spi, 0xD221); spi_write_dat(spi, 0x90);
232*4882a593Smuzhiyun spi_write_com(spi, 0xD222); spi_write_dat(spi, 0x02);
233*4882a593Smuzhiyun spi_write_com(spi, 0xD223); spi_write_dat(spi, 0xCB);
234*4882a593Smuzhiyun spi_write_com(spi, 0xD224); spi_write_dat(spi, 0x02);
235*4882a593Smuzhiyun spi_write_com(spi, 0xD225); spi_write_dat(spi, 0xF2);
236*4882a593Smuzhiyun spi_write_com(spi, 0xD226); spi_write_dat(spi, 0x03);
237*4882a593Smuzhiyun spi_write_com(spi, 0xD227); spi_write_dat(spi, 0x2A);
238*4882a593Smuzhiyun spi_write_com(spi, 0xD228); spi_write_dat(spi, 0x03);
239*4882a593Smuzhiyun spi_write_com(spi, 0xD229); spi_write_dat(spi, 0x51);
240*4882a593Smuzhiyun spi_write_com(spi, 0xD22A); spi_write_dat(spi, 0x03);
241*4882a593Smuzhiyun spi_write_com(spi, 0xD22B); spi_write_dat(spi, 0x80);
242*4882a593Smuzhiyun spi_write_com(spi, 0xD22C); spi_write_dat(spi, 0x03);
243*4882a593Smuzhiyun spi_write_com(spi, 0xD22D); spi_write_dat(spi, 0x9F);
244*4882a593Smuzhiyun spi_write_com(spi, 0xD22E); spi_write_dat(spi, 0x03);
245*4882a593Smuzhiyun spi_write_com(spi, 0xD22F); spi_write_dat(spi, 0xBE);
246*4882a593Smuzhiyun spi_write_com(spi, 0xD230); spi_write_dat(spi, 0x03);
247*4882a593Smuzhiyun spi_write_com(spi, 0xD231); spi_write_dat(spi, 0xF9);
248*4882a593Smuzhiyun spi_write_com(spi, 0xD232); spi_write_dat(spi, 0x03);
249*4882a593Smuzhiyun spi_write_com(spi, 0xD233); spi_write_dat(spi, 0xFF);
250*4882a593Smuzhiyun
251*4882a593Smuzhiyun spi_write_com(spi, 0xD300); spi_write_dat(spi, 0x00);
252*4882a593Smuzhiyun spi_write_com(spi, 0xD301); spi_write_dat(spi, 0x05);
253*4882a593Smuzhiyun spi_write_com(spi, 0xD302); spi_write_dat(spi, 0x00);
254*4882a593Smuzhiyun spi_write_com(spi, 0xD303); spi_write_dat(spi, 0x15);
255*4882a593Smuzhiyun spi_write_com(spi, 0xD304); spi_write_dat(spi, 0x00);
256*4882a593Smuzhiyun spi_write_com(spi, 0xD305); spi_write_dat(spi, 0x30);
257*4882a593Smuzhiyun spi_write_com(spi, 0xD306); spi_write_dat(spi, 0x00);
258*4882a593Smuzhiyun spi_write_com(spi, 0xD307); spi_write_dat(spi, 0x47);
259*4882a593Smuzhiyun spi_write_com(spi, 0xD308); spi_write_dat(spi, 0x00);
260*4882a593Smuzhiyun spi_write_com(spi, 0xD309); spi_write_dat(spi, 0x5B);
261*4882a593Smuzhiyun spi_write_com(spi, 0xD30A); spi_write_dat(spi, 0x00);
262*4882a593Smuzhiyun spi_write_com(spi, 0xD30B); spi_write_dat(spi, 0x7D);
263*4882a593Smuzhiyun spi_write_com(spi, 0xD30C); spi_write_dat(spi, 0x00);
264*4882a593Smuzhiyun spi_write_com(spi, 0xD30D); spi_write_dat(spi, 0x9D);
265*4882a593Smuzhiyun spi_write_com(spi, 0xD30E); spi_write_dat(spi, 0x00);
266*4882a593Smuzhiyun spi_write_com(spi, 0xD30F); spi_write_dat(spi, 0xCC);
267*4882a593Smuzhiyun spi_write_com(spi, 0xD310); spi_write_dat(spi, 0x00);
268*4882a593Smuzhiyun spi_write_com(spi, 0xD311); spi_write_dat(spi, 0xF3);
269*4882a593Smuzhiyun spi_write_com(spi, 0xD312); spi_write_dat(spi, 0x01);
270*4882a593Smuzhiyun spi_write_com(spi, 0xD313); spi_write_dat(spi, 0x32);
271*4882a593Smuzhiyun spi_write_com(spi, 0xD314); spi_write_dat(spi, 0x01);
272*4882a593Smuzhiyun spi_write_com(spi, 0xD315); spi_write_dat(spi, 0x63);
273*4882a593Smuzhiyun spi_write_com(spi, 0xD316); spi_write_dat(spi, 0x01);
274*4882a593Smuzhiyun spi_write_com(spi, 0xD317); spi_write_dat(spi, 0xB1);
275*4882a593Smuzhiyun spi_write_com(spi, 0xD318); spi_write_dat(spi, 0x01);
276*4882a593Smuzhiyun spi_write_com(spi, 0xD319); spi_write_dat(spi, 0xF0);
277*4882a593Smuzhiyun spi_write_com(spi, 0xD31A); spi_write_dat(spi, 0x01);
278*4882a593Smuzhiyun spi_write_com(spi, 0xD31B); spi_write_dat(spi, 0xF2);
279*4882a593Smuzhiyun spi_write_com(spi, 0xD31C); spi_write_dat(spi, 0x02);
280*4882a593Smuzhiyun spi_write_com(spi, 0xD31D); spi_write_dat(spi, 0x2A);
281*4882a593Smuzhiyun spi_write_com(spi, 0xD31E); spi_write_dat(spi, 0x02);
282*4882a593Smuzhiyun spi_write_com(spi, 0xD31F); spi_write_dat(spi, 0x67);
283*4882a593Smuzhiyun spi_write_com(spi, 0xD320); spi_write_dat(spi, 0x02);
284*4882a593Smuzhiyun spi_write_com(spi, 0xD321); spi_write_dat(spi, 0x90);
285*4882a593Smuzhiyun spi_write_com(spi, 0xD322); spi_write_dat(spi, 0x02);
286*4882a593Smuzhiyun spi_write_com(spi, 0xD323); spi_write_dat(spi, 0xCB);
287*4882a593Smuzhiyun spi_write_com(spi, 0xD324); spi_write_dat(spi, 0x02);
288*4882a593Smuzhiyun spi_write_com(spi, 0xD325); spi_write_dat(spi, 0xF2);
289*4882a593Smuzhiyun spi_write_com(spi, 0xD326); spi_write_dat(spi, 0x03);
290*4882a593Smuzhiyun spi_write_com(spi, 0xD327); spi_write_dat(spi, 0x2A);
291*4882a593Smuzhiyun spi_write_com(spi, 0xD328); spi_write_dat(spi, 0x03);
292*4882a593Smuzhiyun spi_write_com(spi, 0xD329); spi_write_dat(spi, 0x51);
293*4882a593Smuzhiyun spi_write_com(spi, 0xD32A); spi_write_dat(spi, 0x03);
294*4882a593Smuzhiyun spi_write_com(spi, 0xD32B); spi_write_dat(spi, 0x80);
295*4882a593Smuzhiyun spi_write_com(spi, 0xD32C); spi_write_dat(spi, 0x03);
296*4882a593Smuzhiyun spi_write_com(spi, 0xD32D); spi_write_dat(spi, 0x9F);
297*4882a593Smuzhiyun spi_write_com(spi, 0xD32E); spi_write_dat(spi, 0x03);
298*4882a593Smuzhiyun spi_write_com(spi, 0xD32F); spi_write_dat(spi, 0xBE);
299*4882a593Smuzhiyun spi_write_com(spi, 0xD330); spi_write_dat(spi, 0x03);
300*4882a593Smuzhiyun spi_write_com(spi, 0xD331); spi_write_dat(spi, 0xF9);
301*4882a593Smuzhiyun spi_write_com(spi, 0xD332); spi_write_dat(spi, 0x03);
302*4882a593Smuzhiyun spi_write_com(spi, 0xD333); spi_write_dat(spi, 0xFF);
303*4882a593Smuzhiyun
304*4882a593Smuzhiyun spi_write_com(spi, 0xD400); spi_write_dat(spi, 0x00);
305*4882a593Smuzhiyun spi_write_com(spi, 0xD401); spi_write_dat(spi, 0x05);
306*4882a593Smuzhiyun spi_write_com(spi, 0xD402); spi_write_dat(spi, 0x00);
307*4882a593Smuzhiyun spi_write_com(spi, 0xD403); spi_write_dat(spi, 0x15);
308*4882a593Smuzhiyun spi_write_com(spi, 0xD404); spi_write_dat(spi, 0x00);
309*4882a593Smuzhiyun spi_write_com(spi, 0xD405); spi_write_dat(spi, 0x30);
310*4882a593Smuzhiyun spi_write_com(spi, 0xD406); spi_write_dat(spi, 0x00);
311*4882a593Smuzhiyun spi_write_com(spi, 0xD407); spi_write_dat(spi, 0x47);
312*4882a593Smuzhiyun spi_write_com(spi, 0xD408); spi_write_dat(spi, 0x00);
313*4882a593Smuzhiyun spi_write_com(spi, 0xD409); spi_write_dat(spi, 0x5B);
314*4882a593Smuzhiyun spi_write_com(spi, 0xD40A); spi_write_dat(spi, 0x00);
315*4882a593Smuzhiyun spi_write_com(spi, 0xD40B); spi_write_dat(spi, 0x7D);
316*4882a593Smuzhiyun spi_write_com(spi, 0xD40C); spi_write_dat(spi, 0x00);
317*4882a593Smuzhiyun spi_write_com(spi, 0xD40D); spi_write_dat(spi, 0x9D);
318*4882a593Smuzhiyun spi_write_com(spi, 0xD40E); spi_write_dat(spi, 0x00);
319*4882a593Smuzhiyun spi_write_com(spi, 0xD40F); spi_write_dat(spi, 0xCC);
320*4882a593Smuzhiyun spi_write_com(spi, 0xD410); spi_write_dat(spi, 0x00);
321*4882a593Smuzhiyun spi_write_com(spi, 0xD411); spi_write_dat(spi, 0xF3);
322*4882a593Smuzhiyun spi_write_com(spi, 0xD412); spi_write_dat(spi, 0x01);
323*4882a593Smuzhiyun spi_write_com(spi, 0xD413); spi_write_dat(spi, 0x32);
324*4882a593Smuzhiyun spi_write_com(spi, 0xD414); spi_write_dat(spi, 0x01);
325*4882a593Smuzhiyun spi_write_com(spi, 0xD415); spi_write_dat(spi, 0x63);
326*4882a593Smuzhiyun spi_write_com(spi, 0xD416); spi_write_dat(spi, 0x01);
327*4882a593Smuzhiyun spi_write_com(spi, 0xD417); spi_write_dat(spi, 0xB1);
328*4882a593Smuzhiyun spi_write_com(spi, 0xD418); spi_write_dat(spi, 0x01);
329*4882a593Smuzhiyun spi_write_com(spi, 0xD419); spi_write_dat(spi, 0xF0);
330*4882a593Smuzhiyun spi_write_com(spi, 0xD41A); spi_write_dat(spi, 0x01);
331*4882a593Smuzhiyun spi_write_com(spi, 0xD41B); spi_write_dat(spi, 0xF2);
332*4882a593Smuzhiyun spi_write_com(spi, 0xD41C); spi_write_dat(spi, 0x02);
333*4882a593Smuzhiyun spi_write_com(spi, 0xD41D); spi_write_dat(spi, 0x2A);
334*4882a593Smuzhiyun spi_write_com(spi, 0xD41E); spi_write_dat(spi, 0x02);
335*4882a593Smuzhiyun spi_write_com(spi, 0xD41F); spi_write_dat(spi, 0x67);
336*4882a593Smuzhiyun spi_write_com(spi, 0xD420); spi_write_dat(spi, 0x02);
337*4882a593Smuzhiyun spi_write_com(spi, 0xD421); spi_write_dat(spi, 0x90);
338*4882a593Smuzhiyun spi_write_com(spi, 0xD422); spi_write_dat(spi, 0x02);
339*4882a593Smuzhiyun spi_write_com(spi, 0xD423); spi_write_dat(spi, 0xCB);
340*4882a593Smuzhiyun spi_write_com(spi, 0xD424); spi_write_dat(spi, 0x02);
341*4882a593Smuzhiyun spi_write_com(spi, 0xD425); spi_write_dat(spi, 0xF2);
342*4882a593Smuzhiyun spi_write_com(spi, 0xD426); spi_write_dat(spi, 0x03);
343*4882a593Smuzhiyun spi_write_com(spi, 0xD427); spi_write_dat(spi, 0x2A);
344*4882a593Smuzhiyun spi_write_com(spi, 0xD428); spi_write_dat(spi, 0x03);
345*4882a593Smuzhiyun spi_write_com(spi, 0xD429); spi_write_dat(spi, 0x51);
346*4882a593Smuzhiyun spi_write_com(spi, 0xD42A); spi_write_dat(spi, 0x03);
347*4882a593Smuzhiyun spi_write_com(spi, 0xD42B); spi_write_dat(spi, 0x80);
348*4882a593Smuzhiyun spi_write_com(spi, 0xD42C); spi_write_dat(spi, 0x03);
349*4882a593Smuzhiyun spi_write_com(spi, 0xD42D); spi_write_dat(spi, 0x9F);
350*4882a593Smuzhiyun spi_write_com(spi, 0xD42E); spi_write_dat(spi, 0x03);
351*4882a593Smuzhiyun spi_write_com(spi, 0xD42F); spi_write_dat(spi, 0xBE);
352*4882a593Smuzhiyun spi_write_com(spi, 0xD430); spi_write_dat(spi, 0x03);
353*4882a593Smuzhiyun spi_write_com(spi, 0xD431); spi_write_dat(spi, 0xF9);
354*4882a593Smuzhiyun spi_write_com(spi, 0xD432); spi_write_dat(spi, 0x03);
355*4882a593Smuzhiyun spi_write_com(spi, 0xD433); spi_write_dat(spi, 0xFF);
356*4882a593Smuzhiyun
357*4882a593Smuzhiyun spi_write_com(spi, 0xD500); spi_write_dat(spi, 0x00);
358*4882a593Smuzhiyun spi_write_com(spi, 0xD501); spi_write_dat(spi, 0x05);
359*4882a593Smuzhiyun spi_write_com(spi, 0xD502); spi_write_dat(spi, 0x00);
360*4882a593Smuzhiyun spi_write_com(spi, 0xD503); spi_write_dat(spi, 0x15);
361*4882a593Smuzhiyun spi_write_com(spi, 0xD504); spi_write_dat(spi, 0x00);
362*4882a593Smuzhiyun spi_write_com(spi, 0xD505); spi_write_dat(spi, 0x30);
363*4882a593Smuzhiyun spi_write_com(spi, 0xD506); spi_write_dat(spi, 0x00);
364*4882a593Smuzhiyun spi_write_com(spi, 0xD507); spi_write_dat(spi, 0x47);
365*4882a593Smuzhiyun spi_write_com(spi, 0xD508); spi_write_dat(spi, 0x00);
366*4882a593Smuzhiyun spi_write_com(spi, 0xD509); spi_write_dat(spi, 0x5B);
367*4882a593Smuzhiyun spi_write_com(spi, 0xD50A); spi_write_dat(spi, 0x00);
368*4882a593Smuzhiyun spi_write_com(spi, 0xD50B); spi_write_dat(spi, 0x7D);
369*4882a593Smuzhiyun spi_write_com(spi, 0xD50C); spi_write_dat(spi, 0x00);
370*4882a593Smuzhiyun spi_write_com(spi, 0xD50D); spi_write_dat(spi, 0x9D);
371*4882a593Smuzhiyun spi_write_com(spi, 0xD50E); spi_write_dat(spi, 0x00);
372*4882a593Smuzhiyun spi_write_com(spi, 0xD50F); spi_write_dat(spi, 0xCC);
373*4882a593Smuzhiyun spi_write_com(spi, 0xD510); spi_write_dat(spi, 0x00);
374*4882a593Smuzhiyun spi_write_com(spi, 0xD511); spi_write_dat(spi, 0xF3);
375*4882a593Smuzhiyun spi_write_com(spi, 0xD512); spi_write_dat(spi, 0x01);
376*4882a593Smuzhiyun spi_write_com(spi, 0xD513); spi_write_dat(spi, 0x32);
377*4882a593Smuzhiyun spi_write_com(spi, 0xD514); spi_write_dat(spi, 0x01);
378*4882a593Smuzhiyun spi_write_com(spi, 0xD515); spi_write_dat(spi, 0x63);
379*4882a593Smuzhiyun spi_write_com(spi, 0xD516); spi_write_dat(spi, 0x01);
380*4882a593Smuzhiyun spi_write_com(spi, 0xD517); spi_write_dat(spi, 0xB1);
381*4882a593Smuzhiyun spi_write_com(spi, 0xD518); spi_write_dat(spi, 0x01);
382*4882a593Smuzhiyun spi_write_com(spi, 0xD519); spi_write_dat(spi, 0xF0);
383*4882a593Smuzhiyun spi_write_com(spi, 0xD51A); spi_write_dat(spi, 0x01);
384*4882a593Smuzhiyun spi_write_com(spi, 0xD51B); spi_write_dat(spi, 0xF2);
385*4882a593Smuzhiyun spi_write_com(spi, 0xD51C); spi_write_dat(spi, 0x02);
386*4882a593Smuzhiyun spi_write_com(spi, 0xD51D); spi_write_dat(spi, 0x2A);
387*4882a593Smuzhiyun spi_write_com(spi, 0xD51E); spi_write_dat(spi, 0x02);
388*4882a593Smuzhiyun spi_write_com(spi, 0xD51F); spi_write_dat(spi, 0x67);
389*4882a593Smuzhiyun spi_write_com(spi, 0xD520); spi_write_dat(spi, 0x02);
390*4882a593Smuzhiyun spi_write_com(spi, 0xD521); spi_write_dat(spi, 0x90);
391*4882a593Smuzhiyun spi_write_com(spi, 0xD522); spi_write_dat(spi, 0x02);
392*4882a593Smuzhiyun spi_write_com(spi, 0xD523); spi_write_dat(spi, 0xCB);
393*4882a593Smuzhiyun spi_write_com(spi, 0xD524); spi_write_dat(spi, 0x02);
394*4882a593Smuzhiyun spi_write_com(spi, 0xD525); spi_write_dat(spi, 0xF2);
395*4882a593Smuzhiyun spi_write_com(spi, 0xD526); spi_write_dat(spi, 0x03);
396*4882a593Smuzhiyun spi_write_com(spi, 0xD527); spi_write_dat(spi, 0x2A);
397*4882a593Smuzhiyun spi_write_com(spi, 0xD528); spi_write_dat(spi, 0x03);
398*4882a593Smuzhiyun spi_write_com(spi, 0xD529); spi_write_dat(spi, 0x51);
399*4882a593Smuzhiyun spi_write_com(spi, 0xD52A); spi_write_dat(spi, 0x03);
400*4882a593Smuzhiyun spi_write_com(spi, 0xD52B); spi_write_dat(spi, 0x80);
401*4882a593Smuzhiyun spi_write_com(spi, 0xD52C); spi_write_dat(spi, 0x03);
402*4882a593Smuzhiyun spi_write_com(spi, 0xD52D); spi_write_dat(spi, 0x9F);
403*4882a593Smuzhiyun spi_write_com(spi, 0xD52E); spi_write_dat(spi, 0x03);
404*4882a593Smuzhiyun spi_write_com(spi, 0xD52F); spi_write_dat(spi, 0xBE);
405*4882a593Smuzhiyun spi_write_com(spi, 0xD530); spi_write_dat(spi, 0x03);
406*4882a593Smuzhiyun spi_write_com(spi, 0xD531); spi_write_dat(spi, 0xF9);
407*4882a593Smuzhiyun spi_write_com(spi, 0xD532); spi_write_dat(spi, 0x03);
408*4882a593Smuzhiyun spi_write_com(spi, 0xD533); spi_write_dat(spi, 0xFF);
409*4882a593Smuzhiyun
410*4882a593Smuzhiyun spi_write_com(spi, 0xD600); spi_write_dat(spi, 0x00);
411*4882a593Smuzhiyun spi_write_com(spi, 0xD601); spi_write_dat(spi, 0x05);
412*4882a593Smuzhiyun spi_write_com(spi, 0xD602); spi_write_dat(spi, 0x00);
413*4882a593Smuzhiyun spi_write_com(spi, 0xD603); spi_write_dat(spi, 0x15);
414*4882a593Smuzhiyun spi_write_com(spi, 0xD604); spi_write_dat(spi, 0x00);
415*4882a593Smuzhiyun spi_write_com(spi, 0xD605); spi_write_dat(spi, 0x30);
416*4882a593Smuzhiyun spi_write_com(spi, 0xD606); spi_write_dat(spi, 0x00);
417*4882a593Smuzhiyun spi_write_com(spi, 0xD607); spi_write_dat(spi, 0x47);
418*4882a593Smuzhiyun spi_write_com(spi, 0xD608); spi_write_dat(spi, 0x00);
419*4882a593Smuzhiyun spi_write_com(spi, 0xD609); spi_write_dat(spi, 0x5B);
420*4882a593Smuzhiyun spi_write_com(spi, 0xD60A); spi_write_dat(spi, 0x00);
421*4882a593Smuzhiyun spi_write_com(spi, 0xD60B); spi_write_dat(spi, 0x7D);
422*4882a593Smuzhiyun spi_write_com(spi, 0xD60C); spi_write_dat(spi, 0x00);
423*4882a593Smuzhiyun spi_write_com(spi, 0xD60D); spi_write_dat(spi, 0x9D);
424*4882a593Smuzhiyun spi_write_com(spi, 0xD60E); spi_write_dat(spi, 0x00);
425*4882a593Smuzhiyun spi_write_com(spi, 0xD60F); spi_write_dat(spi, 0xCC);
426*4882a593Smuzhiyun spi_write_com(spi, 0xD610); spi_write_dat(spi, 0x00);
427*4882a593Smuzhiyun spi_write_com(spi, 0xD611); spi_write_dat(spi, 0xF3);
428*4882a593Smuzhiyun spi_write_com(spi, 0xD612); spi_write_dat(spi, 0x01);
429*4882a593Smuzhiyun spi_write_com(spi, 0xD613); spi_write_dat(spi, 0x32);
430*4882a593Smuzhiyun spi_write_com(spi, 0xD614); spi_write_dat(spi, 0x01);
431*4882a593Smuzhiyun spi_write_com(spi, 0xD615); spi_write_dat(spi, 0x63);
432*4882a593Smuzhiyun spi_write_com(spi, 0xD616); spi_write_dat(spi, 0x01);
433*4882a593Smuzhiyun spi_write_com(spi, 0xD617); spi_write_dat(spi, 0xB1);
434*4882a593Smuzhiyun spi_write_com(spi, 0xD618); spi_write_dat(spi, 0x01);
435*4882a593Smuzhiyun spi_write_com(spi, 0xD619); spi_write_dat(spi, 0xF0);
436*4882a593Smuzhiyun spi_write_com(spi, 0xD61A); spi_write_dat(spi, 0x01);
437*4882a593Smuzhiyun spi_write_com(spi, 0xD61B); spi_write_dat(spi, 0xF2);
438*4882a593Smuzhiyun spi_write_com(spi, 0xD61C); spi_write_dat(spi, 0x02);
439*4882a593Smuzhiyun spi_write_com(spi, 0xD61D); spi_write_dat(spi, 0x2A);
440*4882a593Smuzhiyun spi_write_com(spi, 0xD61E); spi_write_dat(spi, 0x02);
441*4882a593Smuzhiyun spi_write_com(spi, 0xD61F); spi_write_dat(spi, 0x67);
442*4882a593Smuzhiyun spi_write_com(spi, 0xD620); spi_write_dat(spi, 0x02);
443*4882a593Smuzhiyun spi_write_com(spi, 0xD621); spi_write_dat(spi, 0x90);
444*4882a593Smuzhiyun spi_write_com(spi, 0xD622); spi_write_dat(spi, 0x02);
445*4882a593Smuzhiyun spi_write_com(spi, 0xD623); spi_write_dat(spi, 0xCB);
446*4882a593Smuzhiyun spi_write_com(spi, 0xD624); spi_write_dat(spi, 0x02);
447*4882a593Smuzhiyun spi_write_com(spi, 0xD625); spi_write_dat(spi, 0xF2);
448*4882a593Smuzhiyun spi_write_com(spi, 0xD626); spi_write_dat(spi, 0x03);
449*4882a593Smuzhiyun spi_write_com(spi, 0xD627); spi_write_dat(spi, 0x2A);
450*4882a593Smuzhiyun spi_write_com(spi, 0xD628); spi_write_dat(spi, 0x03);
451*4882a593Smuzhiyun spi_write_com(spi, 0xD629); spi_write_dat(spi, 0x51);
452*4882a593Smuzhiyun spi_write_com(spi, 0xD62A); spi_write_dat(spi, 0x03);
453*4882a593Smuzhiyun spi_write_com(spi, 0xD62B); spi_write_dat(spi, 0x80);
454*4882a593Smuzhiyun spi_write_com(spi, 0xD62C); spi_write_dat(spi, 0x03);
455*4882a593Smuzhiyun spi_write_com(spi, 0xD62D); spi_write_dat(spi, 0x9F);
456*4882a593Smuzhiyun spi_write_com(spi, 0xD62E); spi_write_dat(spi, 0x03);
457*4882a593Smuzhiyun spi_write_com(spi, 0xD62F); spi_write_dat(spi, 0xBE);
458*4882a593Smuzhiyun spi_write_com(spi, 0xD630); spi_write_dat(spi, 0x03);
459*4882a593Smuzhiyun spi_write_com(spi, 0xD631); spi_write_dat(spi, 0xF9);
460*4882a593Smuzhiyun spi_write_com(spi, 0xD632); spi_write_dat(spi, 0x03);
461*4882a593Smuzhiyun spi_write_com(spi, 0xD633); spi_write_dat(spi, 0xFF);
462*4882a593Smuzhiyun
463*4882a593Smuzhiyun /* LV2 Page 0 enable */
464*4882a593Smuzhiyun spi_write_com(spi, 0xF000); spi_write_dat(spi, 0x55);
465*4882a593Smuzhiyun spi_write_com(spi, 0xF001); spi_write_dat(spi, 0xAA);
466*4882a593Smuzhiyun spi_write_com(spi, 0xF002); spi_write_dat(spi, 0x52);
467*4882a593Smuzhiyun spi_write_com(spi, 0xF003); spi_write_dat(spi, 0x08);
468*4882a593Smuzhiyun spi_write_com(spi, 0xF004); spi_write_dat(spi, 0x00);
469*4882a593Smuzhiyun
470*4882a593Smuzhiyun /* Display control */
471*4882a593Smuzhiyun spi_write_com(spi, 0xB100); spi_write_dat(spi, 0xFC);
472*4882a593Smuzhiyun spi_write_com(spi, 0xB101); spi_write_dat(spi, 0x00);
473*4882a593Smuzhiyun
474*4882a593Smuzhiyun /* Source hold time */
475*4882a593Smuzhiyun spi_write_com(spi, 0xB600); spi_write_dat(spi, 0x05);
476*4882a593Smuzhiyun
477*4882a593Smuzhiyun /* Gate EQ control */
478*4882a593Smuzhiyun spi_write_com(spi, 0xB700); spi_write_dat(spi, 0x70);
479*4882a593Smuzhiyun spi_write_com(spi, 0xB701); spi_write_dat(spi, 0x70);
480*4882a593Smuzhiyun
481*4882a593Smuzhiyun /* Source EQ control (Mode 2) */
482*4882a593Smuzhiyun spi_write_com(spi, 0xB800); spi_write_dat(spi, 0x01);
483*4882a593Smuzhiyun spi_write_com(spi, 0xB801); spi_write_dat(spi, 0x05);
484*4882a593Smuzhiyun spi_write_com(spi, 0xB802); spi_write_dat(spi, 0x05);
485*4882a593Smuzhiyun spi_write_com(spi, 0xB803); spi_write_dat(spi, 0x05);
486*4882a593Smuzhiyun
487*4882a593Smuzhiyun /* Inversion mode (Column) */
488*4882a593Smuzhiyun spi_write_com(spi, 0xBC00); spi_write_dat(spi, 0x00);
489*4882a593Smuzhiyun spi_write_com(spi, 0xBC01); spi_write_dat(spi, 0x00);
490*4882a593Smuzhiyun spi_write_com(spi, 0xBC02); spi_write_dat(spi, 0x00);
491*4882a593Smuzhiyun
492*4882a593Smuzhiyun /* Timing control 8phase dual side/4H/4delay/RST_EN */
493*4882a593Smuzhiyun spi_write_com(spi, 0xC900); spi_write_dat(spi, 0xD0);
494*4882a593Smuzhiyun spi_write_com(spi, 0xC901); spi_write_dat(spi, 0x82);
495*4882a593Smuzhiyun spi_write_com(spi, 0xC902); spi_write_dat(spi, 0x50);
496*4882a593Smuzhiyun spi_write_com(spi, 0xC903); spi_write_dat(spi, 0x50);
497*4882a593Smuzhiyun spi_write_com(spi, 0xC904); spi_write_dat(spi, 0x50);
498*4882a593Smuzhiyun
499*4882a593Smuzhiyun spi_write_com(spi, 0x3A00); spi_write_dat(spi, 0x55);
500*4882a593Smuzhiyun mdelay(120);
501*4882a593Smuzhiyun spi_write_com(spi, 0x1100);
502*4882a593Smuzhiyun mdelay(120);
503*4882a593Smuzhiyun spi_write_com(spi, 0x2900);
504*4882a593Smuzhiyun mdelay(120);
505*4882a593Smuzhiyun /* spi_write_com(spi, 0x2100); spi_write_dat(spi, 0x00); */
506*4882a593Smuzhiyun spi_write_com(spi, 0x2C00);
507*4882a593Smuzhiyun
508*4882a593Smuzhiyun return 0;
509*4882a593Smuzhiyun err_claim_bus:
510*4882a593Smuzhiyun spi_free_slave(spi);
511*4882a593Smuzhiyun return -1;
512*4882a593Smuzhiyun }
513