Merge "dev: gcdb: Support post power API to handle LP11 panel config"
diff --git a/AndroidBoot.mk b/AndroidBoot.mk
index 6836163..32994a3 100644
--- a/AndroidBoot.mk
+++ b/AndroidBoot.mk
@@ -7,7 +7,7 @@
   SIGNED_KERNEL := SIGNED_KERNEL=0
 endif
 
-ifeq ($(call is-board-platform,msm8660),true)
+ifeq ($(TARGET_BOARD_PLATFORM),msm8660)
   BOOTLOADER_PLATFORM := msm8660_surf
 else
   BOOTLOADER_PLATFORM := $(TARGET_BOARD_PLATFORM)
diff --git a/dev/gcdb/display/include/panel_generic_720p_cmd.h b/dev/gcdb/display/include/panel_generic_720p_cmd.h
new file mode 100644
index 0000000..8320407
--- /dev/null
+++ b/dev/gcdb/display/include/panel_generic_720p_cmd.h
@@ -0,0 +1,184 @@
+/* Copyright (c) 2013, The Linux Foundation. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ *  * Redistributions of source code must retain the above copyright
+ *    notice, this list of conditions and the following disclaimer.
+ *  * Redistributions in binary form must reproduce the above copyright
+ *    notice, this list of conditions and the following disclaimer in
+ *    the documentation and/or other materials provided with the
+ *    distribution.
+ *  * Neither the name of The Linux Foundation nor the names of its
+ *    contributors may be used to endorse or promote products derived
+ *    from this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+ * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+ * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
+ * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
+ * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
+ * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
+ * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
+ * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
+ * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
+ * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+ * SUCH DAMAGE.
+ */
+
+/*---------------------------------------------------------------------------
+ * This file is autogenerated file using gcdb parser. Please do not edit it.
+ * Update input XML file to add a new entry or update variable in this file
+ * VERSION = "1.0"
+ *---------------------------------------------------------------------------*/
+
+#ifndef _PANEL_GENERIC_720P_CMD_H_
+
+#define _PANEL_GENERIC_720P_CMD_H_
+/*---------------------------------------------------------------------------*/
+/* HEADER files                                                              */
+/*---------------------------------------------------------------------------*/
+#include "panel.h"
+
+/*---------------------------------------------------------------------------*/
+/* Panel configuration                                                       */
+/*---------------------------------------------------------------------------*/
+
+static struct panel_config generic_720p_cmd_panel_data = {
+  "qcom,mdss_dsi_generic_720p_cmd", "dsi:0:", "qcom,mdss-dsi-panel",
+  10, 1, "DISPLAY_1", 0, 0, 60, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0
+};
+
+/*---------------------------------------------------------------------------*/
+/* Panel resolution                                                          */
+/*---------------------------------------------------------------------------*/
+static struct panel_resolution generic_720p_cmd_panel_res = {
+  768, 1280, 26, 26, 26, 0, 2, 2, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0
+};
+
+/*---------------------------------------------------------------------------*/
+/* Panel Color Information                                                   */
+/*---------------------------------------------------------------------------*/
+static struct color_info generic_720p_cmd_color = {
+  24, 0, 0xff, 0, 0, 0
+};
+
+/*---------------------------------------------------------------------------*/
+/* Panel Command information                                                 */
+/*---------------------------------------------------------------------------*/
+static char generic_720p_cmd_on_cmd0[] = {
+0x11, 0x00, 0x05, 0x80 };
+
+
+static char generic_720p_cmd_on_cmd1[] = {
+0x36, 0x00, 0x15, 0x80 };
+
+
+static char generic_720p_cmd_on_cmd2[] = {
+0x29, 0x00, 0x05, 0x80 };
+
+
+static char generic_720p_cmd_on_cmd3[] = {
+0x53, 0x24, 0x15, 0x80 };
+
+
+static char generic_720p_cmd_on_cmd4[] = {
+0x35, 0x00, 0x15, 0x80 };
+
+
+
+
+static struct mipi_dsi_cmd generic_720p_cmd_on_command[] = {
+{ 0x4 , generic_720p_cmd_on_cmd0},
+{ 0x4 , generic_720p_cmd_on_cmd1},
+{ 0x4 , generic_720p_cmd_on_cmd2},
+{ 0x4 , generic_720p_cmd_on_cmd3},
+{ 0x4 , generic_720p_cmd_on_cmd4}
+};
+#define GENERIC_720P_CMD_ON_COMMAND 5
+
+
+static char generic_720p_cmdoff_cmd0[] = {
+0x34, 0x00, 0x05, 0x80 };
+
+
+static char generic_720p_cmdoff_cmd1[] = {
+0x10, 0x00, 0x05, 0x80 };
+
+
+static char generic_720p_cmdoff_cmd2[] = {
+0x28, 0x00, 0x05, 0x80 };
+
+
+static char generic_720p_cmdoff_cmd3[] = {
+0x53, 0x00, 0x15, 0x80 };
+
+
+
+
+static struct mipi_dsi_cmd generic_720p_cmd_off_command[] = {
+{ 0x4 , generic_720p_cmdoff_cmd0},
+{ 0x4 , generic_720p_cmdoff_cmd1},
+{ 0x4 , generic_720p_cmdoff_cmd2},
+{ 0x4 , generic_720p_cmdoff_cmd3}
+};
+#define GENERIC_720P_CMD_OFF_COMMAND 4
+
+
+static struct command_state generic_720p_cmd_state = {
+  0, 1
+};
+
+/*---------------------------------------------------------------------------*/
+/* Command mode panel information                                            */
+/*---------------------------------------------------------------------------*/
+
+static struct commandpanel_info generic_720p_cmd_command_panel = {
+  1, 1, 1, 0, 0, 0x2c, 0, 0, 0, 1, 0, 0
+};
+
+/*---------------------------------------------------------------------------*/
+/* Video mode panel information                                              */
+/*---------------------------------------------------------------------------*/
+
+static struct videopanel_info generic_720p_cmd_video_panel = {
+  0, 0, 0, 0, 1, 1, 1, 0, 0x9
+};
+
+/*---------------------------------------------------------------------------*/
+/* Lane Configuration                                                        */
+/*---------------------------------------------------------------------------*/
+
+static struct lane_configuration generic_720p_cmd_lane_config = {
+  4, 0, 1, 1, 1, 1
+};
+
+
+/*---------------------------------------------------------------------------*/
+/* Panel Timing                                                              */
+/*---------------------------------------------------------------------------*/
+static const uint32_t generic_720p_cmd_timings[] = {
+  0x6e, 0x26, 0x1b, 0x00, 0x35, 0x34, 0x20, 0x28, 0x17, 0x03, 0x04, 0x00
+};
+
+static struct panel_timing generic_720p_cmd_timing_info = {
+  0, 4, 0x20, 0x2a
+};
+
+static struct panel_reset_sequence generic_720p_cmd_reset_seq = {
+ { 1, 0, 1, }, { 20, 2, 20, }, 2
+};
+
+
+/*---------------------------------------------------------------------------*/
+/* Backlight Settings                                                        */
+/*---------------------------------------------------------------------------*/
+
+static struct backlight generic_720p_cmd_backlight = {
+  1, 1, 4095, 100, 1, "PMIC_8941"
+};
+
+#define GENERIC_720P_CMD_SIGNATURE 0x210000
+
+#endif /*_PANEL_GENERIC_720P_CMD_H_*/
diff --git a/target/msm8974/oem_panel.c b/target/msm8974/oem_panel.c
index 1f876d7..c9b87c2 100755
--- a/target/msm8974/oem_panel.c
+++ b/target/msm8974/oem_panel.c
@@ -43,8 +43,9 @@
 #include "include/panel_toshiba_720p_video.h"
 #include "include/panel_sharp_qhd_video.h"
 #include "include/panel_jdi_1080p_video.h"
+#include "include/panel_generic_720p_cmd.h"
 
-#define DISPLAY_MAX_PANEL_DETECTION 2
+#define DISPLAY_MAX_PANEL_DETECTION 3
 
 /*---------------------------------------------------------------------------*/
 /* static panel selection variable                                           */
@@ -53,6 +54,7 @@
 JDI_1080P_VIDEO_PANEL,
 TOSHIBA_720P_VIDEO_PANEL,
 SHARP_QHD_VIDEO_PANEL,
+GENERIC_720P_CMD_PANEL,
 UNKNOWN_PANEL
 };
 
@@ -147,6 +149,27 @@
 			jdi_1080p_video_timings, TIMING_SIZE);
 		pinfo->mipi.signature = JDI_1080P_VIDEO_SIGNATURE;
 		break;
+	case GENERIC_720P_CMD_PANEL:
+		panelstruct->paneldata    = &generic_720p_cmd_panel_data;
+		panelstruct->panelres     = &generic_720p_cmd_panel_res;
+		panelstruct->color        = &generic_720p_cmd_color;
+		panelstruct->videopanel   = &generic_720p_cmd_video_panel;
+		panelstruct->commandpanel = &generic_720p_cmd_command_panel;
+		panelstruct->state        = &generic_720p_cmd_state;
+		panelstruct->laneconfig   = &generic_720p_cmd_lane_config;
+		panelstruct->paneltiminginfo
+			= &generic_720p_cmd_timing_info;
+		panelstruct->panelresetseq
+					 = &generic_720p_cmd_reset_seq;
+		panelstruct->backlightinfo = &generic_720p_cmd_backlight;
+		pinfo->mipi.panel_cmds
+			= generic_720p_cmd_on_command;
+		pinfo->mipi.num_of_panel_cmds
+			= GENERIC_720P_CMD_ON_COMMAND;
+		memcpy(phy_db->timing,
+			generic_720p_cmd_timings, TIMING_SIZE);
+		pinfo->mipi.signature = GENERIC_720P_CMD_SIGNATURE;
+		break;
 	case UNKNOWN_PANEL:
 		memset(panelstruct, 0, sizeof(struct panel_struct));
 		memset(pinfo->mipi.panel_cmds, 0, sizeof(struct mipi_dsi_cmd));
@@ -184,6 +207,9 @@
 		case 1:
 			panel_id = TOSHIBA_720P_VIDEO_PANEL;
 			break;
+		case 2:
+			panel_id = GENERIC_720P_CMD_PANEL;
+			break;
 		default:
 			panel_id = UNKNOWN_PANEL;
 			ret = false;