124 lines
6.4 KiB
C
124 lines
6.4 KiB
C
/****************************************************************************
|
|
* drivers/lcd/st7789.h
|
|
*
|
|
* Licensed to the Apache Software Foundation (ASF) under one or more
|
|
* contributor license agreements. See the NOTICE file distributed with
|
|
* this work for additional information regarding copyright ownership. The
|
|
* ASF licenses this file to you under the Apache License, Version 2.0 (the
|
|
* "License"); you may not use this file except in compliance with the
|
|
* License. You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
* License for the specific language governing permissions and limitations
|
|
* under the License.
|
|
*
|
|
****************************************************************************/
|
|
|
|
#ifndef __DRIVERS_LCD_ST7789_H
|
|
#define __DRIVERS_LCD_ST7789_H
|
|
|
|
/****************************************************************************
|
|
* Included Files
|
|
****************************************************************************/
|
|
|
|
/****************************************************************************
|
|
* Pre-processor Definitions
|
|
****************************************************************************/
|
|
|
|
/* System Function Command Table 1 */
|
|
|
|
#define ST7789_NOP 0x00 /* No Operation */
|
|
#define ST7789_SWRESET 0x01 /* Software Reset */
|
|
#define ST7789_RDDID 0x04 /* Read Display ID */
|
|
#define ST7789_RDDST 0x09 /* Read Display Status */
|
|
#define ST7789_RDDPM 0x0a /* Read Display Power */
|
|
#define ST7789_RDDMADCTL 0x0b /* Read Display MADCTL */
|
|
#define ST7789_RDDCOLMOD 0x0c /* Read Display Pixel Format */
|
|
#define ST7789_RDDIM 0x0d /* Read Display Image Mode */
|
|
#define ST7789_RDDSM 0x0e /* Read Display Signal Mode */
|
|
#define ST7789_RDDSDR 0x0f /* Read Display Self-Diagnostic Result */
|
|
#define ST7789_SLPIN 0x10 /* Sleep In & Booster Off */
|
|
#define ST7789_SLPOUT 0x11 /* Sleep Out & Booster On */
|
|
#define ST7789_PTLON 0x12 /* Partial Mode On */
|
|
#define ST7789_NORON 0x13 /* Partial Mode Off */
|
|
#define ST7789_INVOFF 0x20 /* Display Inversion Off */
|
|
#define ST7789_INVON 0x21 /* Display Inversion On */
|
|
#define ST7789_GAMSET 0x26 /* Gamma Set */
|
|
#define ST7789_DISPOFF 0x28 /* Display Off */
|
|
#define ST7789_DISPON 0x29 /* Display On */
|
|
#define ST7789_CASET 0x2a /* Column Address Set */
|
|
#define ST7789_RASET 0x2b /* Row Address Set */
|
|
#define ST7789_RAMWR 0x2c /* Memory Write */
|
|
#define ST7789_RAMRD 0x2e /* Memory Read */
|
|
#define ST7789_PTLAR 0x30 /* Partial Area */
|
|
#define ST7789_VSCRDEF 0x33 /* Vertical Scrolling Definition */
|
|
#define ST7789_TEOFF 0x34 /* Tearing Effect Line Off */
|
|
#define ST7789_TEON 0x35 /* Tearing Effect Line On */
|
|
#define ST7789_MADCTL 0x36 /* Memory Data Access Control */
|
|
#define ST7789_VSCRSADD 0x37 /* Vertical Scrolling Start Address */
|
|
#define ST7789_IDMOFF 0x38 /* Idle Mode Off */
|
|
#define ST7789_IDMON 0x39 /* Idle Mode On */
|
|
#define ST7789_COLMOD 0x3a /* Interface Pixel Format */
|
|
#define ST7789_RAMWRC 0x3c /* Memory Write Continue */
|
|
#define ST7789_RAMRDC 0x3e /* Memory Read Continue */
|
|
#define ST7789_TESCAN 0x44 /* Set Tear Scanline */
|
|
#define ST7789_RDTESCAN 0x45 /* Get Scanline */
|
|
#define ST7789_WRDISBV 0x51 /* Write Display Brightness */
|
|
#define ST7789_RDDISBV 0x52 /* Read Display Brightness Value */
|
|
#define ST7789_WRCTRLD 0x53 /* Write CTRL Display */
|
|
#define ST7789_RDCTRLD 0x54 /* Read CTRL Value Display */
|
|
#define ST7789_WRCACE 0x55 /* Write Content Adaptive Brightness Control and Color Enhancement */
|
|
#define ST7789_RDCABC 0x56 /* Read Content Adaptive Brightness Control */
|
|
#define ST7789_WRCABCMB 0x5e /* Write CABC Minimum Brightness */
|
|
#define ST7789_RDCABCMB 0x5f /* Read CABC Minimum Brightness */
|
|
#define ST7789_RDABCSDR 0x68 /* Read Automatic Brightness Control Self-Diagnostic Result */
|
|
#define ST7789_RDID1 0xda /* Read ID1 */
|
|
#define ST7789_RDID2 0xdb /* Read ID2 */
|
|
#define ST7789_RDID3 0xdc /* Read ID3 */
|
|
|
|
/* System Function Command Table 2 */
|
|
|
|
#define ST7789_RAMCTRL 0xb0 /* RAM Control */
|
|
#define ST7789_RGBCTRL 0xb1 /* RGB Control */
|
|
#define ST7789_PORCTRL 0xb2 /* Porch Control */
|
|
#define ST7789_FRCTRL1 0xb3 /* Frame Rate Control */
|
|
#define ST7789_PARCTRL 0xb5 /* Partial Control */
|
|
#define ST7789_GCTRL 0xb7 /* Gate Control */
|
|
#define ST7789_GTADJ 0xb8 /* Gate on Timing Adjustment */
|
|
#define ST7789_DGMEN 0xba /* Digital Gamma Enable */
|
|
#define ST7789_VCOMS 0xbb /* VCOMS Setting */
|
|
#define ST7789_POWSAVE 0xbc /* Power Saving Mode */
|
|
#define ST7789_DLPOFFSAVE 0xbd /* Display Off Power Save */
|
|
#define ST7789_LCMCTRL 0xc0 /* LCM Control */
|
|
#define ST7789_IDSET 0xc1 /* ID Setting */
|
|
#define ST7789_VDVVRHEN 0xc2 /* VDV and VRH Command Enable */
|
|
#define ST7789_VRHS 0xc3 /* VRH Set */
|
|
#define ST7789_VDVSET 0xc4 /* VDV Set */
|
|
#define ST7789_VCMOFSET 0xc5 /* VCOMS Offset Set */
|
|
#define ST7789_FRCTR2 0xc6 /* FR Control 2 */
|
|
#define ST7789_CABCCTRL 0xc7 /* CABC Control */
|
|
#define ST7789_REGSEL1 0xc8 /* Register Value Selection 1 */
|
|
#define ST7789_REGSEL2 0xca /* Register Value Selection 2 */
|
|
#define ST7789_PWMFRSEL 0xcc /* PWM Frequency Selection */
|
|
#define ST7789_PWCTRL1 0xd0 /* Power Control 1 */
|
|
#define ST7789_VAPVANEN 0xd2 /* Enable VAP/VAN Signal Output */
|
|
#define ST7789_CMD2EN 0xdf /* Command 2 Enable */
|
|
#define ST7789_PVGAMCTRL 0xe0 /* Positive Voltage Gamma Control */
|
|
#define ST7789_NVGAMCTRL 0xe1 /* Negative Voltage Gamma Control */
|
|
#define ST7789_DGMLUTR 0xe2 /* Digital Gamma Look-Up Table for Red */
|
|
#define ST7789_DGMLUTB 0xe3 /* Digital Gamma Look-Up Table for Blue */
|
|
#define ST7789_GATECTRL 0xe4 /* Gate Control */
|
|
#define ST7789_SPI2EN 0xe7 /* SPI2 Enable */
|
|
#define ST7789_PWCTRL2 0xe8 /* Power Control 2 */
|
|
#define ST7789_EQCTRL 0xe9 /* Equalize Time Control */
|
|
#define ST7789_PROMCTRL 0xec /* Program Control */
|
|
#define ST7789_PROMEN 0xfa /* Program Mode Enable */
|
|
#define ST7789_NVMSET 0xfc /* NVM Setting */
|
|
#define ST7789_PROMACT 0xfe /* Program Action */
|
|
|
|
#endif /* __DRIVERS_LCD_ST7789_H */
|