zephyr/drivers/display/uc81xx_regs.h
Xiao Qin 7c46b0b898 drivers: display: uc81xx: add support for uc8175
Add support for uc8175 display driver. uc8175 has a slightly
different command/data length requirements for certain registers,
namely TRES and PTL, compared to uc8176/uc8179

This commit refactors the driver code and such that setting TRES and PTL
registers are now done by function pointers provided by config->quirks,
by the same token as how it is done for setting CDI register

Signed-off-by: Xiao Qin <xiaoq@google.com>
2023-12-11 15:57:21 +01:00

151 lines
3.5 KiB
C

/*
* Copyright (c) 2020 PHYTEC Messtechnik GmbH
*
* SPDX-License-Identifier: Apache-2.0
*/
#ifndef ZEPHYR_DRIVERS_DISPLAY_UC81XX_REGS_H_
#define ZEPHYR_DRIVERS_DISPLAY_UC81XX_REGS_H_
/* UC8176/UC8179 */
#define UC81XX_CMD_PSR 0x00
#define UC81XX_CMD_PWR 0x01
#define UC81XX_CMD_POF 0x02
#define UC81XX_CMD_PFS 0x03
#define UC81XX_CMD_PON 0x04
#define UC81XX_CMD_PMES 0x05
#define UC81XX_CMD_BTST 0x06
#define UC81XX_CMD_DSLP 0x07
#define UC81XX_CMD_DTM1 0x10
#define UC81XX_CMD_DSP 0x11
#define UC81XX_CMD_DRF 0x12
/* UC8179 only */
#define UC81XX_CMD_DTM2 0x13
#define UC81XX_CMD_DUSPI 0x15
#define UC81XX_CMD_AUTO 0x17
#define UC81XX_CMD_LUTOPT 0x2A
#define UC81XX_CMD_KWOPT 0x2B
#define UC81XX_CMD_LUTC 0x20
#define UC81XX_CMD_LUTWW 0x21
#define UC81XX_CMD_LUTKW 0x22
#define UC81XX_CMD_LUTWK 0x23
#define UC81XX_CMD_LUTKK 0x24
#define UC81XX_CMD_LUTBD 0x25
/* UC8176/UC8179 */
#define UC81XX_CMD_PLL 0x30
#define UC81XX_CMD_TSC 0x40
#define UC81XX_CMD_TSE 0x41
#define UC81XX_CMD_TSW 0x42
#define UC81XX_CMD_TSR 0x43
/* UC8179 */
#define UC81XX_CMD_PBC 0x44
/* UC8176/UC8179 - different register layouts */
#define UC81XX_CMD_CDI 0x50
/* UC8176/UC8179 */
#define UC81XX_CMD_LPD 0x51
/* UC8179 */
#define UC81XX_CMD_EVS 0x52
/* UC8176/UC8179 */
#define UC81XX_CMD_TCON 0x60
#define UC81XX_CMD_TRES 0x61
#define UC81XX_CMD_GSST 0x65
#define UC81XX_CMD_REV 0x70
#define UC81XX_CMD_FLG 0x71
#define UC81XX_CMD_AMV 0x80
#define UC81XX_CMD_VV 0x81
#define UC81XX_CMD_VDCS 0x82
#define UC81XX_CMD_PTL 0x90
#define UC81XX_CMD_PTIN 0x91
#define UC81XX_CMD_PTOUT 0x92
#define UC81XX_CMD_PGM 0xA0
#define UC81XX_CMD_APG 0xA1
#define UC81XX_CMD_ROTP 0xA2
#define UC81XX_CMD_CCSET 0xE0
#define UC81XX_CMD_PWS 0xE3
/* UC8179 */
#define UC81XX_CMD_LVSEL 0xE4
/* UC8176/UC8179 */
#define UC81XX_CMD_TSSET 0xE5
/* UC8179 */
#define UC81XX_CMD_TSBDRY 0xE7
#define UC81XX_PSR_REG BIT(5)
#define UC81XX_PSR_KW_R BIT(4)
#define UC81XX_PSR_UD BIT(3)
#define UC81XX_PSR_SHL BIT(2)
#define UC81XX_PSR_SHD BIT(1)
#define UC81XX_PSR_RST BIT(0)
#define UC81XX_AUTO_PON_DRF_POF 0xA5
#define UC81XX_AUTO_PON_DRF_POF_DSLP 0xA7
#define UC8176_CDI_VBD_MASK 0xc0
#define UC8176_CDI_VBD0 BIT(6)
#define UC8176_CDI_VBD1 BIT(7)
#define UC8176_CDI_DDX1 BIT(5)
#define UC8176_CDI_DDX0 BIT(4)
#define UC8176_CDI_CDI_MASK 0x0f
#define UC8179_CDI_REG_LENGTH 2U
#define UC8179_CDI_BDZ_DDX_IDX 0
#define UC8179_CDI_CDI_IDX 1
#define UC8179_CDI_BDZ BIT(7)
#define UC8179_CDI_BDV1 BIT(5)
#define UC8179_CDI_BDV0 BIT(4)
#define UC8179_CDI_N2OCP BIT(3)
#define UC8179_CDI_DDX1 BIT(1)
#define UC8179_CDI_DDX0 BIT(0)
struct uc81xx_tres8 {
uint8_t hres;
uint8_t vres;
} __packed;
BUILD_ASSERT(sizeof(struct uc81xx_tres8) == 2);
struct uc81xx_ptl8 {
uint8_t hrst;
uint8_t hred;
uint8_t vrst;
uint8_t vred;
uint8_t flags;
} __packed;
BUILD_ASSERT(sizeof(struct uc81xx_ptl8) == 5);
struct uc81xx_tres16 {
uint16_t hres;
uint16_t vres;
} __packed;
BUILD_ASSERT(sizeof(struct uc81xx_tres16) == 4);
struct uc81xx_ptl16 {
uint16_t hrst;
uint16_t hred;
uint16_t vrst;
uint16_t vred;
uint8_t flags;
} __packed;
BUILD_ASSERT(sizeof(struct uc81xx_ptl16) == 9);
#define UC81XX_PTL_FLAG_PT_SCAN BIT(0)
/* Time constants in ms */
#define UC81XX_RESET_DELAY 10U
#define UC81XX_PON_DELAY 100U
#define UC81XX_BUSY_DELAY 1U
#endif /* ZEPHYR_DRIVERS_DISPLAY_UC81XX_REGS_H_ */