225 lines
9.1 KiB
C
225 lines
9.1 KiB
C
/**
|
|
******************************************************************************
|
|
* @file otm8009a.h
|
|
* @author MCD Application Team
|
|
* @version V1.0.2
|
|
* @date 27-January-2017
|
|
* @brief This file contains all the constants parameters for the OTM8009A
|
|
* which is the LCD Driver for KoD KM-040TMP-02-0621 (WVGA)
|
|
* DSI LCD Display.
|
|
******************************************************************************
|
|
* @attention
|
|
*
|
|
* <h2><center>© COPYRIGHT(c) 2017 STMicroelectronics</center></h2>
|
|
*
|
|
* Redistribution and use in source and binary forms, with or without modification,
|
|
* are permitted provided that the following conditions are met:
|
|
* 1. Redistributions of source code must retain the above copyright notice,
|
|
* this list of conditions and the following disclaimer.
|
|
* 2. 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.
|
|
* 3. Neither the name of STMicroelectronics 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 HOLDER 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.
|
|
*
|
|
******************************************************************************
|
|
*/
|
|
|
|
/* Define to prevent recursive inclusion -------------------------------------*/
|
|
#ifndef __OTM8009A_H
|
|
#define __OTM8009A_H
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/* Includes ------------------------------------------------------------------*/
|
|
#include <stdint.h>
|
|
/** @addtogroup BSP
|
|
* @{
|
|
*/
|
|
|
|
/** @addtogroup Components
|
|
* @{
|
|
*/
|
|
|
|
/** @addtogroup otm8009a
|
|
* @{
|
|
*/
|
|
|
|
/** @addtogroup OTM8009A_Exported_Variables
|
|
* @{
|
|
*/
|
|
|
|
#if defined ( __GNUC__ )
|
|
#ifndef __weak
|
|
#define __weak __attribute__((weak))
|
|
#endif /* __weak */
|
|
#endif /* __GNUC__ */
|
|
|
|
/**
|
|
* @brief LCD_OrientationTypeDef
|
|
* Possible values of Display Orientation
|
|
*/
|
|
#define OTM8009A_ORIENTATION_PORTRAIT ((gU32)0x00) /* Portrait orientation choice of LCD screen */
|
|
#define OTM8009A_ORIENTATION_LANDSCAPE ((gU32)0x01) /* Landscape orientation choice of LCD screen */
|
|
|
|
/**
|
|
* @brief Possible values of
|
|
* pixel data format (ie color coding) transmitted on DSI Data lane in DSI packets
|
|
*/
|
|
#define OTM8009A_FORMAT_RGB888 ((gU32)0x00) /* Pixel format chosen is RGB888 : 24 bpp */
|
|
#define OTM8009A_FORMAT_RBG565 ((gU32)0x02) /* Pixel format chosen is RGB565 : 16 bpp */
|
|
|
|
/**
|
|
* @brief otm8009a_480x800 Size
|
|
*/
|
|
|
|
/* Width and Height in Portrait mode */
|
|
#define OTM8009A_480X800_WIDTH ((gU16)480) /* LCD PIXEL WIDTH */
|
|
#define OTM8009A_480X800_HEIGHT ((gU16)800) /* LCD PIXEL HEIGHT */
|
|
|
|
/* Width and Height in Landscape mode */
|
|
#define OTM8009A_800X480_WIDTH ((gU16)800) /* LCD PIXEL WIDTH */
|
|
#define OTM8009A_800X480_HEIGHT ((gU16)480) /* LCD PIXEL HEIGHT */
|
|
|
|
/**
|
|
* @brief OTM8009A_480X800 Timing parameters for Portrait orientation mode
|
|
*/
|
|
#define OTM8009A_480X800_HSYNC ((gU16)2) /* Horizontal synchronization */
|
|
#define OTM8009A_480X800_HBP ((gU16)34) /* Horizontal back porch */
|
|
#define OTM8009A_480X800_HFP ((gU16)34) /* Horizontal front porch */
|
|
#define OTM8009A_480X800_VSYNC ((gU16)1) /* Vertical synchronization */
|
|
#define OTM8009A_480X800_VBP ((gU16)15) /* Vertical back porch */
|
|
#define OTM8009A_480X800_VFP ((gU16)16) /* Vertical front porch */
|
|
|
|
/**
|
|
* @brief OTM8009A_800X480 Timing parameters for Landscape orientation mode
|
|
* Same values as for Portrait mode in fact.
|
|
*/
|
|
#define OTM8009A_800X480_HSYNC OTM8009A_480X800_VSYNC /* Horizontal synchronization */
|
|
#define OTM8009A_800X480_HBP OTM8009A_480X800_VBP /* Horizontal back porch */
|
|
#define OTM8009A_800X480_HFP OTM8009A_480X800_VFP /* Horizontal front porch */
|
|
#define OTM8009A_800X480_VSYNC OTM8009A_480X800_HSYNC /* Vertical synchronization */
|
|
#define OTM8009A_800X480_VBP OTM8009A_480X800_HBP /* Vertical back porch */
|
|
#define OTM8009A_800X480_VFP OTM8009A_480X800_HFP /* Vertical front porch */
|
|
|
|
|
|
/* List of OTM8009A used commands */
|
|
/* Detailed in OTM8009A Data Sheet 'DATA_SHEET_OTM8009A_V0 92.pdf' */
|
|
/* Version of 14 June 2012 */
|
|
#define OTM8009A_CMD_NOP 0x00 /* NOP command */
|
|
#define OTM8009A_CMD_SWRESET 0x01 /* Sw reset command */
|
|
#define OTM8009A_CMD_RDDMADCTL 0x0B /* Read Display MADCTR command : read memory display access ctrl */
|
|
#define OTM8009A_CMD_RDDCOLMOD 0x0C /* Read Display pixel format */
|
|
#define OTM8009A_CMD_SLPIN 0x10 /* Sleep In command */
|
|
#define OTM8009A_CMD_SLPOUT 0x11 /* Sleep Out command */
|
|
#define OTM8009A_CMD_PTLON 0x12 /* Partial mode On command */
|
|
|
|
#define OTM8009A_CMD_DISPOFF 0x28 /* Display Off command */
|
|
#define OTM8009A_CMD_DISPON 0x29 /* Display On command */
|
|
|
|
#define OTM8009A_CMD_CASET 0x2A /* Column address set command */
|
|
#define OTM8009A_CMD_PASET 0x2B /* Page address set command */
|
|
|
|
#define OTM8009A_CMD_RAMWR 0x2C /* Memory (GRAM) write command */
|
|
#define OTM8009A_CMD_RAMRD 0x2E /* Memory (GRAM) read command */
|
|
|
|
#define OTM8009A_CMD_PLTAR 0x30 /* Partial area command (4 parameters) */
|
|
|
|
#define OTM8009A_CMD_TEOFF 0x34 /* Tearing Effect Line Off command : command with no parameter */
|
|
|
|
#define OTM8009A_CMD_TEEON 0x35 /* Tearing Effect Line On command : command with 1 parameter 'TELOM' */
|
|
|
|
/* Parameter TELOM : Tearing Effect Line Output Mode : possible values */
|
|
#define OTM8009A_TEEON_TELOM_VBLANKING_INFO_ONLY 0x00
|
|
#define OTM8009A_TEEON_TELOM_VBLANKING_AND_HBLANKING_INFO 0x01
|
|
|
|
#define OTM8009A_CMD_MADCTR 0x36 /* Memory Access write control command */
|
|
|
|
/* Possible used values of MADCTR */
|
|
#define OTM8009A_MADCTR_MODE_PORTRAIT 0x00
|
|
#define OTM8009A_MADCTR_MODE_LANDSCAPE 0x60 /* MY = 0, MX = 1, MV = 1, ML = 0, RGB = 0 */
|
|
|
|
#define OTM8009A_CMD_IDMOFF 0x38 /* Idle mode Off command */
|
|
#define OTM8009A_CMD_IDMON 0x39 /* Idle mode On command */
|
|
|
|
#define OTM8009A_CMD_COLMOD 0x3A /* Interface Pixel format command */
|
|
|
|
/* Possible values of COLMOD parameter corresponding to used pixel formats */
|
|
#define OTM8009A_COLMOD_RGB565 0x55
|
|
#define OTM8009A_COLMOD_RGB888 0x77
|
|
|
|
#define OTM8009A_CMD_RAMWRC 0x3C /* Memory write continue command */
|
|
#define OTM8009A_CMD_RAMRDC 0x3E /* Memory read continue command */
|
|
|
|
#define OTM8009A_CMD_WRTESCN 0x44 /* Write Tearing Effect Scan line command */
|
|
#define OTM8009A_CMD_RDSCNL 0x45 /* Read Tearing Effect Scan line command */
|
|
|
|
/* CABC Management : ie : Content Adaptive Back light Control in IC OTM8009a */
|
|
#define OTM8009A_CMD_WRDISBV 0x51 /* Write Display Brightness command */
|
|
#define OTM8009A_CMD_WRCTRLD 0x53 /* Write CTRL Display command */
|
|
#define OTM8009A_CMD_WRCABC 0x55 /* Write Content Adaptive Brightness command */
|
|
#define OTM8009A_CMD_WRCABCMB 0x5E /* Write CABC Minimum Brightness command */
|
|
|
|
/**
|
|
* @brief OTM8009A_480X800 frequency divider
|
|
*/
|
|
#define OTM8009A_480X800_FREQUENCY_DIVIDER 2 /* LCD Frequency divider */
|
|
|
|
/**
|
|
* @}
|
|
*/
|
|
|
|
/* Exported macro ------------------------------------------------------------*/
|
|
|
|
/** @defgroup OTM8009A_Exported_Macros OTM8009A Exported Macros
|
|
* @{
|
|
*/
|
|
|
|
/**
|
|
* @}
|
|
*/
|
|
|
|
/* Exported functions --------------------------------------------------------*/
|
|
|
|
/** @addtogroup OTM8009A_Exported_Functions
|
|
* @{
|
|
*/
|
|
void DSI_IO_WriteCmd(gU32 NbrParams, gU8 *pParams);
|
|
gU8 OTM8009A_Init(gU32 ColorCoding, gU32 orientation);
|
|
void OTM8009A_IO_Delay(gU32 Delay);
|
|
/**
|
|
* @}
|
|
*/
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* __OTM8009A_480X800_H */
|
|
/**
|
|
* @}
|
|
*/
|
|
|
|
/**
|
|
* @}
|
|
*/
|
|
|
|
/**
|
|
* @}
|
|
*/
|
|
|
|
/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/
|