blob: b778cf26da0cb1b5170fcabf06f32e3d464b5e0f [file] [log] [blame]
/* Copyright (c) 2014-2015, 2018 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 "AS IS" AND ANY EXPRESS OR IMPLIED
* WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT
* 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.
*
*/
#ifndef _TARGET_MSM8909_DISPLAY_H
#define _TARGET_MSM8909_DISPLAY_H
/*---------------------------------------------------------------------------*/
/* HEADER files */
/*---------------------------------------------------------------------------*/
#include <display_resource.h>
/*---------------------------------------------------------------------------*/
/* GPIO configuration */
/*---------------------------------------------------------------------------*/
static struct gpio_pin reset_gpio = {
"msmgpio", 25, 3, 1, 0, 1
};
static struct gpio_pin enable_gpio = {
"msmgpio", 97, 3, 1, 0, 1
};
static struct gpio_pin bkl_gpio = {
"msmgpio", 37, 3, 1, 0, 1
};
static struct gpio_pin spi_bkl_gpio = {
"msmgpio", 60, 3, 1, 0, 1
};
static struct gpio_pin enp_gpio = {
"msmgpio", 97, 3, 1, 0, 1
};
static struct gpio_pin enn_gpio = {
"msmgpio", 32, 3, 1, 0, 1
};
static struct gpio_pin dc_gpio = {
"msmgpio", 52, 3, 1, 0, 1
};
static struct gpio_pin spi_dc_gpio = {
"msmgpio", 59, 3, 1, 0, 1
};
static struct gpio_pin te_gpio = {
0, 0, 0, 0, 0, 0
};
static struct gpio_pin pwm_gpio = {
0, 0, 0, 0, 0, 0
};
/*---------------------------------------------------------------------------*/
/* Target Physical configuration */
/*---------------------------------------------------------------------------*/
static const uint32_t panel_strength_ctrl[] = {
0xff, 0x06
};
static const char panel_bist_ctrl[] = {
0x00, 0x00, 0xb1, 0xff, 0x00, 0x00
};
static const uint32_t panel_regulator_settings[] = {
0x00, 0x01, 0x01, 0x00, 0x20, 0x07, 0x00
};
static const char panel_lane_config[] = {
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x01, 0x97,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x01, 0x97,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x01, 0x97,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x01, 0x97,
0x00, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x01, 0xbb
};
static const uint32_t panel_physical_ctrl[] = {
0x5f, 0x00, 0x00, 0x10
};
/*---------------------------------------------------------------------------*/
/* Other Configuration */
/*---------------------------------------------------------------------------*/
#define DISPLAY_CMDLINE_PREFIX " mdss_mdp3.panel="
#define MIPI_FB_ADDR 0x83200000
#define MIPI_HSYNC_PULSE_WIDTH 12
#define MIPI_HSYNC_BACK_PORCH_DCLK 32
#define MIPI_HSYNC_FRONT_PORCH_DCLK 144
#define MIPI_VSYNC_PULSE_WIDTH 4
#define MIPI_VSYNC_BACK_PORCH_LINES 3
#define MIPI_VSYNC_FRONT_PORCH_LINES 9
#define SPI_BLSP_ID 1
#define SPI_QUP_ID 3
#endif