blob: 941eefc199579961f6c9b3028cc46f7fab48bab7 [file] [log] [blame]
Greg Griscod6250552011-06-29 14:40:23 -07001/* Copyright (c) 2010-2011, Code Aurora Forum. All rights reserved.
Chandan Uddaraju78ae6752010-10-19 12:57:10 -07002 *
3 * Redistribution and use in source and binary forms, with or without
4 * modification, are permitted provided that the following conditions are
5 * met:
6 * * Redistributions of source code must retain the above copyright
7 * notice, this list of conditions and the following disclaimer.
8 * * Redistributions in binary form must reproduce the above
9 * copyright notice, this list of conditions and the following
10 * disclaimer in the documentation and/or other materials provided
11 * with the distribution.
12 * * Neither the name of Code Aurora Forum, Inc. nor the names of its
13 * contributors may be used to endorse or promote products derived
14 * from this software without specific prior written permission.
15 *
16 * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED
17 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
18 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT
19 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS
20 * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
21 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
22 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
23 * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
24 * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
25 * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
26 * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27 *
28 */
29
30#include <reg.h>
Shashank Mittalcbd271d2011-01-14 15:18:33 -080031#include <endian.h>
Chandan Uddaraju78ae6752010-10-19 12:57:10 -070032#include <mipi_dsi.h>
33#include <dev/fbcon.h>
34#include <target/display.h>
Greg Griscod6250552011-06-29 14:40:23 -070035#include <stdlib.h>
Chandan Uddaraju78ae6752010-10-19 12:57:10 -070036
37#define MIPI_FB_ADDR 0x43E00000
38
Chandan Uddarajufe93e822010-11-21 20:44:47 -080039#if DISPLAY_MIPI_PANEL_TOSHIBA
Chandan Uddaraju78ae6752010-10-19 12:57:10 -070040static struct fbcon_config mipi_fb_cfg = {
41 .height = TSH_MIPI_FB_HEIGHT,
42 .width = TSH_MIPI_FB_WIDTH,
43 .stride = TSH_MIPI_FB_WIDTH,
44 .format = FB_FORMAT_RGB888,
45 .bpp = 24,
46 .update_start = NULL,
47 .update_done = NULL,
48};
Chandan Uddarajufe93e822010-11-21 20:44:47 -080049#elif DISPLAY_MIPI_PANEL_NOVATEK_BLUE
50static struct fbcon_config mipi_fb_cfg = {
51 .height = NOV_MIPI_FB_HEIGHT,
52 .width = NOV_MIPI_FB_WIDTH,
53 .stride = NOV_MIPI_FB_WIDTH,
54 .format = FB_FORMAT_RGB888,
55 .bpp = 24,
56 .update_start = NULL,
57 .update_done = NULL,
58};
59#else
60static struct fbcon_config mipi_fb_cfg = {
61 .height = 0,
62 .width = 0,
63 .stride = 0,
64 .format = 0,
65 .bpp = 0,
66 .update_start = NULL,
67 .update_done = NULL,
68};
69#endif
70
71static int cmd_mode_status = 0;
Greg Griscod6250552011-06-29 14:40:23 -070072void secure_writel(uint32_t, uint32_t);
73uint32_t secure_readl(uint32_t);
Chandan Uddaraju78ae6752010-10-19 12:57:10 -070074
75void configure_dsicore_dsiclk()
76{
77 unsigned char mnd_mode, root_en, clk_en;
Chandan Uddarajufe93e822010-11-21 20:44:47 -080078 unsigned long src_sel = 0x3; // dsi_phy_pll0_src
Chandan Uddaraju78ae6752010-10-19 12:57:10 -070079 unsigned long pre_div_func = 0x00; // predivide by 1
80 unsigned long pmxo_sel;
81
Chandan Uddaraju3cbbd302011-03-11 11:48:11 -080082 secure_writel(pre_div_func << 14 | src_sel, MMSS_DSI_NS);
Chandan Uddarajufe93e822010-11-21 20:44:47 -080083 mnd_mode = 0; // Bypass MND
Chandan Uddaraju78ae6752010-10-19 12:57:10 -070084 root_en = 1;
85 clk_en = 1;
86 pmxo_sel = 0;
87
Chandan Uddaraju3cbbd302011-03-11 11:48:11 -080088 secure_writel((pmxo_sel << 8) | (mnd_mode << 6), MMSS_DSI_CC);
89 secure_writel(secure_readl(MMSS_DSI_CC) | root_en << 2, MMSS_DSI_CC);
90 secure_writel(secure_readl(MMSS_DSI_CC) | clk_en, MMSS_DSI_CC);
Chandan Uddaraju78ae6752010-10-19 12:57:10 -070091}
92
93void configure_dsicore_byteclk(void)
94{
Chandan Uddaraju3cbbd302011-03-11 11:48:11 -080095 secure_writel(0x00400401, MMSS_MISC_CC2); // select pxo
Chandan Uddaraju78ae6752010-10-19 12:57:10 -070096}
97
98void configure_dsicore_pclk(void)
99{
Chandan Uddaraju78ae6752010-10-19 12:57:10 -0700100 unsigned char mnd_mode, root_en, clk_en;
101 unsigned long src_sel = 0x3; // dsi_phy_pll0_src
102 unsigned long pre_div_func = 0x01; // predivide by 2
103
Chandan Uddaraju3cbbd302011-03-11 11:48:11 -0800104 secure_writel(pre_div_func << 12 | src_sel, MMSS_DSI_PIXEL_NS);
Chandan Uddaraju78ae6752010-10-19 12:57:10 -0700105
Chandan Uddarajufe93e822010-11-21 20:44:47 -0800106 mnd_mode = 0; // Bypass MND
Chandan Uddaraju78ae6752010-10-19 12:57:10 -0700107 root_en = 1;
108 clk_en = 1;
Chandan Uddaraju3cbbd302011-03-11 11:48:11 -0800109 secure_writel(mnd_mode << 6, MMSS_DSI_PIXEL_CC);
110 secure_writel(secure_readl(MMSS_DSI_PIXEL_CC) | root_en << 2,
111 MMSS_DSI_PIXEL_CC);
112 secure_writel(secure_readl(MMSS_DSI_PIXEL_CC) | clk_en,
113 MMSS_DSI_PIXEL_CC);
Chandan Uddaraju78ae6752010-10-19 12:57:10 -0700114}
115
Chandan Uddarajufe93e822010-11-21 20:44:47 -0800116int mipi_dsi_phy_ctrl_config(struct mipi_dsi_panel_config *pinfo)
Chandan Uddaraju78ae6752010-10-19 12:57:10 -0700117{
118
Chandan Uddarajufe93e822010-11-21 20:44:47 -0800119 unsigned i;
120 unsigned off = 0;
121 struct mipi_dsi_phy_ctrl *pd;
Chandan Uddaraju78ae6752010-10-19 12:57:10 -0700122
123 writel(0x00000001, DSI_PHY_SW_RESET);
Chandan Uddarajufe93e822010-11-21 20:44:47 -0800124 mdelay(50);
Chandan Uddaraju78ae6752010-10-19 12:57:10 -0700125 writel(0x00000000, DSI_PHY_SW_RESET);
126
Chandan Uddarajufe93e822010-11-21 20:44:47 -0800127 pd = (pinfo->dsi_phy_config);
Chandan Uddaraju78ae6752010-10-19 12:57:10 -0700128
Chandan Uddarajufe93e822010-11-21 20:44:47 -0800129 off = 0x02cc; /* regulator ctrl 0 */
130 for (i = 0; i < 4; i++) {
131 writel(pd->regulator[i], MIPI_DSI_BASE + off);
132 off += 4;
133 }
134
135 off = 0x0260; /* phy timig ctrl 0 */
136 for (i = 0; i < 11; i++) {
137 writel(pd->timing[i], MIPI_DSI_BASE + off);
138 off += 4;
139 }
Chandan Uddaraju78ae6752010-10-19 12:57:10 -0700140
141 // T_CLK_POST, T_CLK_PRE for CLK lane P/N HS 200 mV timing length should >
142 // data lane HS timing length
Chandan Uddarajufe93e822010-11-21 20:44:47 -0800143 writel(0xa1e, DSI_CLKOUT_TIMING_CTRL);
Chandan Uddaraju78ae6752010-10-19 12:57:10 -0700144
Chandan Uddarajufe93e822010-11-21 20:44:47 -0800145 off = 0x0290; /* ctrl 0 */
146 for (i = 0; i < 4; i++) {
147 writel(pd->ctrl[i], MIPI_DSI_BASE + off);
148 off += 4;
Chandan Uddaraju78ae6752010-10-19 12:57:10 -0700149 }
150
Chandan Uddarajufe93e822010-11-21 20:44:47 -0800151 off = 0x02a0; /* strength 0 */
152 for (i = 0; i < 4; i++) {
153 writel(pd->strength[i], MIPI_DSI_BASE + off);
154 off += 4;
155 }
156
157 off = 0x0204; /* pll ctrl 1, skip 0 */
158 for (i = 1; i < 21; i++) {
159 writel(pd->pll[i], MIPI_DSI_BASE + off);
160 off += 4;
161 }
162
163 /* pll ctrl 0 */
164 writel(pd->pll[0], MIPI_DSI_BASE + 0x200);
165 writel((pd->pll[0] | 0x01), MIPI_DSI_BASE + 0x200);
Chandan Uddaraju78ae6752010-10-19 12:57:10 -0700166
167 return (0);
168}
169
Chandan Uddarajufe93e822010-11-21 20:44:47 -0800170struct mipi_dsi_panel_config *get_panel_info(void)
171{
172#if DISPLAY_MIPI_PANEL_TOSHIBA
173 return &toshiba_panel_info;
174#elif DISPLAY_MIPI_PANEL_NOVATEK_BLUE
175 return &novatek_panel_info;
176#endif
177 return NULL;
178
179}
180
Chandan Uddaraju78ae6752010-10-19 12:57:10 -0700181int dsi_cmd_dma_trigger_for_panel()
182{
183 unsigned long ReadValue;
184 unsigned long count = 0;
185 int status = 0;
186
187 writel(0x03030303, DSI_INT_CTRL);
Chandan Uddarajufe93e822010-11-21 20:44:47 -0800188 mdelay(10);
Chandan Uddaraju78ae6752010-10-19 12:57:10 -0700189 writel(0x1, DSI_CMD_MODE_DMA_SW_TRIGGER);
190 ReadValue = readl(DSI_INT_CTRL) & 0x00000001;
191 while (ReadValue != 0x00000001) {
192 ReadValue = readl(DSI_INT_CTRL) & 0x00000001;
193 count++;
194 if (count > 0xffff) {
195 status = FAIL;
196 printf("\n\nThis command mode dma test is failed");
197 return status;
198 }
199 }
200
201 writel((readl(DSI_INT_CTRL) | 0x01000001), DSI_INT_CTRL);
202 printf
203 ("\n\nThis command mode is tested successfully, continue on next command mode test");
204 return status;
205}
206
Chandan Uddarajuc1df5652011-03-03 21:15:51 -0800207
Chandan Uddarajufe93e822010-11-21 20:44:47 -0800208int mipi_dsi_cmds_tx(struct mipi_dsi_cmd *cmds, int count)
Chandan Uddaraju78ae6752010-10-19 12:57:10 -0700209{
Chandan Uddarajufe93e822010-11-21 20:44:47 -0800210 int ret = 0;
211 struct mipi_dsi_cmd *cm;
212 int i = 0;
Chandan Uddaraju78ae6752010-10-19 12:57:10 -0700213
Chandan Uddarajufe93e822010-11-21 20:44:47 -0800214 cm = cmds;
215 for (i = 0; i < count; i++) {
216 memcpy(DSI_CMD_DMA_MEM_START_ADDR_PANEL, (cm->payload), cm->size);
217 writel(DSI_CMD_DMA_MEM_START_ADDR_PANEL, DSI_DMA_CMD_OFFSET);
218 writel(cm->size, DSI_DMA_CMD_LENGTH); // reg 0x48 for this build
219 ret += dsi_cmd_dma_trigger_for_panel();
220 mdelay(10);
221 cm++;
222 }
223 return ret;
224}
225
Shashank Mittalcbd271d2011-01-14 15:18:33 -0800226/*
227 * mipi_dsi_cmd_rx: can receive at most 16 bytes
228 * per transaction since it only have 4 32bits reigsters
229 * to hold data.
230 * therefore Maximum Return Packet Size need to be set to 16.
231 * any return data more than MRPS need to be break down
232 * to multiple transactions.
233 */
234int mipi_dsi_cmds_rx(char **rp, int len)
235{
236 uint32_t *lp, data;
237 char * dp;
238 int i, off, cnt;
239 int rlen, res;
240
241 if(len <= 2)
242 rlen = 4; /* short read */
243 else
244 rlen = MIPI_DSI_MRPS + 6; /* 4 bytes header + 2 bytes crc */
245
246 if (rlen > MIPI_DSI_REG_LEN) {
247 return 0;
248 }
249
250 res = rlen & 0x03;
251
252 rlen += res; /* 4 byte align */
253 lp = (uint32_t *)(*rp);
254
255 cnt = rlen;
256 cnt += 3;
257 cnt >>=2;
258
259 if (cnt > 4)
260 cnt = 4; /* 4 x 32 bits registers only */
261
262 off = 0x068; /* DSI_RDBK_DATA0 */
263 off += ((cnt - 1) * 4);
264
265 for (i = 0; i < cnt; i++) {
266 data = (uint32_t)readl(MIPI_DSI_BASE + off);
267 *lp++ = ntohl(data); /* to network byte order */
268 off -= 4;
269 }
270
271 if(len > 2)
272 {
273 /*First 4 bytes + paded bytes will be header next len bytes would be payload*/
274 for(i = 0; i < len; i++)
275 {
276 dp = *rp;
277 dp[i] = dp[4 + res + i];
278 }
279 }
280
281 return len;
282}
283
284static int mipi_dsi_cmd_bta_sw_trigger(void)
285{
286 uint32_t data;
287 int cnt = 0;
288 int err = 0;
289
290 writel(0x01, MIPI_DSI_BASE + 0x094); /* trigger */
291 while (cnt < 10000) {
292 data = readl(MIPI_DSI_BASE + 0x0004); /*DSI_STATUS*/
293 if ((data & 0x0010) == 0)
294 break;
295 cnt++;
296 }
297 if(cnt == 10000)
298 err = 1;
299 return err;
300}
301
302static uint32_t mipi_novatek_manufacture_id(void)
303{
304 char rec_buf[24];
305 char *rp = rec_buf;
306 uint32_t *lp, data;
307
308 mipi_dsi_cmds_tx(&novatek_panel_manufacture_id_cmd, 1);
309 mipi_dsi_cmds_rx(&rp, 3);
310
311 lp = (uint32_t *)rp;
312 data = (uint32_t)*lp;
313 data = ntohl(data);
314 data = data >> 8;
315 return data;
316}
317
Chandan Uddarajufe93e822010-11-21 20:44:47 -0800318int mipi_dsi_panel_initialize(struct mipi_dsi_panel_config *pinfo)
319{
Chandan Uddaraju78ae6752010-10-19 12:57:10 -0700320 unsigned char DMA_STREAM1 = 0; // for mdp display processor path
321 unsigned char EMBED_MODE1 = 1; // from frame buffer
322 unsigned char POWER_MODE2 = 1; // from frame buffer
323 unsigned char PACK_TYPE1 = 1; // long packet
324 unsigned char VC1 = 0;
325 unsigned char DT1 = 0; // non embedded mode
326 unsigned short WC1 = 0; // for non embedded mode only
327 int status = 0;
Chandan Uddarajufe93e822010-11-21 20:44:47 -0800328 unsigned char DLNx_EN;
Chandan Uddaraju78ae6752010-10-19 12:57:10 -0700329
Chandan Uddarajufe93e822010-11-21 20:44:47 -0800330 switch (pinfo->num_of_lanes) {
331 default:
332 case 1:
333 DLNx_EN = 1; // 1 lane
334 break;
335 case 2:
336 DLNx_EN = 3; // 2 lane
337 break;
338 case 3:
339 DLNx_EN = 7; // 3 lane
340 break;
341 }
342
343 writel(0x0001, DSI_SOFT_RESET);
344 writel(0x0000, DSI_SOFT_RESET);
345
Chandan Uddaraju78ae6752010-10-19 12:57:10 -0700346 writel((0 << 16) | 0x3f, DSI_CLK_CTRL); // reg:0x118
347 writel(DMA_STREAM1 << 8 | 0x04, DSI_TRIG_CTRL); // reg 0x80 dma trigger: sw
Chandan Uddarajufe93e822010-11-21 20:44:47 -0800348 // trigger 0x4; dma stream1
Chandan Uddaraju78ae6752010-10-19 12:57:10 -0700349 writel(0 << 30 | DLNx_EN << 4 | 0x105, DSI_CTRL); // reg 0x00 for this
Chandan Uddarajufe93e822010-11-21 20:44:47 -0800350 // build
Chandan Uddaraju78ae6752010-10-19 12:57:10 -0700351 writel(EMBED_MODE1 << 28 | POWER_MODE2 << 26
352 | PACK_TYPE1 << 24 | VC1 << 22 | DT1 << 16 | WC1,
353 DSI_COMMAND_MODE_DMA_CTRL);
Chandan Uddaraju78ae6752010-10-19 12:57:10 -0700354
Chandan Uddarajufe93e822010-11-21 20:44:47 -0800355 status = mipi_dsi_cmds_tx(pinfo->panel_cmds, pinfo->num_of_panel_cmds);
Chandan Uddaraju78ae6752010-10-19 12:57:10 -0700356
357 return status;
358}
359
360int config_dsi_video_mode(unsigned short disp_width, unsigned short disp_height,
361 unsigned short img_width, unsigned short img_height,
362 unsigned short hsync_porch0_fp,
363 unsigned short hsync_porch0_bp,
364 unsigned short vsync_porch0_fp,
365 unsigned short vsync_porch0_bp,
366 unsigned short hsync_width,
367 unsigned short vsync_width, unsigned short dst_format,
368 unsigned short traffic_mode,
369 unsigned short datalane_num)
370{
371
372 unsigned char DST_FORMAT;
373 unsigned char TRAFIC_MODE;
374 unsigned char DLNx_EN;
375 // video mode data ctrl
376 int status = 0;
377 unsigned long low_pwr_stop_mode = 0;
378 unsigned char eof_bllp_pwr = 0x9;
379 unsigned char interleav = 0;
380
381 // disable mdp first
382 writel(0x00000000, MDP_DSI_VIDEO_EN);
383
384 writel(0x00000000, DSI_CLK_CTRL);
385 writel(0x00000000, DSI_CLK_CTRL);
386 writel(0x00000000, DSI_CLK_CTRL);
387 writel(0x00000000, DSI_CLK_CTRL);
388 writel(0x00000002, DSI_CLK_CTRL);
389 writel(0x00000006, DSI_CLK_CTRL);
390 writel(0x0000000e, DSI_CLK_CTRL);
391 writel(0x0000001e, DSI_CLK_CTRL);
392 writel(0x0000003e, DSI_CLK_CTRL);
393
394 writel(0, DSI_CTRL);
395
396 writel(0, DSI_ERR_INT_MASK0);
397
398 DST_FORMAT = 0; // RGB565
399 printf("\nDSI_Video_Mode - Dst Format: RGB565");
400
401 DLNx_EN = 1; // 1 lane with clk programming
402 printf("\nData Lane: 1 lane\n");
403
404 TRAFIC_MODE = 0; // non burst mode with sync pulses
405 printf("\nTraffic mode: non burst mode with sync pulses\n");
406
407 writel(0x02020202, DSI_INT_CTRL);
408
409 writel(((img_width + hsync_porch0_bp) << 16) | hsync_porch0_bp,
410 DSI_VIDEO_MODE_ACTIVE_H);
411
412 writel(((img_height + vsync_porch0_bp) << 16) | (vsync_porch0_bp),
413 DSI_VIDEO_MODE_ACTIVE_V);
414
415 writel(((img_height + vsync_porch0_fp + vsync_porch0_bp) << 16)
416 | img_width + hsync_porch0_fp + hsync_porch0_bp,
417 DSI_VIDEO_MODE_TOTAL);
418
419 writel((hsync_width << 16) | 0, DSI_VIDEO_MODE_HSYNC);
420
421 writel(0 << 16 | 0, DSI_VIDEO_MODE_VSYNC);
422
423 writel(vsync_width << 16 | 0, DSI_VIDEO_MODE_VSYNC_VPOS);
424
425 writel(1, DSI_EOT_PACKET_CTRL);
426
427 writel(0x00000100, DSI_MISR_VIDEO_CTRL);
428
429 writel(low_pwr_stop_mode << 16 | eof_bllp_pwr << 12 | TRAFIC_MODE << 8
430 | DST_FORMAT << 4 | 0x0, DSI_VIDEO_MODE_CTRL);
431
432 writel(0x67, DSI_CAL_STRENGTH_CTRL);
433
434 writel(0x80006711, DSI_CAL_CTRL);
435
436 writel(0x00010100, DSI_MISR_VIDEO_CTRL);
437
438 writel(0x00010100, DSI_INT_CTRL);
439 writel(0x02010202, DSI_INT_CTRL);
440
441 writel(0x02030303, DSI_INT_CTRL);
442
443 writel(interleav << 30 | 0 << 24 | 0 << 20 | DLNx_EN << 4
444 | 0x103, DSI_CTRL);
Chandan Uddarajufe93e822010-11-21 20:44:47 -0800445 mdelay(10);
Chandan Uddaraju78ae6752010-10-19 12:57:10 -0700446
447 return status;
448}
449
Chandan Uddarajufe93e822010-11-21 20:44:47 -0800450int config_dsi_cmd_mode(unsigned short disp_width, unsigned short disp_height,
451 unsigned short img_width, unsigned short img_height,
452 unsigned short dst_format,
453 unsigned short traffic_mode,
454 unsigned short datalane_num)
455{
456 unsigned char DST_FORMAT;
457 unsigned char TRAFIC_MODE;
458 unsigned char DLNx_EN;
459 // video mode data ctrl
460 int status = 0;
Greg Griscod6250552011-06-29 14:40:23 -0700461 unsigned char interleav = 0;
462 unsigned char ystride = 0x03;
Chandan Uddarajufe93e822010-11-21 20:44:47 -0800463 // disable mdp first
464
465 writel(0x00000000, DSI_CLK_CTRL);
466 writel(0x00000000, DSI_CLK_CTRL);
467 writel(0x00000000, DSI_CLK_CTRL);
468 writel(0x00000000, DSI_CLK_CTRL);
469 writel(0x00000002, DSI_CLK_CTRL);
470 writel(0x00000006, DSI_CLK_CTRL);
471 writel(0x0000000e, DSI_CLK_CTRL);
472 writel(0x0000001e, DSI_CLK_CTRL);
473 writel(0x0000003e, DSI_CLK_CTRL);
474
475 writel(0x10000000, DSI_ERR_INT_MASK0);
476
477 // writel(0, DSI_CTRL);
478
479 // writel(0, DSI_ERR_INT_MASK0);
480
481 DST_FORMAT = 8; // RGB888
482 printf("\nDSI_Cmd_Mode - Dst Format: RGB888");
483
484 DLNx_EN = 3; // 2 lane with clk programming
485 printf("\nData Lane: 2 lane\n");
486
487 TRAFIC_MODE = 0; // non burst mode with sync pulses
488 printf("\nTraffic mode: non burst mode with sync pulses\n");
489
490 writel(0x02020202, DSI_INT_CTRL);
491
492 writel(0x00100000 | DST_FORMAT, DSI_COMMAND_MODE_MDP_CTRL);
493 writel((img_width * ystride + 1) << 16 | 0x0039,
494 DSI_COMMAND_MODE_MDP_STREAM0_CTRL);
495 writel((img_width * ystride + 1) << 16 | 0x0039,
496 DSI_COMMAND_MODE_MDP_STREAM1_CTRL);
497 writel(img_height << 16 | img_width, DSI_COMMAND_MODE_MDP_STREAM0_TOTAL);
498 writel(img_height << 16 | img_width, DSI_COMMAND_MODE_MDP_STREAM1_TOTAL);
499 writel(0xEE, DSI_CAL_STRENGTH_CTRL);
500 writel(0x80000000, DSI_CAL_CTRL);
501 writel(0x40, DSI_TRIG_CTRL);
502 writel(0x13c2c, DSI_COMMAND_MODE_MDP_DCS_CMD_CTRL);
503 writel(interleav << 30 | 0 << 24 | 0 << 20 | DLNx_EN << 4 | 0x105,
504 DSI_CTRL);
505 mdelay(10);
506 writel(0x10000000, DSI_COMMAND_MODE_DMA_CTRL);
507 writel(0x10000000, DSI_MISR_CMD_CTRL);
508 writel(0x00000040, DSI_ERR_INT_MASK0);
509 writel(0x1, DSI_EOT_PACKET_CTRL);
510 // writel(0x0, MDP_OVERLAYPROC0_START);
511 writel(0x00000001, MDP_DMA_P_START);
512 mdelay(10);
513 writel(0x1, DSI_CMD_MODE_MDP_SW_TRIGGER);
514
515 status = 1;
516 return status;
517}
518
Chandan Uddaraju78ae6752010-10-19 12:57:10 -0700519int mdp_setup_dma_p_video_mode(unsigned short disp_width,
520 unsigned short disp_height,
521 unsigned short img_width,
522 unsigned short img_height,
523 unsigned short hsync_porch0_fp,
524 unsigned short hsync_porch0_bp,
525 unsigned short vsync_porch0_fp,
526 unsigned short vsync_porch0_bp,
527 unsigned short hsync_width,
528 unsigned short vsync_width,
529 unsigned long input_img_addr,
530 unsigned short img_width_full_size,
531 unsigned short pack_pattern,
532 unsigned char ystride)
533{
534
535 // unsigned long mdp_intr_status;
536 int status = FAIL;
537 unsigned long hsync_period;
538 unsigned long vsync_period;
539 unsigned long vsync_period_intmd;
540
541 printf("\nHi setup MDP4.1 for DSI Video Mode\n");
542
543 hsync_period = img_width + hsync_porch0_fp + hsync_porch0_bp + 1;
544 vsync_period_intmd = img_height + vsync_porch0_fp + vsync_porch0_bp + 1;
545 vsync_period = vsync_period_intmd * hsync_period;
546
547 // ----- programming MDP_AXI_RDMASTER_CONFIG --------
548 /* MDP_AXI_RDMASTER_CONFIG set all master to read from AXI port 0, that's
549 the only port connected */
550 writel(0x00290000, MDP_AXI_RDMASTER_CONFIG);
551 writel(0x00000004, MDP_AXI_WRMASTER_CONFIG);
552 writel(0x00007777, MDP_MAX_RD_PENDING_CMD_CONFIG);
553 writel(0x00000049, MDP_DISP_INTF_SEL);
554 writel(0x0000000b, MDP_OVERLAYPROC0_CFG);
555
556 // ------------- programming MDP_DMA_P_CONFIG ---------------------
557 writel(pack_pattern << 8 | 0xbf | (0 << 25), MDP_DMA_P_CONFIG); // rgb888
558
559 writel(0x00000000, MDP_DMA_P_OUT_XY);
560 writel(img_height << 16 | img_width, MDP_DMA_P_SIZE);
561 writel(input_img_addr, MDP_DMA_P_BUF_ADDR);
562 writel(img_width_full_size * ystride, MDP_DMA_P_BUF_Y_STRIDE);
563 writel(0x00ff0000, MDP_DMA_P_OP_MODE);
564 writel(hsync_period << 16 | hsync_width, MDP_DSI_VIDEO_HSYNC_CTL);
565 writel(vsync_period, MDP_DSI_VIDEO_VSYNC_PERIOD);
566 writel(vsync_width * hsync_period, MDP_DSI_VIDEO_VSYNC_PULSE_WIDTH);
567 writel((img_width + hsync_porch0_bp - 1) << 16 | hsync_porch0_bp,
568 MDP_DSI_VIDEO_DISPLAY_HCTL);
569 writel(vsync_porch0_bp * hsync_period, MDP_DSI_VIDEO_DISPLAY_V_START);
570 writel((img_height + vsync_porch0_bp) * hsync_period,
571 MDP_DSI_VIDEO_DISPLAY_V_END);
572 writel(0x00ABCDEF, MDP_DSI_VIDEO_BORDER_CLR);
573 writel(0x00000000, MDP_DSI_VIDEO_HSYNC_SKEW);
574 writel(0x00000000, MDP_DSI_VIDEO_CTL_POLARITY);
575 // end of cmd mdp
576
577 writel(0x00000001, MDP_DSI_VIDEO_EN); // MDP_DSI_EN ENABLE
578
579 status = PASS;
580 return status;
581}
582
Chandan Uddarajufe93e822010-11-21 20:44:47 -0800583int mipi_dsi_video_config(unsigned short num_of_lanes)
Chandan Uddaraju78ae6752010-10-19 12:57:10 -0700584{
585
586 int status = 0;
587 unsigned long ReadValue;
588 unsigned long count = 0;
589 unsigned long low_pwr_stop_mode = 0; // low power mode 0x1111 start from
Chandan Uddarajufe93e822010-11-21 20:44:47 -0800590 // bit16, high spd mode 0x0
Chandan Uddaraju78ae6752010-10-19 12:57:10 -0700591 unsigned char eof_bllp_pwr = 0x9; // bit 12, 15, 1:low power stop mode or
Chandan Uddarajufe93e822010-11-21 20:44:47 -0800592 // let cmd mode eng send packets in hs
593 // or lp mode
Chandan Uddaraju78ae6752010-10-19 12:57:10 -0700594 unsigned short display_wd = mipi_fb_cfg.width;
595 unsigned short display_ht = mipi_fb_cfg.height;
596 unsigned short image_wd = mipi_fb_cfg.width;
597 unsigned short image_ht = mipi_fb_cfg.height;
598 unsigned short hsync_porch_fp = MIPI_HSYNC_FRONT_PORCH_DCLK;
599 unsigned short hsync_porch_bp = MIPI_HSYNC_BACK_PORCH_DCLK;
600 unsigned short vsync_porch_fp = MIPI_VSYNC_FRONT_PORCH_LINES;
601 unsigned short vsync_porch_bp = MIPI_VSYNC_BACK_PORCH_LINES;
602 unsigned short hsync_width = MIPI_HSYNC_PULSE_WIDTH;
603 unsigned short vsync_width = MIPI_VSYNC_PULSE_WIDTH;
604 unsigned short dst_format = 0;
605 unsigned short traffic_mode = 0;
606 unsigned short pack_pattern = 0x12;
607 unsigned char ystride = 3;
608
609 low_pwr_stop_mode = 0x1111; // low pwr mode bit16:HSA, bit20:HBA,
Chandan Uddarajufe93e822010-11-21 20:44:47 -0800610 // bit24:HFP, bit28:PULSE MODE, need enough
611 // time for swithc from LP to HS
Chandan Uddaraju78ae6752010-10-19 12:57:10 -0700612 eof_bllp_pwr = 0x9; // low power stop mode or let cmd mode eng send
Chandan Uddarajufe93e822010-11-21 20:44:47 -0800613 // packets in hs or lp mode
Chandan Uddaraju78ae6752010-10-19 12:57:10 -0700614
615 status += config_dsi_video_mode(display_wd, display_ht, image_wd, image_ht,
616 hsync_porch_fp, hsync_porch_bp,
617 vsync_porch_fp, vsync_porch_bp, hsync_width,
618 vsync_width, dst_format, traffic_mode,
619 num_of_lanes);
620
621 status +=
622 mdp_setup_dma_p_video_mode(display_wd, display_ht, image_wd, image_ht,
623 hsync_porch_fp, hsync_porch_bp,
624 vsync_porch_fp, vsync_porch_bp, hsync_width,
625 vsync_width, MIPI_FB_ADDR, image_wd,
626 pack_pattern, ystride);
627
628 ReadValue = readl(DSI_INT_CTRL) & 0x00010000;
629 while (ReadValue != 0x00010000) {
630 ReadValue = readl(DSI_INT_CTRL) & 0x00010000;
631 count++;
632 if (count > 0xffff) {
633 status = FAIL;
634 printf("\nToshiba Video 565 pulse 1 lane test is failed\n");
635 return status;
636 }
637 }
638
639 printf("\nToshiba Video 565 pulse 1 lane is tested successfully \n");
640 return status;
641}
642
Chandan Uddarajufe93e822010-11-21 20:44:47 -0800643int mipi_dsi_cmd_config(unsigned short num_of_lanes)
644{
645
646 int status = 0;
Chandan Uddarajufe93e822010-11-21 20:44:47 -0800647 unsigned long input_img_addr = MIPI_FB_ADDR;
Chandan Uddarajufe93e822010-11-21 20:44:47 -0800648 unsigned short image_wd = mipi_fb_cfg.width;
649 unsigned short image_ht = mipi_fb_cfg.height;
Chandan Uddarajufe93e822010-11-21 20:44:47 -0800650 unsigned short pack_pattern = 0x12;
651 unsigned char ystride = 3;
652
653 writel(0x03ffffff, MDP_INTR_ENABLE);
654 writel(0x0000000b, MDP_OVERLAYPROC0_CFG);
655
656 // ------------- programming MDP_DMA_P_CONFIG ---------------------
657 writel(pack_pattern << 8 | 0x3f | (0 << 25), MDP_DMA_P_CONFIG); // rgb888
658
659 writel(0x00000000, MDP_DMA_P_OUT_XY);
660 writel(image_ht << 16 | image_wd, MDP_DMA_P_SIZE);
661 writel(input_img_addr, MDP_DMA_P_BUF_ADDR);
662
663 writel(image_wd * ystride, MDP_DMA_P_BUF_Y_STRIDE);
664
665 writel(0x00000000, MDP_DMA_P_OP_MODE);
666
667 writel(0x10, MDP_DSI_CMD_MODE_ID_MAP);
668 writel(0x01, MDP_DSI_CMD_MODE_TRIGGER_EN);
669
670 writel(0x0001a000, MDP_AXI_RDMASTER_CONFIG);
671 writel(0x00000004, MDP_AXI_WRMASTER_CONFIG);
672 writel(0x00007777, MDP_MAX_RD_PENDING_CMD_CONFIG);
673 writel(0x8a, MDP_DISP_INTF_SEL);
674
675 return status;
676}
677
678int is_cmd_mode_enabled(void)
679{
680 return cmd_mode_status;
681}
682
683void mipi_dsi_cmd_mode_trigger(void)
684{
685 int status = 0;
686 unsigned short display_wd = mipi_fb_cfg.width;
687 unsigned short display_ht = mipi_fb_cfg.height;
688 unsigned short image_wd = mipi_fb_cfg.width;
689 unsigned short image_ht = mipi_fb_cfg.height;
690 unsigned short dst_format = 0;
691 unsigned short traffic_mode = 0;
692 struct mipi_dsi_panel_config *panel_info = &novatek_panel_info;
693 status += mipi_dsi_cmd_config(panel_info->num_of_lanes);
694 mdelay(50);
695 config_dsi_cmd_mode(display_wd, display_ht, image_wd, image_ht,
696 dst_format, traffic_mode,
697 panel_info->num_of_lanes /* num_of_lanes */ );
698}
699
Chandan Uddaraju78ae6752010-10-19 12:57:10 -0700700void mipi_dsi_shutdown(void)
701{
Chandan Uddarajuc1df5652011-03-03 21:15:51 -0800702 writel(0x00000000, MDP_DSI_VIDEO_EN);
703 mdelay(60);
704 writel(0x00000000, MDP_INTR_ENABLE);
705 writel(0x00000003, MDP_OVERLAYPROC0_CFG);
Ajay Dudani8fb36092011-01-27 18:09:50 -0800706 writel(0x01010101, DSI_INT_CTRL);
Chandan Uddarajuc1df5652011-03-03 21:15:51 -0800707 writel(0x13FF3BFF, DSI_ERR_INT_MASK0);
Ajay Dudani8fb36092011-01-27 18:09:50 -0800708 writel(0, DSIPHY_PLL_CTRL_0);
709 writel(0, DSI_CLK_CTRL);
710 writel(0, DSI_CTRL);
Chandan Uddarajuc1df5652011-03-03 21:15:51 -0800711 secure_writel(0x0, MMSS_DSI_CC);
712 secure_writel(0x0, MMSS_DSI_PIXEL_CC);
Chandan Uddaraju78ae6752010-10-19 12:57:10 -0700713}
714
715struct fbcon_config *mipi_init(void)
716{
717 int status = 0;
Chandan Uddarajufe93e822010-11-21 20:44:47 -0800718 struct mipi_dsi_panel_config *panel_info = get_panel_info();
Chandan Uddaraju78ae6752010-10-19 12:57:10 -0700719 writel(0x00001800, MMSS_SFPB_GPREG);
720 configure_dsicore_dsiclk();
721 configure_dsicore_byteclk();
722 configure_dsicore_pclk();
Chandan Uddarajufe93e822010-11-21 20:44:47 -0800723 mipi_dsi_phy_ctrl_config(panel_info);
724 status += mipi_dsi_panel_initialize(panel_info);
Shashank Mittalcbd271d2011-01-14 15:18:33 -0800725#if DISPLAY_MIPI_PANEL_NOVATEK_BLUE
726 mipi_dsi_cmd_bta_sw_trigger();
727 mipi_novatek_manufacture_id();
728#endif
Chandan Uddaraju78ae6752010-10-19 12:57:10 -0700729 mipi_fb_cfg.base = MIPI_FB_ADDR;
730
Chandan Uddarajufe93e822010-11-21 20:44:47 -0800731 if (panel_info->mode == MIPI_VIDEO_MODE)
732 status += mipi_dsi_video_config(panel_info->num_of_lanes);
733
734 if (panel_info->mode == MIPI_CMD_MODE)
735 cmd_mode_status = 1;
736
Chandan Uddaraju78ae6752010-10-19 12:57:10 -0700737 return &mipi_fb_cfg;
738}