|  | /* | 
|  | * Copyright (c) 2020 Teslabs Engineering S.L. | 
|  | * Copyright (c) 2021 Krivorot Oleg <krivorot.oleg@gmail.com> | 
|  | * Copyright (c) 2022 Konstantinos Papadopoulos <kostas.papadopulos@gmail.com> | 
|  | * | 
|  | * SPDX-License-Identifier: Apache-2.0 | 
|  | */ | 
|  | #ifndef ZEPHYR_DRIVERS_DISPLAY_DISPLAY_ILI9342C_H_ | 
|  | #define ZEPHYR_DRIVERS_DISPLAY_DISPLAY_ILI9342C_H_ | 
|  |  | 
|  | #include <zephyr/device.h> | 
|  |  | 
|  | /* 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 ili9xxx_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_ */ |