#include "p_ssd1963.h" #define LV_DRV_DELAY_MS(x) delay_ms(x) #define LV_DRV_DISP_CMD_DATA(x) /** * @file SSD1963.c * */ /********************* * INCLUDES *********************/ #include "SSD1963.h" #if USE_SSD1963 #include /********************* * DEFINES *********************/ #define SSD1963_CMD_MODE 0 #define SSD1963_DATA_MODE 1 /********************** * TYPEDEFS **********************/ /********************** * STATIC PROTOTYPES **********************/ static inline void ssd1963_cmd_mode(void); static inline void ssd1963_data_mode(void); static inline void ssd1963_cmd(uint8_t cmd); static inline void ssd1963_data(uint8_t data); static void ssd1963_io_init(void); static void ssd1963_reset(void); static void ssd1963_set_clk(void); static void ssd1963_set_tft_spec(void); static void ssd1963_init_bl(void); /********************** * STATIC VARIABLES **********************/ static bool cmd_mode = true; /********************** * MACROS **********************/ /********************** * GLOBAL FUNCTIONS **********************/ void ssd1963_init(void) { LV_DRV_DISP_CMD_DATA(SSD1963_CMD_MODE); cmd_mode = true; LV_DRV_DELAY_MS(250); ssd1963_cmd(0x00E2); //PLL multiplier, set PLL clock to 120M ssd1963_data(0x0023); //N=0x36 for 6.5M, 0x23 for 10M crystal ssd1963_data(0x0002); ssd1963_data(0x0004); ssd1963_cmd(0x00E0); // PLL enable ssd1963_data(0x0001); LV_DRV_DELAY_MS(1); ssd1963_cmd(0x00E0); ssd1963_data(0x0003); // now, use PLL output as system clock LV_DRV_DELAY_MS(1); ssd1963_cmd(0x0001); // software reset LV_DRV_DELAY_MS(1); ssd1963_cmd(0x00E6); //PLL setting for PCLK, depends on resolution ssd1963_data(0x0001); //HX8257C ssd1963_data(0x0033); //HX8257C ssd1963_data(0x0033); //HX8257C ssd1963_cmd(0x00B0); //LCD SPECIFICATION ssd1963_data(0x0020); ssd1963_data(0x0000); ssd1963_data(((SSD1963_HOR_RES - 1) >> 8) & 0X00FF); //Set HDP ssd1963_data((SSD1963_HOR_RES - 1) & 0X00FF); ssd1963_data(((SSD1963_VER_RES - 1) >> 8) & 0X00FF); //Set VDP ssd1963_data((SSD1963_VER_RES - 1) & 0X00FF); ssd1963_data(0x0000); LV_DRV_DELAY_MS(1);//Delay10us(5); ssd1963_cmd(0x00B4); //HSYNC ssd1963_data((SSD1963_HT >> 8) & 0X00FF); //Set HT ssd1963_data(SSD1963_HT & 0X00FF); ssd1963_data((SSD1963_HPS >> 8) & 0X00FF); //Set HPS ssd1963_data(SSD1963_HPS & 0X00FF); ssd1963_data(SSD1963_HPW); //Set HPW ssd1963_data((SSD1963_LPS >> 8) & 0X00FF); //SetLPS ssd1963_data(SSD1963_LPS & 0X00FF); ssd1963_data(0x0000); ssd1963_cmd(0x00B6); //VSYNC ssd1963_data((SSD1963_VT >> 8) & 0X00FF); //Set VT ssd1963_data(SSD1963_VT & 0X00FF); ssd1963_data((SSD1963_VPS >> 8) & 0X00FF); //Set VPS ssd1963_data(SSD1963_VPS & 0X00FF); ssd1963_data(SSD1963_VPW); //Set VPW ssd1963_data((SSD1963_FPS >> 8) & 0X00FF); //Set FPS ssd1963_data(SSD1963_FPS & 0X00FF); ssd1963_cmd(0x00B8); ssd1963_data(0x000f); //GPIO is controlled by host GPIO[3:0]=output GPIO[0]=1 LCD ON GPIO[0]=1 LCD OFF ssd1963_data(0x0001); //GPIO0 normal ssd1963_cmd(0x00BA); ssd1963_data(0x0001); //GPIO[0] out 1 --- LCD display on/off control PIN ssd1963_cmd(0x0036); //rotation ssd1963_data(0x0008); //RGB=BGR ssd1963_cmd(0x003A); //Set the current pixel format for RGB image data ssd1963_data(0x0050); //16-bit/pixel ssd1963_cmd(0x00F0); //Pixel Data Interface Format ssd1963_data(0x0003); //16-bit(565 format) data ssd1963_cmd(0x00BC); ssd1963_data(0x0040); //contrast value ssd1963_data(0x0080); //brightness value ssd1963_data(0x0040); //saturation value ssd1963_data(0x0001); //Post Processor Enable LV_DRV_DELAY_MS(1); ssd1963_cmd(0x0029); //display on ssd1963_cmd(0x00BE); //set PWM for B/L ssd1963_data(0x0006); ssd1963_data(0x0080); ssd1963_data(0x0001); ssd1963_data(0x00f0); ssd1963_data(0x0000); ssd1963_data(0x0000); ssd1963_cmd(0x00d0); ssd1963_data(0x000d); //DisplayBacklightOn(); LV_DRV_DELAY_MS(30); } void ssd1963_flush(lv_disp_drv_t * disp_drv, const lv_area_t * area, lv_color_t * color_p) { /*Return if the area is out the screen*/ if(area->x2 < 0) return; if(area->y2 < 0) return; if(area->x1 > SSD1963_HOR_RES - 1) return; if(area->y1 > SSD1963_VER_RES - 1) return; /*Truncate the area to the screen*/ int32_t act_x1 = area->x1 < 0 ? 0 : area->x1; int32_t act_y1 = area->y1 < 0 ? 0 : area->y1; int32_t act_x2 = area->x2 > SSD1963_HOR_RES - 1 ? SSD1963_HOR_RES - 1 : area->x2; int32_t act_y2 = area->y2 > SSD1963_VER_RES - 1 ? SSD1963_VER_RES - 1 : area->y2; //Set the rectangular area ssd1963_cmd(0x002A); ssd1963_data(act_x1 >> 8); ssd1963_data(0x00FF & act_x1); ssd1963_data(act_x2 >> 8); ssd1963_data(0x00FF & act_x2); ssd1963_cmd(0x002B); ssd1963_data(act_y1 >> 8); ssd1963_data(0x00FF & act_y1); ssd1963_data(act_y2 >> 8); ssd1963_data(0x00FF & act_y2); ssd1963_cmd(0x2c); int16_t i; uint16_t full_w = area->x2 - area->x1 + 1; ssd1963_data_mode(); LV_DRV_DISP_PAR_CS(0); #if LV_COLOR_DEPTH == 16 uint16_t act_w = act_x2 - act_x1 + 1; for(i = act_y1; i <= act_y2; i++) { LV_DRV_DISP_PAR_WR_ARRAY((uint16_t *)color_p, act_w); color_p += full_w; } LV_DRV_DISP_PAR_CS(1); #else int16_t j; for(i = act_y1; i <= act_y2; i++) { for(j = 0; j <= act_x2 - act_x1 + 1; j++) { LV_DRV_DISP_PAR_WR_WORD(color_p[j]); color_p += full_w; } } #endif lv_disp_flush_ready(disp_drv); } /********************** * STATIC FUNCTIONS **********************/ static void ssd1963_io_init(void) { LV_DRV_DISP_CMD_DATA(SSD1963_CMD_MODE); cmd_mode = true; } static void ssd1963_reset(void) { /*Hardware reset*/ LV_DRV_DISP_RST(1); LV_DRV_DELAY_MS(50); LV_DRV_DISP_RST(0); LV_DRV_DELAY_MS(50); LV_DRV_DISP_RST(1); LV_DRV_DELAY_MS(50); /*Chip enable*/ LV_DRV_DISP_PAR_CS(0); LV_DRV_DELAY_MS(10); LV_DRV_DISP_PAR_CS(1); LV_DRV_DELAY_MS(5); /*Software reset*/ ssd1963_cmd(0x01); LV_DRV_DELAY_MS(20); ssd1963_cmd(0x01); LV_DRV_DELAY_MS(20); ssd1963_cmd(0x01); LV_DRV_DELAY_MS(20); } /** * Command mode */ static inline void ssd1963_cmd_mode(void) { if(cmd_mode == false) { LV_DRV_DISP_CMD_DATA(SSD1963_CMD_MODE); cmd_mode = true; } } /** * Data mode */ static inline void ssd1963_data_mode(void) { if(cmd_mode != false) { LV_DRV_DISP_CMD_DATA(SSD1963_DATA_MODE); cmd_mode = false; } } /** * Write command * @param cmd the command */ static inline void ssd1963_cmd(uint8_t cmd) { LV_DRV_DISP_PAR_CS(0); ssd1963_cmd_mode(); LV_DRV_DISP_PAR_WR_WORD(cmd); LV_DRV_DISP_PAR_CS(1); } /** * Write data * @param data the data */ static inline void ssd1963_data(uint8_t data) { LV_DRV_DISP_PAR_CS(0); ssd1963_data_mode(); LV_DRV_DISP_PAR_WR_WORD(data); LV_DRV_DISP_PAR_CS(1); } #endif