comparison src/cs/drivers/drv_app/r2d/lcds/BW_D_Sample/r2d_task_init_i.c @ 0:945cf7f506b2

src/cs: chipsetsw import from tcs211-fcmodem binary blobs and LCD demo files have been excluded, all line endings are LF only
author Mychaela Falconia <falcon@freecalypso.org>
date Sun, 25 Sep 2016 22:50:11 +0000
parents
children 96c047b4325e
comparison
equal deleted inserted replaced
-1:000000000000 0:945cf7f506b2
1 /* Used by refresh task to extract bytes from the
2 framebuffer */
3
4 #include "r2d/lcds/bw_d_sample/r2d_tfd_lcd.h"
5
6 #include "main/sys_types.h"
7 #include "l1_types.h"
8 #include "memif/mem.h"
9
10
11 #define R2D_MB_PRIM_SIZE (4000)
12
13
14 const unsigned char INIT_DISCTL[11] = { 0xDE,0x01,0x64,0x00,0x1B,0xF4,0x00,0xDC,0x00,0x02,0x00};
15
16 const unsigned char INIT_GCP64[126] = {
17 0x15,0x00,0x29,0x00,0x3E,0x00,0x51,0x00, 0x65,0x00,0x7A,0x00,0x8D,0x00,0XA1,0x00,
18 0XB6,0x00,0XC7,0x00,0XD8,0x00,0XEB,0x00, 0XFB,0x00,0x0B,0x01,0X1B,0x01,0X27,0x01,
19 0x34,0x01,0x41,0x01,0x4C,0x01,0x55,0x01, 0x5F,0x01,0x68,0x01,0x70,0x01,0x78,0x01,
20 0x7E,0x01,0x86,0x01,0x8C,0x01,0x94,0x01, 0x9B,0x01,0XA1,0x01,0xA4,0x01,0xA9,0x01,
21 0xAD,0x01,0xB2,0x01,0xB7,0x01,0xBC,0x01, 0xC0,0x01,0xC4,0x01,0xC8,0x01,0xCB,0x01,
22 0xCF,0x01,0xD2,0x01,0xD5,0x01,0xD8,0x01, 0xDB,0x01,0xE0,0x01,0xE3,0x01,0xE6,0x01,
23 0xE8,0x01,0xEB,0x01,0xEE,0x01,0xF1,0x01, 0xF3,0x01,0xF8,0x01,0xF9,0x01,0xFC,0x01,
24 0x00,0x02,0x03,0x02,0x07,0x02,0x09,0x02, 0x0E,0x02,0x13,0x02,0x1C,0x02 };
25 const unsigned char INIT_GCP16[15] = {
26 0x1A,0x31,0x48,0x54,0x5F,0x67,0x70,0x76,0x7C,0x80,0x83,0x84,0x85,0x87,0x96 };
27
28 const unsigned char INIT_MD_PSET[4] = { 0x00, 0x01, 0x00, 0x01 };
29 const unsigned char INIT_MD_CSET[4] = { 0x00, 0x02, 0x00, 0x02 };
30
31 const unsigned char INIT_SD_PSET[4] = { 0, 0, 219, 0 };
32 const unsigned char INIT_SD_CSET[4] = { 2, 0, 177, 0 };
33
34 const unsigned char INIT_ASCSET[7] = { 0x00, 0x00, 0xDB, 0x00, 0xDC, 0x00, 0x01 };
35 const unsigned char INIT_SCSTART[2] = { 0x00, 0x00 };
36
37 static void r2d_nop_delay(UINT32 ms)
38 {
39 unsigned short a;
40 while (ms-- > 0) for (a=0;a<1000;a++) asm(" nop");
41 }
42
43 void r2d_refresh_task_init(void)
44 {
45
46 #ifndef _WINDOWS
47
48 UINT32 i;
49
50 LCD_activate;
51
52 LCD_cmd(LCD_DISOFF);
53 LCD_cmd(LCD_SLPIN);
54 LCD_cmd(LCD_DISNOR);
55 LCD_cmd(LCD_GSSET);
56 LCD_data(INIT_GSSET); // 64 gradients
57
58 r2d_nop_delay(100);
59
60
61 LCD_cmd(LCD_DISCTL); // Init LCD controller
62 for (i=0; i<11; i++) LCD_data(INIT_DISCTL[i]);
63
64 LCD_cmd(LCD_GCP64); // Init palette for 64 gradient palette
65 for (i=0; i<126; i++) LCD_data(INIT_GCP64[i]);
66
67 LCD_cmd(LCD_GCP16); // Init palette for 16 gradient palette
68
69 for (i=0; i<15; i++) LCD_data(INIT_GCP16[i]);
70
71 LCD_cmd(LCD_MD_CSET); // set area devoted to DSP interface
72 for (i=0; i<4; i++) LCD_data(INIT_MD_CSET[i]);
73
74 LCD_cmd(LCD_MD_PSET); // set area devoted to DSP interface
75
76 for (i=0; i<4; i++) LCD_data(INIT_MD_PSET[i]);
77
78 LCD_cmd(LCD_SD_CSET); // set area devoted to MPU interface
79 for (i=0; i<4; i++) LCD_data(INIT_SD_CSET[i]);
80
81 LCD_cmd(LCD_SD_PSET); // set area devoted to MPU interface
82 for (i=0; i<4; i++) LCD_data(INIT_SD_PSET[i]);
83
84 LCD_cmd(LCD_DATCTL);
85 LCD_data(INIT_DATCTL);//0x08);
86
87 LCD_cmd(LCD_OSCISEL);
88 LCD_data(INIT_OSCISEL);//0x05);
89
90 LCD_cmd(LCD_14MSET);
91 LCD_data(INIT_14MSET);//0x4B);
92
93 LCD_cmd(LCD_14MEND);
94
95 LCD_cmd(LCD_3500KSET);
96 LCD_data(INIT_3500KSET);//0x45);
97
98 LCD_cmd(LCD_3500KEND);
99
100 r2d_nop_delay(30);
101
102 LCD_cmd(LCD_SLPOUT);
103
104 r2d_nop_delay(20);
105
106 LCD_cmd(LCD_VOLCTL);
107 LCD_data(INIT_VOLCTL_Ton);// 152);
108
109 r2d_nop_delay(20);
110
111 LCD_cmd(LCD_VOLCTL);
112 LCD_data(INIT_VOLCTL);
113
114 r2d_nop_delay(20);
115 LCD_cmd(LCD_DISON);
116
117 LCD_cmd(LCD_RAMWR);
118
119 for (i=0; i<176*220; i++)
120 {
121 //LCD_data(pic_data[i]);
122 // Try filling with white color
123 LCD_data(0x1F);
124 }
125
126
127
128 LCD_deactivate;
129
130 #endif
131 }
132
133 static void r2d_refresh_task_kill(void)
134 {
135 }
136
137 static void r2d_dithering_init(void)
138 {
139 R2D_MALLOC(r2d_mb_id,UINT32,sizeof(UINT32)*4,r2d_g_dithering_matrix);
140 if (r2d_g_dithering_matrix!=NULL)
141 {
142 r2d_g_dithering_matrix[0]=0;
143 r2d_g_dithering_matrix[1]=2;
144 r2d_g_dithering_matrix[2]=3;
145 r2d_g_dithering_matrix[3]=1;
146 }
147 }