blob: 7278487dfc33083d93b188152da3b94bf92082e8 [file] [log] [blame]
wangxl1ddbd092015-02-03 20:31:24 +08001/* Copyright (c) 2013-2014, The Linux Foundation. All rights reserved.
2 *
3 * Redistribution and use in source and binary forms, with or without
4 * modification, are permitted provided that the following conditions
5 * are 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 copyright
9 * notice, this list of conditions and the following disclaimer in
10 * the documentation and/or other materials provided with the
11 * distribution.
12 * * Neither the name of The Linux Foundation 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 BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
17 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
18 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
19 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
20 * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
21 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
22 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
23 * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
24 * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
25 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
26 * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
27 * SUCH DAMAGE.
28 */
29
30#include <debug.h>
31#include <err.h>
32#include <smem.h>
33#include <msm_panel.h>
34#include <board.h>
35#include <mipi_dsi.h>
36
37#include "include/panel.h"
38#include "panel_display.h"
39
40/*---------------------------------------------------------------------------*/
41/* GCDB Panel Database */
42/*---------------------------------------------------------------------------*/
43#include "include/panel_toshiba_720p_video.h"
44#include "include/panel_sharp_qhd_video.h"
45#include "include/panel_jdi_1080p_video.h"
46#include "include/panel_generic_720p_cmd.h"
47#include "include/panel_jdi_qhd_dualdsi_video.h"
48#include "include/panel_jdi_qhd_dualdsi_cmd.h"
liuyan8c8b2c02015-01-26 15:27:19 +080049#include "include/panel_otm1902b_1080p_cmd.h"
wangxl1ddbd092015-02-03 20:31:24 +080050
51#define DISPLAY_MAX_PANEL_DETECTION 3
52
53/*---------------------------------------------------------------------------*/
54/* static panel selection variable */
55/*---------------------------------------------------------------------------*/
56enum {
57JDI_1080P_VIDEO_PANEL,
58TOSHIBA_720P_VIDEO_PANEL,
59SHARP_QHD_VIDEO_PANEL,
60GENERIC_720P_CMD_PANEL,
61JDI_QHD_DUALDSI_VIDEO_PANEL,
62JDI_QHD_DUALDSI_CMD_PANEL,
liuyan8c8b2c02015-01-26 15:27:19 +080063OTM1902B_1080P_CMD_PANEL,
wangxl1ddbd092015-02-03 20:31:24 +080064UNKNOWN_PANEL
65};
66
67/*
68 * The list of panels that are supported on this target.
69 * Any panel in this list can be selected using fastboot oem command.
70 */
71static struct panel_list supp_panels[] = {
72 {"jdi_1080p_video", JDI_1080P_VIDEO_PANEL},
73 {"toshiba_720p_video", TOSHIBA_720P_VIDEO_PANEL},
74 {"sharp_qhd_video", SHARP_QHD_VIDEO_PANEL},
75 {"generic_720p_cmd", GENERIC_720P_CMD_PANEL},
76 {"jdi_qhd_dualdsi_video", JDI_QHD_DUALDSI_VIDEO_PANEL},
77 {"jdi_qhd_dualdsi_cmd", JDI_QHD_DUALDSI_CMD_PANEL},
liuyan04e7c7a2015-02-09 19:50:08 +080078 {"otm1902b_1080p_cmd",OTM1902B_1080P_CMD_PANEL},
wangxl1ddbd092015-02-03 20:31:24 +080079};
80
81static uint32_t panel_id;
82
83int oem_panel_rotation()
84{
85 /* OEM can keep there panel spefic on instructions in this
86 function */
87 return NO_ERROR;
88}
89
90
91int oem_panel_on()
92{
93 /* OEM can keep there panel spefic on instructions in this
94 function */
95 return NO_ERROR;
96}
97
98int oem_panel_off()
99{
100 /* OEM can keep there panel spefic off instructions in this
101 function */
102 return NO_ERROR;
103}
104
105static void init_panel_data(struct panel_struct *panelstruct,
106 struct msm_panel_info *pinfo,
107 struct mdss_dsi_phy_ctrl *phy_db)
108{
109 switch (panel_id) {
110 case TOSHIBA_720P_VIDEO_PANEL:
111 panelstruct->paneldata = &toshiba_720p_video_panel_data;
112 panelstruct->panelres = &toshiba_720p_video_panel_res;
113 panelstruct->color = &toshiba_720p_video_color;
114 panelstruct->videopanel = &toshiba_720p_video_video_panel;
115 panelstruct->commandpanel = &toshiba_720p_video_command_panel;
116 panelstruct->state = &toshiba_720p_video_state;
117 panelstruct->laneconfig = &toshiba_720p_video_lane_config;
118 panelstruct->paneltiminginfo
119 = &toshiba_720p_video_timing_info;
120 panelstruct->panelresetseq
121 = &toshiba_720p_video_panel_reset_seq;
122 panelstruct->backlightinfo = &toshiba_720p_video_backlight;
123 pinfo->mipi.panel_cmds
124 = toshiba_720p_video_on_command;
125 pinfo->mipi.num_of_panel_cmds
126 = TOSHIBA_720P_VIDEO_ON_COMMAND;
127 memcpy(phy_db->timing,
128 toshiba_720p_video_timings, TIMING_SIZE);
129 pinfo->mipi.signature = TOSHIBA_720P_VIDEO_SIGNATURE;
130 break;
131 case SHARP_QHD_VIDEO_PANEL:
132 panelstruct->paneldata = &sharp_qhd_video_panel_data;
133 panelstruct->panelres = &sharp_qhd_video_panel_res;
134 panelstruct->color = &sharp_qhd_video_color;
135 panelstruct->videopanel = &sharp_qhd_video_video_panel;
136 panelstruct->commandpanel = &sharp_qhd_video_command_panel;
137 panelstruct->state = &sharp_qhd_video_state;
138 panelstruct->laneconfig = &sharp_qhd_video_lane_config;
139 panelstruct->paneltiminginfo
140 = &sharp_qhd_video_timing_info;
141 panelstruct->panelresetseq
142 = &sharp_qhd_video_panel_reset_seq;
143 panelstruct->backlightinfo = &sharp_qhd_video_backlight;
144 pinfo->mipi.panel_cmds
145 = sharp_qhd_video_on_command;
146 pinfo->mipi.num_of_panel_cmds
147 = SHARP_QHD_VIDEO_ON_COMMAND;
148 memcpy(phy_db->timing,
149 sharp_qhd_video_timings, TIMING_SIZE);
150 break;
151 case JDI_1080P_VIDEO_PANEL:
152 panelstruct->paneldata = &jdi_1080p_video_panel_data;
153 panelstruct->panelres = &jdi_1080p_video_panel_res;
154 panelstruct->color = &jdi_1080p_video_color;
155 panelstruct->videopanel = &jdi_1080p_video_video_panel;
156 panelstruct->commandpanel = &jdi_1080p_video_command_panel;
157 panelstruct->state = &jdi_1080p_video_state;
158 panelstruct->laneconfig = &jdi_1080p_video_lane_config;
159 panelstruct->paneltiminginfo
160 = &jdi_1080p_video_timing_info;
161 panelstruct->panelresetseq
162 = &jdi_1080p_video_panel_reset_seq;
163 panelstruct->backlightinfo = &jdi_1080p_video_backlight;
164 pinfo->mipi.panel_cmds
165 = jdi_1080p_video_on_command;
166 pinfo->mipi.num_of_panel_cmds
167 = JDI_1080P_VIDEO_ON_COMMAND;
168 memcpy(phy_db->timing,
169 jdi_1080p_video_timings, TIMING_SIZE);
170 pinfo->mipi.signature = JDI_1080P_VIDEO_SIGNATURE;
171 break;
172 case GENERIC_720P_CMD_PANEL:
173 panelstruct->paneldata = &generic_720p_cmd_panel_data;
174 panelstruct->panelres = &generic_720p_cmd_panel_res;
175 panelstruct->color = &generic_720p_cmd_color;
176 panelstruct->videopanel = &generic_720p_cmd_video_panel;
177 panelstruct->commandpanel = &generic_720p_cmd_command_panel;
178 panelstruct->state = &generic_720p_cmd_state;
179 panelstruct->laneconfig = &generic_720p_cmd_lane_config;
180 panelstruct->paneltiminginfo
181 = &generic_720p_cmd_timing_info;
182 panelstruct->panelresetseq
183 = &generic_720p_cmd_reset_seq;
184 panelstruct->backlightinfo = &generic_720p_cmd_backlight;
185 pinfo->mipi.panel_cmds
186 = generic_720p_cmd_on_command;
187 pinfo->mipi.num_of_panel_cmds
188 = GENERIC_720P_CMD_ON_COMMAND;
189 memcpy(phy_db->timing,
190 generic_720p_cmd_timings, TIMING_SIZE);
191 pinfo->mipi.signature = GENERIC_720P_CMD_SIGNATURE;
192 break;
193 case JDI_QHD_DUALDSI_VIDEO_PANEL:
194 panelstruct->paneldata = &jdi_qhd_dualdsi_video_panel_data;
195 panelstruct->panelres = &jdi_qhd_dualdsi_video_panel_res;
196 panelstruct->color = &jdi_qhd_dualdsi_video_color;
197 panelstruct->videopanel = &jdi_qhd_dualdsi_video_video_panel;
198 panelstruct->commandpanel = &jdi_qhd_dualdsi_video_command_panel;
199 panelstruct->state = &jdi_qhd_dualdsi_video_state;
200 panelstruct->laneconfig = &jdi_qhd_dualdsi_video_lane_config;
201 panelstruct->paneltiminginfo
202 = &jdi_qhd_dualdsi_video_timing_info;
203 panelstruct->panelresetseq
204 = &jdi_qhd_dualdsi_video_reset_seq;
205 panelstruct->backlightinfo = &jdi_qhd_dualdsi_video_backlight;
206 pinfo->mipi.panel_cmds
207 = jdi_qhd_dualdsi_video_on_command;
208 pinfo->mipi.num_of_panel_cmds
209 = JDI_QHD_DUALDSI_VIDEO_ON_COMMAND;
210 memcpy(phy_db->timing,
211 jdi_qhd_dualdsi_video_timings, TIMING_SIZE);
212 break;
213 case JDI_QHD_DUALDSI_CMD_PANEL:
214 panelstruct->paneldata = &jdi_qhd_dualdsi_cmd_panel_data;
215 panelstruct->panelres = &jdi_qhd_dualdsi_cmd_panel_res;
216 panelstruct->color = &jdi_qhd_dualdsi_cmd_color;
217 panelstruct->videopanel = &jdi_qhd_dualdsi_cmd_video_panel;
218 panelstruct->commandpanel = &jdi_qhd_dualdsi_cmd_command_panel;
219 panelstruct->state = &jdi_qhd_dualdsi_cmd_state;
220 panelstruct->laneconfig = &jdi_qhd_dualdsi_cmd_lane_config;
221 panelstruct->paneltiminginfo
222 = &jdi_qhd_dualdsi_cmd_timing_info;
223 panelstruct->panelresetseq
224 = &jdi_qhd_dualdsi_cmd_reset_seq;
225 panelstruct->backlightinfo = &jdi_qhd_dualdsi_cmd_backlight;
226 pinfo->mipi.panel_cmds
227 = jdi_qhd_dualdsi_cmd_on_command;
228 pinfo->mipi.num_of_panel_cmds
229 = JDI_QHD_DUALDSI_CMD_ON_COMMAND;
230 memcpy(phy_db->timing,
231 jdi_qhd_dualdsi_cmd_timings, TIMING_SIZE);
232 break;
liuyan8c8b2c02015-01-26 15:27:19 +0800233 case OTM1902B_1080P_CMD_PANEL:
234 panelstruct->paneldata = &otm1902b_1080p_cmd_panel_data;
235 panelstruct->panelres = &otm1902b_1080p_cmd_panel_res;
236 panelstruct->color = &otm1902b_1080p_cmd_color;
237 panelstruct->videopanel = &otm1902b_1080p_cmd_video_panel;
238 panelstruct->commandpanel = &otm1902b_1080p_cmd_command_panel;
239 panelstruct->state = &otm1902b_1080p_cmd_state;
240 panelstruct->laneconfig = &otm1902b_1080p_cmd_lane_config;
241 panelstruct->paneltiminginfo
242 = &otm1902b_1080p_cmd_timing_info;
243 panelstruct->panelresetseq
244 = &otm1902b_1080p_cmd_panel_reset_seq;
245 panelstruct->backlightinfo = &otm1902b_1080p_cmd_backlight;
246 pinfo->mipi.panel_cmds
247 = otm1902b_1080p_cmd_on_command;
248 pinfo->mipi.num_of_panel_cmds
liuyan04e7c7a2015-02-09 19:50:08 +0800249 = OTM1902B_1080P_CMD_ON_COMMAND;
liuyan8c8b2c02015-01-26 15:27:19 +0800250 memcpy(phy_db->timing,
251 otm1902b_1080p_cmd_timings, TIMING_SIZE);
252 break;
wangxl1ddbd092015-02-03 20:31:24 +0800253 case UNKNOWN_PANEL:
254 memset(panelstruct, 0, sizeof(struct panel_struct));
255 memset(pinfo->mipi.panel_cmds, 0, sizeof(struct mipi_dsi_cmd));
256 pinfo->mipi.num_of_panel_cmds = 0;
257 memset(phy_db->timing, 0, TIMING_SIZE);
258 pinfo->mipi.signature = 0;
259 break;
260 }
261}
262
263uint32_t oem_panel_max_auto_detect_panels()
264{
265 return target_panel_auto_detect_enabled() ?
266 DISPLAY_MAX_PANEL_DETECTION : 0;
267}
268
269static uint32_t auto_pan_loop = 0;
270
271bool oem_panel_select(const char *panel_name, struct panel_struct *panelstruct,
272 struct msm_panel_info *pinfo,
273 struct mdss_dsi_phy_ctrl *phy_db)
274{
275 uint32_t hw_id = board_hardware_id();
276 uint32_t target_id = board_target_id();
277 bool ret = true;
278 int32_t panel_override_id;
279
280 if (panel_name) {
281 panel_override_id = panel_name_to_id(supp_panels,
282 ARRAY_SIZE(supp_panels), panel_name);
283
284 if (panel_override_id < 0) {
285 dprintf(CRITICAL, "Not able to search the panel:%s\n",
286 panel_name + strspn(panel_name, " "));
287 } else if (panel_override_id < UNKNOWN_PANEL) {
288 /* panel override using fastboot oem command */
289 panel_id = panel_override_id;
290
291 dprintf(INFO, "OEM panel override:%s\n",
292 panel_name + strspn(panel_name, " "));
293 goto panel_init;
294 }
295 }
296
297 switch (hw_id) {
298 case HW_PLATFORM_MTP:
299 case HW_PLATFORM_FLUID:
300 case HW_PLATFORM_SURF:
301 switch (auto_pan_loop) {
302 case 0:
liuyan04e7c7a2015-02-09 19:50:08 +0800303 panel_id = OTM1902B_1080P_CMD_PANEL;
wangxl1ddbd092015-02-03 20:31:24 +0800304 break;
305 case 1:
306 panel_id = TOSHIBA_720P_VIDEO_PANEL;
307 break;
308 case 2:
309 panel_id = GENERIC_720P_CMD_PANEL;
310 break;
311 default:
312 panel_id = UNKNOWN_PANEL;
313 ret = false;
314 break;
315 }
316 auto_pan_loop++;
317 break;
318 case HW_PLATFORM_DRAGON:
319 panel_id = SHARP_QHD_VIDEO_PANEL;
320 break;
321 default:
322 dprintf(CRITICAL, "Display not enabled for %d HW type\n"
323 , hw_id);
324 return false;
325 }
liuyan04e7c7a2015-02-09 19:50:08 +0800326
wangxl1ddbd092015-02-03 20:31:24 +0800327panel_init:
328 init_panel_data(panelstruct, pinfo, phy_db);
329
330 return ret;
331}