1 /* drivers/video/sprdfb/lcd_nt51017_mipi.c
\r
3 * Support for nt51017 mipi LCD device
\r
5 * Copyright (C) 2010 Spreadtrum
\r
8 #include <asm/arch/sprd_lcd.h>
\r
9 #include "../sprdfb.h"
\r
10 #define printk printf
\r
14 #define LCD_PRINT printk
\r
16 #define LCD_PRINT(...)
\r
19 #define MAX_DATA 150
\r
21 typedef struct LCM_Init_Code_tag {
\r
23 unsigned char data[MAX_DATA];
\r
26 typedef struct LCM_force_cmd_code_tag{
\r
27 unsigned int datatype;
\r
28 LCM_Init_Code real_cmd_code;
\r
29 }LCM_Force_Cmd_Code;
\r
31 #define LCM_TAG_SHIFT 24
\r
32 #define LCM_TAG_MASK ((1 << 24) -1)
\r
33 #define LCM_SEND(len) ((1 << LCM_TAG_SHIFT)| len)
\r
34 #define LCM_SLEEP(ms) ((2 << LCM_TAG_SHIFT)| ms)
\r
35 //#define ARRAY_SIZE(array) ( sizeof(array) / sizeof(array[0]))
\r
37 #define LCM_TAG_SEND (1<< 0)
\r
38 #define LCM_TAG_SLEEP (1 << 1)
\r
43 static LCM_Init_Code init_data[] = {
\r
44 {LCM_SEND(2), {0x83, 0x96} },
\r
45 {LCM_SEND(2), {0x84, 0x69} },
\r
46 {LCM_SEND(2), {0x92, 0x19} },
\r
47 {LCM_SEND(2), {0x83, 0x00} },
\r
48 {LCM_SEND(2), {0x84, 0x00} },
\r
49 {LCM_SEND(2), {0x96, 0x00} },
\r
54 static LCM_Init_Code sleep_in[] = {
\r
56 {LCM_SEND(1), {0x11}},
\r
60 static LCM_Init_Code sleep_out[] = {
\r
61 {LCM_SEND(1), {0x10}},
\r
67 static int32_t nt51017_mipi_init(struct panel_spec *self)
\r
70 sprd_gpio_request(NULL, BACKLIGHT_GPIO);
\r
71 sprd_gpio_direction_output(NULL, BACKLIGHT_GPIO, 0);
\r
72 sprd_gpio_request(NULL, 152);
\r
73 sprd_gpio_direction_output(NULL, 152, 0);
\r
74 sprd_gpio_request(NULL, 232);
\r
75 sprd_gpio_direction_output(NULL, 232, 0);
\r
76 sprd_gpio_request(NULL, 233);
\r
77 sprd_gpio_direction_output(NULL, 233, 0);
\r
79 sprd_gpio_set(NULL, BACKLIGHT_GPIO, 1);
\r
80 sprd_gpio_set(NULL, 152, 1);
\r
82 sprd_gpio_set(NULL, 232, 1);
\r
83 sprd_gpio_set(NULL, 233, 1);
\r
86 LCM_Init_Code *init = init_data;
\r
89 mipi_set_cmd_mode_t mipi_set_cmd_mode = self->info.mipi->ops->mipi_set_cmd_mode;
\r
90 mipi_dcs_write_t mipi_dcs_write = self->info.mipi->ops->mipi_dcs_write;
\r
91 mipi_eotp_set_t mipi_eotp_set = self->info.mipi->ops->mipi_eotp_set;
\r
93 LCD_PRINT("lcd_nt51017_init\n");
\r
95 mipi_set_cmd_mode();
\r
98 for(i = 0; i < ARRAY_SIZE(init_data); i++){
\r
99 tag = (init->tag >>24);
\r
100 if(tag & LCM_TAG_SEND){
\r
101 mipi_dcs_write(init->data, (init->tag & LCM_TAG_MASK));
\r
103 }else if(tag & LCM_TAG_SLEEP){
\r
104 mdelay(init->tag & LCM_TAG_MASK);//udelay((init->tag & LCM_TAG_MASK) * 1000);
\r
108 mipi_eotp_set(0,0);
\r
113 static uint32_t nt51017_readid(struct panel_spec *self)
\r
117 uint8_t read_data[4] = {0};
\r
118 int32_t read_rtn = 0;
\r
119 uint8_t param[2] = {0};
\r
120 mipi_set_cmd_mode_t mipi_set_cmd_mode = self->info.mipi->ops->mipi_set_cmd_mode;
\r
121 mipi_force_write_t mipi_force_write = self->info.mipi->ops->mipi_force_write;
\r
122 mipi_force_read_t mipi_force_read = self->info.mipi->ops->mipi_force_read;
\r
123 mipi_eotp_set_t mipi_eotp_set = self->info.mipi->ops->mipi_eotp_set;
\r
125 LCD_PRINT("lcd_nt51017_mipi read id!\n");
\r
127 mipi_set_cmd_mode();
\r
128 mipi_eotp_set(0,0);
\r
130 for(j = 0; j < 4; j++){
\r
133 mipi_force_write(0x37, param, 2);
\r
134 read_rtn = mipi_force_read(0xda,1,&read_data[0]);
\r
135 LCD_PRINT("lcd_nt51017_mipi read id 0xda value is 0x%x!\n",read_data[0]);
\r
137 read_rtn = mipi_force_read(0xdb,1,&read_data[1]);
\r
138 LCD_PRINT("lcd_nt51017_mipi read id 0xdb value is 0x%x!\n",read_data[1]);
\r
140 read_rtn = mipi_force_read(0xdc,1,&read_data[2]);
\r
141 LCD_PRINT("lcd_nt51017_mipi read id 0xdc value is 0x%x!\n",read_data[2]);
\r
143 if((0x55 == read_data[0])&&(0xbf == read_data[1] || 0xc0 == read_data[1] || 0xbe == read_data[1])&&(0x90 == read_data[2])){
\r
144 LCD_PRINT("lcd_nt51017_mipi read id success!\n");
\r
149 mipi_eotp_set(0,0);
\r
151 LCD_PRINT("lcd_s6d77a1_mipi read id failed!\n");
\r
157 static struct panel_operations lcd_nt51017_mipi_operations = {
\r
158 .panel_init = nt51017_mipi_init,
\r
159 .panel_readid = nt51017_readid,
\r
162 static struct timing_rgb lcd_nt51017_mipi_timing = {
\r
164 .hfp = 80, /* unit: pixel */
\r
167 .vfp = 18, /*unit: line*/
\r
174 static struct info_mipi lcd_nt51017_mipi_info = {
\r
175 .work_mode = SPRDFB_MIPI_MODE_VIDEO,
\r
176 .video_bus_width = 24, /*18,16*/
\r
178 .phy_feq =481*1000,
\r
179 .h_sync_pol = SPRDFB_POLARITY_POS,
\r
180 .v_sync_pol = SPRDFB_POLARITY_POS,
\r
181 .de_pol = SPRDFB_POLARITY_POS,
\r
182 .te_pol = SPRDFB_POLARITY_POS,
\r
183 .color_mode_pol = SPRDFB_POLARITY_NEG,
\r
184 .shut_down_pol = SPRDFB_POLARITY_NEG,
\r
185 .timing = &lcd_nt51017_mipi_timing,
\r
189 struct panel_spec lcd_nt51017_mipi_spec = {
\r
193 .type = LCD_MODE_DSI,
\r
194 .direction = LCD_DIRECT_NORMAL,
\r
195 //.suspend_mode = SEND_SLEEP_CMD,
\r
197 .mipi = &lcd_nt51017_mipi_info
\r
199 .ops = &lcd_nt51017_mipi_operations,
\r