151 lines
4.8 KiB
C
151 lines
4.8 KiB
C
|
/**
|
||
|
* @file SSD1963.h
|
||
|
*
|
||
|
*/
|
||
|
|
||
|
#ifndef SSD1963_H
|
||
|
#define SSD1963_H
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
extern "C" {
|
||
|
#endif
|
||
|
|
||
|
/*********************
|
||
|
* INCLUDES
|
||
|
*********************/
|
||
|
#ifndef LV_DRV_NO_CONF
|
||
|
#ifdef LV_CONF_INCLUDE_SIMPLE
|
||
|
#include "lv_drv_conf.h"
|
||
|
#else
|
||
|
#include "../../lv_drv_conf.h"
|
||
|
#endif
|
||
|
#endif
|
||
|
|
||
|
#if USE_SSD1963
|
||
|
|
||
|
#ifdef LV_LVGL_H_INCLUDE_SIMPLE
|
||
|
#include "lvgl.h"
|
||
|
#else
|
||
|
#include "lvgl/lvgl.h"
|
||
|
#endif
|
||
|
|
||
|
/*********************
|
||
|
* DEFINES
|
||
|
*********************/
|
||
|
// SSD1963 command table
|
||
|
#define CMD_NOP 0x00 //No operation
|
||
|
#define CMD_SOFT_RESET 0x01 //Software reset
|
||
|
#define CMD_GET_PWR_MODE 0x0A //Get the current power mode
|
||
|
#define CMD_GET_ADDR_MODE 0x0B //Get the frame memory to the display panel read order
|
||
|
#define CMD_GET_PIXEL_FORMAT 0x0C //Get the current pixel format
|
||
|
#define CMD_GET_DISPLAY_MODE 0x0D //Returns the display mode
|
||
|
#define CMD_GET_SIGNAL_MODE 0x0E //
|
||
|
#define CMD_GET_DIAGNOSTIC 0x0F
|
||
|
#define CMD_ENT_SLEEP 0x10
|
||
|
#define CMD_EXIT_SLEEP 0x11
|
||
|
#define CMD_ENT_PARTIAL_MODE 0x12
|
||
|
#define CMD_ENT_NORMAL_MODE 0x13
|
||
|
#define CMD_EXIT_INVERT_MODE 0x20
|
||
|
#define CMD_ENT_INVERT_MODE 0x21
|
||
|
#define CMD_SET_GAMMA 0x26
|
||
|
#define CMD_BLANK_DISPLAY 0x28
|
||
|
#define CMD_ON_DISPLAY 0x29
|
||
|
#define CMD_SET_COLUMN 0x2A
|
||
|
#define CMD_SET_PAGE 0x2B
|
||
|
#define CMD_WR_MEMSTART 0x2C
|
||
|
#define CMD_RD_MEMSTART 0x2E
|
||
|
#define CMD_SET_PARTIAL_AREA 0x30
|
||
|
#define CMD_SET_SCROLL_AREA 0x33
|
||
|
#define CMD_SET_TEAR_OFF 0x34 //synchronization information is not sent from the display
|
||
|
#define CMD_SET_TEAR_ON 0x35 //sync. information is sent from the display
|
||
|
#define CMD_SET_ADDR_MODE 0x36 //set fram buffer read order to the display panel
|
||
|
#define CMD_SET_SCROLL_START 0x37
|
||
|
#define CMD_EXIT_IDLE_MODE 0x38
|
||
|
#define CMD_ENT_IDLE_MODE 0x39
|
||
|
#define CMD_SET_PIXEL_FORMAT 0x3A //defines how many bits per pixel is used
|
||
|
#define CMD_WR_MEM_AUTO 0x3C
|
||
|
#define CMD_RD_MEM_AUTO 0x3E
|
||
|
#define CMD_SET_TEAR_SCANLINE 0x44
|
||
|
#define CMD_GET_SCANLINE 0x45
|
||
|
#define CMD_RD_DDB_START 0xA1
|
||
|
#define CMD_RD_DDB_AUTO 0xA8
|
||
|
#define CMD_SET_PANEL_MODE 0xB0
|
||
|
#define CMD_GET_PANEL_MODE 0xB1
|
||
|
#define CMD_SET_HOR_PERIOD 0xB4
|
||
|
#define CMD_GET_HOR_PERIOD 0xB5
|
||
|
#define CMD_SET_VER_PERIOD 0xB6
|
||
|
#define CMD_GET_VER_PERIOD 0xB7
|
||
|
#define CMD_SET_GPIO_CONF 0xB8
|
||
|
#define CMD_GET_GPIO_CONF 0xB9
|
||
|
#define CMD_SET_GPIO_VAL 0xBA
|
||
|
#define CMD_GET_GPIO_STATUS 0xBB
|
||
|
#define CMD_SET_POST_PROC 0xBC
|
||
|
#define CMD_GET_POST_PROC 0xBD
|
||
|
#define CMD_SET_PWM_CONF 0xBE
|
||
|
#define CMD_GET_PWM_CONF 0xBF
|
||
|
#define CMD_SET_LCD_GEN0 0xC0
|
||
|
#define CMD_GET_LCD_GEN0 0xC1
|
||
|
#define CMD_SET_LCD_GEN1 0xC2
|
||
|
#define CMD_GET_LCD_GEN1 0xC3
|
||
|
#define CMD_SET_LCD_GEN2 0xC4
|
||
|
#define CMD_GET_LCD_GEN2 0xC5
|
||
|
#define CMD_SET_LCD_GEN3 0xC6
|
||
|
#define CMD_GET_LCD_GEN3 0xC7
|
||
|
#define CMD_SET_GPIO0_ROP 0xC8
|
||
|
#define CMD_GET_GPIO0_ROP 0xC9
|
||
|
#define CMD_SET_GPIO1_ROP 0xCA
|
||
|
#define CMD_GET_GPIO1_ROP 0xCB
|
||
|
#define CMD_SET_GPIO2_ROP 0xCC
|
||
|
#define CMD_GET_GPIO2_ROP 0xCD
|
||
|
#define CMD_SET_GPIO3_ROP 0xCE
|
||
|
#define CMD_GET_GPIO3_ROP 0xCF
|
||
|
#define CMD_SET_ABC_DBC_CONF 0xD0
|
||
|
#define CMD_GET_ABC_DBC_CONF 0xD1
|
||
|
#define CMD_SET_DBC_HISTO_PTR 0xD2
|
||
|
#define CMD_GET_DBC_HISTO_PTR 0xD3
|
||
|
#define CMD_SET_DBC_THRES 0xD4
|
||
|
#define CMD_GET_DBC_THRES 0xD5
|
||
|
#define CMD_SET_ABM_TMR 0xD6
|
||
|
#define CMD_GET_ABM_TMR 0xD7
|
||
|
#define CMD_SET_AMB_LVL0 0xD8
|
||
|
#define CMD_GET_AMB_LVL0 0xD9
|
||
|
#define CMD_SET_AMB_LVL1 0xDA
|
||
|
#define CMD_GET_AMB_LVL1 0xDB
|
||
|
#define CMD_SET_AMB_LVL2 0xDC
|
||
|
#define CMD_GET_AMB_LVL2 0xDD
|
||
|
#define CMD_SET_AMB_LVL3 0xDE
|
||
|
#define CMD_GET_AMB_LVL3 0xDF
|
||
|
#define CMD_PLL_START 0xE0 //start the PLL
|
||
|
#define CMD_PLL_STOP 0xE1 //disable the PLL
|
||
|
#define CMD_SET_PLL_MN 0xE2
|
||
|
#define CMD_GET_PLL_MN 0xE3
|
||
|
#define CMD_GET_PLL_STATUS 0xE4 //get the current PLL status
|
||
|
#define CMD_ENT_DEEP_SLEEP 0xE5
|
||
|
#define CMD_SET_PCLK 0xE6 //set pixel clock (LSHIFT signal) frequency
|
||
|
#define CMD_GET_PCLK 0xE7 //get pixel clock (LSHIFT signal) freq. settings
|
||
|
#define CMD_SET_DATA_INTERFACE 0xF0
|
||
|
#define CMD_GET_DATA_INTERFACE 0xF1
|
||
|
|
||
|
|
||
|
/**********************
|
||
|
* TYPEDEFS
|
||
|
**********************/
|
||
|
|
||
|
/**********************
|
||
|
* GLOBAL PROTOTYPES
|
||
|
**********************/
|
||
|
void ssd1963_init(void);
|
||
|
void ssd1963_flush(lv_disp_drv_t * disp_drv, const lv_area_t * area, lv_color_t * color_p);
|
||
|
|
||
|
/**********************
|
||
|
* MACROS
|
||
|
**********************/
|
||
|
|
||
|
#endif /* USE_SSD1963 */
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
} /* extern "C" */
|
||
|
#endif
|
||
|
|
||
|
#endif /* SSD1963_H */
|