/* * Copyright (c) 2020 Teslabs Engineering S.L. * Copyright (c) 2021 Krivorot Oleg * Copyright (c) 2022 Konstantinos Papadopoulos * * SPDX-License-Identifier: Apache-2.0 */ #ifndef ZEPHYR_DRIVERS_DISPLAY_DISPLAY_ILI9342C_H_ #define ZEPHYR_DRIVERS_DISPLAY_DISPLAY_ILI9342C_H_ #include /* Commands/registers. */ #define ILI9342C_GAMSET 0x26 #define ILI9342C_IFMODE 0xB0 #define ILI9342C_FRMCTR1 0xB1 #define ILI9342C_INVTR 0xB4 #define ILI9342C_DISCTRL 0xB6 #define ILI9342C_ETMOD 0xB7 #define ILI9342C_PWCTRL1 0xC0 #define ILI9342C_PWCTRL2 0xC1 #define ILI9342C_PWCTRL3 0xC2 #define ILI9342C_VMCTRL1 0xC5 #define ILI9342C_SETEXTC 0xC8 #define ILI9342C_PGAMCTRL 0xE0 #define ILI9342C_NGAMCTRL 0xE1 #define ILI9342C_IFCTL 0xF6 /* Commands/registers length. */ #define ILI9342C_GAMSET_LEN 1U #define ILI9342C_IFMODE_LEN 1U #define ILI9342C_FRMCTR1_LEN 2U #define ILI9342C_INVTR_LEN 1U #define ILI9342C_DISCTRL_LEN 4U #define ILI9342C_ETMOD_LEN 1U #define ILI9342C_PWCTRL1_LEN 2U #define ILI9342C_PWCTRL2_LEN 1U #define ILI9342C_PWCTRL3_LEN 1U #define ILI9342C_VMCTRL1_LEN 1U #define ILI9342C_SETEXTC_LEN 3U #define ILI9342C_PGAMCTRL_LEN 15U #define ILI9342C_NGAMCTRL_LEN 15U #define ILI9342C_IFCTL_LEN 3U /** X resolution (pixels). */ #define ILI9342c_X_RES 320U /** Y resolution (pixels). */ #define ILI9342c_Y_RES 240U /** ILI9342C registers to be initialized. */ struct ili9342c_regs { uint8_t gamset[ILI9342C_GAMSET_LEN]; uint8_t ifmode[ILI9342C_IFMODE_LEN]; uint8_t frmctr1[ILI9342C_FRMCTR1_LEN]; uint8_t invtr[ILI9342C_INVTR_LEN]; uint8_t disctrl[ILI9342C_DISCTRL_LEN]; uint8_t etmod[ILI9342C_ETMOD_LEN]; uint8_t pwctrl1[ILI9342C_PWCTRL1_LEN]; uint8_t pwctrl2[ILI9342C_PWCTRL2_LEN]; uint8_t pwctrl3[ILI9342C_PWCTRL3_LEN]; uint8_t vmctrl1[ILI9342C_VMCTRL1_LEN]; uint8_t setextc[ILI9342C_SETEXTC_LEN]; uint8_t pgamctrl[ILI9342C_PGAMCTRL_LEN]; uint8_t ngamctrl[ILI9342C_NGAMCTRL_LEN]; uint8_t ifctl[ILI9342C_IFCTL_LEN]; }; /* Initializer macro for ILI9342C registers. */ #define ILI9342c_REGS_INIT(n) \ static const struct ili9342c_regs ili9342c_regs_##n = { \ .gamset = DT_PROP(DT_INST(n, ilitek_ili9342c), gamset), \ .ifmode = DT_PROP(DT_INST(n, ilitek_ili9342c), ifmode), \ .frmctr1 = DT_PROP(DT_INST(n, ilitek_ili9342c), frmctr1), \ .invtr = DT_PROP(DT_INST(n, ilitek_ili9342c), invtr), \ .disctrl = DT_PROP(DT_INST(n, ilitek_ili9342c), disctrl), \ .etmod = DT_PROP(DT_INST(n, ilitek_ili9342c), etmod), \ .pwctrl1 = DT_PROP(DT_INST(n, ilitek_ili9342c), pwctrl1), \ .pwctrl2 = DT_PROP(DT_INST(n, ilitek_ili9342c), pwctrl2), \ .pwctrl3 = DT_PROP(DT_INST(n, ilitek_ili9342c), pwctrl3), \ .vmctrl1 = DT_PROP(DT_INST(n, ilitek_ili9342c), vmctrl1), \ .setextc = {0xFF, 0x93, 0x42}, \ .pgamctrl = DT_PROP(DT_INST(n, ilitek_ili9342c), pgamctrl), \ .ngamctrl = DT_PROP(DT_INST(n, ilitek_ili9342c), ngamctrl), \ .ifctl = DT_PROP(DT_INST(n, ilitek_ili9342c), ifctl), \ }; /** * @brief Initialize ILI9342C registers with DT values. * * @param dev ILI9342C device instance * @return 0 on success, errno otherwise. */ int ili9342c_regs_init(const struct device *dev); #endif /* ZEPHYR_DRIVERS_DISPLAY_DISPLAY_ILI9342C_H_ */