blob: b64ac326c9382aa8091129cb7b5d9a8271457630 [file] [log] [blame]
Padmanabhan Komanduru9d49f892015-04-10 12:58:46 -07001/* Copyright (c) 2015, 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 <string.h>
32#include <err.h>
33#include <smem.h>
34#include <msm_panel.h>
35#include <board.h>
feifanz525046b2015-06-01 20:31:06 +080036#include <qtimer.h>
Padmanabhan Komanduru9d49f892015-04-10 12:58:46 -070037#include <mipi_dsi.h>
38#include <target/display.h>
39
40#include "include/panel.h"
41#include "panel_display.h"
42
43/*---------------------------------------------------------------------------*/
44/* GCDB Panel Database */
45/*---------------------------------------------------------------------------*/
46#include "include/panel_truly_1080p_video.h"
Jayant Shekhar9ea8dcd2015-04-20 15:18:37 +053047#include "include/panel_truly_1080p_cmd.h"
feifanz174c82c2015-04-15 18:57:07 +080048#include "include/panel_otm1906c_1080p_cmd.h"
Vishnuvardhan Prodduturi16eb20f2015-06-05 18:03:54 +053049#include "include/panel_sharp_1080p_cmd.h"
Padmanabhan Komanduru49a86cf2015-06-08 18:24:30 +053050#include "include/panel_nt35597_wqxga_dualdsi_video.h"
Vishnuvardhan Prodduturic1a46c52015-06-29 16:35:23 +053051#include "include/panel_nt35597_wqxga_dualdsi_cmd.h"
Padmanabhan Komanduru9d49f892015-04-10 12:58:46 -070052
53/*---------------------------------------------------------------------------*/
54/* static panel selection variable */
55/*---------------------------------------------------------------------------*/
56enum {
57 TRULY_1080P_VIDEO_PANEL,
Jayant Shekhar9ea8dcd2015-04-20 15:18:37 +053058 TRULY_1080P_CMD_PANEL,
feifanz174c82c2015-04-15 18:57:07 +080059 OTM1906C_1080P_CMD_PANEL,
Vishnuvardhan Prodduturi16eb20f2015-06-05 18:03:54 +053060 SHARP_1080P_CMD_PANEL,
Padmanabhan Komanduru49a86cf2015-06-08 18:24:30 +053061 NT35597_WQXGA_DUALDSI_VIDEO_PANEL,
Vishnuvardhan Prodduturic1a46c52015-06-29 16:35:23 +053062 NT35597_WQXGA_DUALDSI_CMD_PANEL,
Padmanabhan Komanduru9d49f892015-04-10 12:58:46 -070063 UNKNOWN_PANEL
64};
65
66uint32_t panel_regulator_settings[] = {
67 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00
68};
69
70/*
71 * The list of panels that are supported on this target.
72 * Any panel in this list can be selected using fastboot oem command.
73 */
74static struct panel_list supp_panels[] = {
75 {"truly_1080p_video", TRULY_1080P_VIDEO_PANEL},
Jayant Shekhar9ea8dcd2015-04-20 15:18:37 +053076 {"truly_1080p_cmd", TRULY_1080P_CMD_PANEL},
Vishnuvardhan Prodduturi16eb20f2015-06-05 18:03:54 +053077 {"sharp_1080p_cmd", SHARP_1080P_CMD_PANEL},
Padmanabhan Komanduru49a86cf2015-06-08 18:24:30 +053078 {"nt35597_wqxga_dualdsi_video", NT35597_WQXGA_DUALDSI_VIDEO_PANEL},
Vishnuvardhan Prodduturic1a46c52015-06-29 16:35:23 +053079 {"nt35597_wqxga_dualdsi_cmd", NT35597_WQXGA_DUALDSI_CMD_PANEL},
Padmanabhan Komanduru9d49f892015-04-10 12:58:46 -070080};
81
82static uint32_t panel_id;
83
Sandeep Panda75fddaa2015-07-06 11:38:25 +053084#define TRULY_1080P_PANEL_ON_DELAY 40
Sandeep Pandac797d542015-06-12 14:37:55 +053085
Padmanabhan Komanduru9d49f892015-04-10 12:58:46 -070086int oem_panel_rotation()
87{
88 return NO_ERROR;
89}
90
91int oem_panel_on()
92{
93 /*
94 *OEM can keep their panel specific on instructions in this
95 *function
feifanz525046b2015-06-01 20:31:06 +080096 */
97 if (panel_id == OTM1906C_1080P_CMD_PANEL) {
98 /* needs extra delay to avoid unexpected artifacts */
99 mdelay(OTM1906C_1080P_CMD_PANEL_ON_DELAY);
Sandeep Panda75fddaa2015-07-06 11:38:25 +0530100 } else if (panel_id == TRULY_1080P_CMD_PANEL ||
101 panel_id == TRULY_1080P_VIDEO_PANEL) {
102 mdelay(TRULY_1080P_PANEL_ON_DELAY);
feifanz525046b2015-06-01 20:31:06 +0800103 }
Sandeep Pandac797d542015-06-12 14:37:55 +0530104
Padmanabhan Komanduru9d49f892015-04-10 12:58:46 -0700105 return NO_ERROR;
106}
107
108int oem_panel_off()
109{
110 /* OEM can keep their panel specific off instructions
111 * in this function
112 */
113 return NO_ERROR;
114}
115
116static int init_panel_data(struct panel_struct *panelstruct,
117 struct msm_panel_info *pinfo,
118 struct mdss_dsi_phy_ctrl *phy_db)
119{
120 int pan_type = PANEL_TYPE_DSI;
121
122 switch (panel_id) {
123 case TRULY_1080P_VIDEO_PANEL:
124 panelstruct->paneldata = &truly_1080p_video_panel_data;
125 panelstruct->paneldata->panel_with_enable_gpio = 1;
126 panelstruct->panelres = &truly_1080p_video_panel_res;
127 panelstruct->color = &truly_1080p_video_color;
128 panelstruct->videopanel = &truly_1080p_video_video_panel;
129 panelstruct->commandpanel = &truly_1080p_video_command_panel;
130 panelstruct->state = &truly_1080p_video_state;
131 panelstruct->laneconfig = &truly_1080p_video_lane_config;
132 panelstruct->paneltiminginfo
133 = &truly_1080p_video_timing_info;
134 panelstruct->panelresetseq
135 = &truly_1080p_video_panel_reset_seq;
136 panelstruct->backlightinfo = &truly_1080p_video_backlight;
137 pinfo->mipi.panel_on_cmds
138 = truly_1080p_video_on_command;
139 pinfo->mipi.num_of_panel_on_cmds
140 = TRULY_1080P_VIDEO_ON_COMMAND;
141 pinfo->mipi.panel_off_cmds
142 = truly_1080p_video_off_command;
143 pinfo->mipi.num_of_panel_off_cmds
144 = TRULY_1080P_VIDEO_OFF_COMMAND;
145 memcpy(phy_db->timing,
146 truly_1080p_video_timings, TIMING_SIZE);
147 pinfo->mipi.signature = TRULY_1080P_VIDEO_SIGNATURE;
148 break;
Jayant Shekhar9ea8dcd2015-04-20 15:18:37 +0530149 case TRULY_1080P_CMD_PANEL:
150 panelstruct->paneldata = &truly_1080p_cmd_panel_data;
151 panelstruct->paneldata->panel_with_enable_gpio = 1;
152 panelstruct->panelres = &truly_1080p_cmd_panel_res;
153 panelstruct->color = &truly_1080p_cmd_color;
154 panelstruct->videopanel = &truly_1080p_cmd_video_panel;
155 panelstruct->commandpanel = &truly_1080p_cmd_command_panel;
156 panelstruct->state = &truly_1080p_cmd_state;
157 panelstruct->laneconfig = &truly_1080p_cmd_lane_config;
158 panelstruct->paneltiminginfo
159 = &truly_1080p_cmd_timing_info;
160 panelstruct->panelresetseq
161 = &truly_1080p_cmd_panel_reset_seq;
162 panelstruct->backlightinfo = &truly_1080p_cmd_backlight;
163 pinfo->mipi.panel_on_cmds
164 = truly_1080p_cmd_on_command;
165 pinfo->mipi.num_of_panel_on_cmds
166 = TRULY_1080P_CMD_ON_COMMAND;
167 pinfo->mipi.panel_off_cmds
168 = truly_1080p_cmd_off_command;
169 pinfo->mipi.num_of_panel_off_cmds
170 = TRULY_1080P_CMD_OFF_COMMAND;
171 memcpy(phy_db->timing,
172 truly_1080p_cmd_timings, TIMING_SIZE);
173 pinfo->mipi.signature = TRULY_1080P_CMD_SIGNATURE;
174 break;
feifanz174c82c2015-04-15 18:57:07 +0800175 case OTM1906C_1080P_CMD_PANEL:
176 panelstruct->paneldata = &otm1906c_1080p_cmd_panel_data;
177 panelstruct->paneldata->panel_with_enable_gpio = 1;
178 panelstruct->panelres = &otm1906c_1080p_cmd_panel_res;
179 panelstruct->color = &otm1906c_1080p_cmd_color;
180 panelstruct->videopanel = &otm1906c_1080p_cmd_video_panel;
181 panelstruct->commandpanel = &otm1906c_1080p_cmd_command_panel;
182 panelstruct->state = &otm1906c_1080p_cmd_state;
183 panelstruct->laneconfig = &otm1906c_1080p_cmd_lane_config;
184 panelstruct->paneltiminginfo
185 = &otm1906c_1080p_cmd_timing_info;
186 panelstruct->panelresetseq
187 = &otm1906c_1080p_cmd_panel_reset_seq;
188 panelstruct->backlightinfo = &otm1906c_1080p_cmd_backlight;
189 pinfo->mipi.panel_on_cmds
190 = otm1906c_1080p_cmd_on_command;
191 pinfo->mipi.num_of_panel_on_cmds
192 = OTM1906C_1080P_CMD_ON_COMMAND;
193 pinfo->mipi.panel_off_cmds
194 = otm1906c_1080p_cmd_off_command;
195 pinfo->mipi.num_of_panel_off_cmds
196 = OTM1906C_1080P_CMD_OFF_COMMAND;
197 memcpy(phy_db->timing,
198 otm1906c_1080p_cmd_timings, TIMING_SIZE);
199 pinfo->mipi.signature = OTM1906C_1080P_CMD_SIGNATURE;
200 break;
Vishnuvardhan Prodduturi16eb20f2015-06-05 18:03:54 +0530201 case SHARP_1080P_CMD_PANEL:
202 panelstruct->paneldata = &sharp_1080p_cmd_panel_data;
203 panelstruct->panelres = &sharp_1080p_cmd_panel_res;
204 panelstruct->paneldata->panel_with_enable_gpio = 1;
205 panelstruct->color = &sharp_1080p_cmd_color;
206 panelstruct->videopanel = &sharp_1080p_cmd_video_panel;
207 panelstruct->commandpanel = &sharp_1080p_cmd_command_panel;
208 panelstruct->state = &sharp_1080p_cmd_state;
209 panelstruct->laneconfig = &sharp_1080p_cmd_lane_config;
210 panelstruct->paneltiminginfo
211 = &sharp_1080p_cmd_timing_info;
212 panelstruct->panelresetseq
213 = &sharp_1080p_cmd_panel_reset_seq;
214 panelstruct->backlightinfo = &sharp_1080p_cmd_backlight;
215 pinfo->mipi.panel_on_cmds
216 = sharp_1080p_cmd_on_command;
217 pinfo->mipi.num_of_panel_on_cmds
218 = SHARP_1080P_CMD_ON_COMMAND;
219 pinfo->mipi.panel_off_cmds
220 = sharp_1080p_cmd_off_command;
221 pinfo->mipi.num_of_panel_off_cmds
222 = SHARP_1080P_CMD_OFF_COMMAND;
223 memcpy(phy_db->timing,
224 sharp_1080p_cmd_timings, TIMING_SIZE);
225 break;
Padmanabhan Komanduru49a86cf2015-06-08 18:24:30 +0530226 case NT35597_WQXGA_DUALDSI_VIDEO_PANEL:
227 panelstruct->paneldata = &nt35597_wqxga_dualdsi_video_panel_data;
228 panelstruct->paneldata->panel_operating_mode = DST_SPLIT_FLAG |
229 SPLIT_DISPLAY_FLAG | DUAL_DSI_FLAG;
230 panelstruct->paneldata->panel_with_enable_gpio = 0;
231
232 panelstruct->panelres = &nt35597_wqxga_dualdsi_video_panel_res;
233 panelstruct->color = &nt35597_wqxga_dualdsi_video_color;
234 panelstruct->videopanel = &nt35597_wqxga_dualdsi_video_video_panel;
235 panelstruct->commandpanel = &nt35597_wqxga_dualdsi_video_command_panel;
236 panelstruct->state = &nt35597_wqxga_dualdsi_video_state;
237 panelstruct->laneconfig = &nt35597_wqxga_dualdsi_video_lane_config;
238 panelstruct->paneltiminginfo
239 = &nt35597_wqxga_dualdsi_video_timing_info;
240 panelstruct->panelresetseq
241 = &nt35597_wqxga_dualdsi_video_reset_seq;
242 panelstruct->backlightinfo = &nt35597_wqxga_dualdsi_video_backlight;
243 pinfo->labibb = &nt35597_wqxga_dualdsi_video_labibb;
244
245 pinfo->mipi.panel_on_cmds
246 = nt35597_wqxga_dualdsi_video_on_command;
247 pinfo->mipi.num_of_panel_on_cmds
248 = NT35597_WQXGA_DUALDSI_VIDEO_ON_COMMAND;
249 pinfo->mipi.panel_off_cmds
250 = nt35597_wqxga_dualdsi_video_off_command;
251 pinfo->mipi.num_of_panel_off_cmds
252 = NT35597_WQXGA_DUALDSI_VIDEO_OFF_COMMAND;
253 memcpy(phy_db->timing, nt35597_wqxga_dualdsi_video_timings,
254 TIMING_SIZE);
255 pinfo->mipi.tx_eot_append = true;
256 break;
Vishnuvardhan Prodduturic1a46c52015-06-29 16:35:23 +0530257 case NT35597_WQXGA_DUALDSI_CMD_PANEL:
258 panelstruct->paneldata = &nt35597_wqxga_dualdsi_cmd_panel_data;
259 panelstruct->paneldata->panel_operating_mode = DST_SPLIT_FLAG |
260 SPLIT_DISPLAY_FLAG | DUAL_DSI_FLAG;
261 panelstruct->paneldata->panel_with_enable_gpio = 0;
262
263 panelstruct->panelres = &nt35597_wqxga_dualdsi_cmd_panel_res;
264 panelstruct->color = &nt35597_wqxga_dualdsi_cmd_color;
265 panelstruct->videopanel = &nt35597_wqxga_dualdsi_cmd_video_panel;
266 panelstruct->commandpanel = &nt35597_wqxga_dualdsi_cmd_command_panel;
267 panelstruct->state = &nt35597_wqxga_dualdsi_cmd_state;
268 panelstruct->laneconfig = &nt35597_wqxga_dualdsi_cmd_lane_config;
269 panelstruct->paneltiminginfo
270 = &nt35597_wqxga_dualdsi_cmd_timing_info;
271 panelstruct->panelresetseq
272 = &nt35597_wqxga_dualdsi_cmd_reset_seq;
273 panelstruct->backlightinfo = &nt35597_wqxga_dualdsi_cmd_backlight;
274
275 pinfo->labibb = &nt35597_wqxga_dualdsi_cmd_labibb;
276
277 pinfo->mipi.panel_on_cmds
278 = nt35597_wqxga_dualdsi_cmd_on_command;
279 pinfo->mipi.num_of_panel_on_cmds
280 = NT35597_WQXGA_DUALDSI_CMD_ON_COMMAND;
281 pinfo->mipi.panel_off_cmds
282 = nt35597_wqxga_dualdsi_cmd_off_command;
283 pinfo->mipi.num_of_panel_off_cmds
284 = NT35597_WQXGA_DUALDSI_CMD_OFF_COMMAND;
285 memcpy(phy_db->timing, nt35597_wqxga_dualdsi_cmd_timings,
286 TIMING_SIZE);
287 pinfo->mipi.tx_eot_append = true;
288 break;
Padmanabhan Komanduru9d49f892015-04-10 12:58:46 -0700289 case UNKNOWN_PANEL:
290 default:
291 memset(panelstruct, 0, sizeof(struct panel_struct));
292 memset(pinfo->mipi.panel_on_cmds, 0,
293 sizeof(struct mipi_dsi_cmd));
294 pinfo->mipi.num_of_panel_on_cmds = 0;
295 memset(pinfo->mipi.panel_off_cmds, 0,
296 sizeof(struct mipi_dsi_cmd));
297 pinfo->mipi.num_of_panel_off_cmds = 0;
298 memset(phy_db->timing, 0, TIMING_SIZE);
299 pan_type = PANEL_TYPE_UNKNOWN;
300 break;
301 }
302 return pan_type;
303}
304
305int oem_panel_select(const char *panel_name, struct panel_struct *panelstruct,
306 struct msm_panel_info *pinfo,
307 struct mdss_dsi_phy_ctrl *phy_db)
308{
309 uint32_t hw_id = board_hardware_id();
310 int32_t panel_override_id;
311
312 if (panel_name) {
313 panel_override_id = panel_name_to_id(supp_panels,
314 ARRAY_SIZE(supp_panels), panel_name);
315
316 if (panel_override_id < 0) {
317 dprintf(CRITICAL, "Not able to search the panel:%s\n",
Padmanabhan Komandurubccbcdc2015-06-30 16:19:24 +0530318 panel_name);
Padmanabhan Komanduru9d49f892015-04-10 12:58:46 -0700319 } else if (panel_override_id < UNKNOWN_PANEL) {
320 /* panel override using fastboot oem command */
321 panel_id = panel_override_id;
322
323 dprintf(INFO, "OEM panel override:%s\n",
Padmanabhan Komandurubccbcdc2015-06-30 16:19:24 +0530324 panel_name);
Padmanabhan Komanduru9d49f892015-04-10 12:58:46 -0700325 goto panel_init;
326 }
327 }
328
329 switch (hw_id) {
330 case HW_PLATFORM_MTP:
Padmanabhan Komanduru49a86cf2015-06-08 18:24:30 +0530331 if (platform_is_msm8956())
332 panel_id = NT35597_WQXGA_DUALDSI_VIDEO_PANEL;
333 else
334 panel_id = TRULY_1080P_VIDEO_PANEL;
Padmanabhan Komanduru9d49f892015-04-10 12:58:46 -0700335 break;
336 case HW_PLATFORM_SURF:
Padmanabhan Komanduru49a86cf2015-06-08 18:24:30 +0530337 if (platform_is_msm8956())
338 panel_id = NT35597_WQXGA_DUALDSI_VIDEO_PANEL;
339 else
340 panel_id = TRULY_1080P_VIDEO_PANEL;
Padmanabhan Komanduru9d49f892015-04-10 12:58:46 -0700341 break;
feifanz174c82c2015-04-15 18:57:07 +0800342 case HW_PLATFORM_QRD:
343 panel_id = OTM1906C_1080P_CMD_PANEL;
344 break;
Padmanabhan Komanduru9d49f892015-04-10 12:58:46 -0700345 default:
346 dprintf(CRITICAL, "Display not enabled for %d HW type\n",
347 hw_id);
348 return PANEL_TYPE_UNKNOWN;
349 }
350
351panel_init:
352 /*
353 * Update all data structures after 'panel_init' label. Only panel
354 * selection is supposed to happen before that.
355 */
Padmanabhan Komanduru0e19a362015-06-08 13:29:32 +0530356 if (platform_is_msm8956())
357 memcpy(panel_regulator_settings,
358 dcdc_regulator_settings_hpm, REGULATOR_SIZE);
359 else
360 memcpy(panel_regulator_settings,
361 dcdc_regulator_settings_lpm, REGULATOR_SIZE);
Padmanabhan Komanduru9d49f892015-04-10 12:58:46 -0700362 pinfo->pipe_type = MDSS_MDP_PIPE_TYPE_RGB;
363 return init_panel_data(panelstruct, pinfo, phy_db);
364}