2021-03-15 14:59:29 +01:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2018 Koen Zandberg
|
|
|
|
* 2021 Francisco Molina
|
2023-07-09 11:58:20 +02:00
|
|
|
* 2023 Gunar Schorcht
|
2021-03-15 14:59:29 +01:00
|
|
|
*
|
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
|
|
* directory for more details.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
2023-07-14 00:14:24 +02:00
|
|
|
* @ingroup drivers_st77xx
|
2021-03-15 14:59:29 +01:00
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
2023-07-14 00:14:24 +02:00
|
|
|
* @brief Device driver implementation for the ST77xx display controller
|
2021-03-15 14:59:29 +01:00
|
|
|
*
|
|
|
|
* @author Koen Zandberg <koen@bergzand.net>
|
|
|
|
* @author Francisco Molina <francois-xavier.molina@inria.fr>
|
2023-07-09 11:58:20 +02:00
|
|
|
* @author Gunar Schorcht <gunar@schorcht.net>
|
2021-03-15 14:59:29 +01:00
|
|
|
*
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <assert.h>
|
|
|
|
#include <string.h>
|
2023-07-09 11:58:20 +02:00
|
|
|
|
2021-03-15 14:59:29 +01:00
|
|
|
#include "byteorder.h"
|
|
|
|
#include "kernel_defines.h"
|
2023-07-09 11:58:20 +02:00
|
|
|
#include "ztimer.h"
|
|
|
|
|
2023-07-14 00:14:24 +02:00
|
|
|
#include "st77xx.h"
|
|
|
|
#include "st77xx_internal.h"
|
2023-07-14 00:26:36 +02:00
|
|
|
#include "st7735_internal.h"
|
|
|
|
#include "st7789_internal.h"
|
|
|
|
#include "st7796_internal.h"
|
|
|
|
|
2021-03-15 14:59:29 +01:00
|
|
|
#include "lcd.h"
|
|
|
|
#include "lcd_internal.h"
|
|
|
|
|
|
|
|
#define ENABLE_DEBUG 0
|
|
|
|
#include "debug.h"
|
|
|
|
|
|
|
|
static int _init(lcd_t *dev, const lcd_params_t *params)
|
|
|
|
{
|
2023-07-14 00:26:36 +02:00
|
|
|
uint8_t command_params[1] = { 0 };
|
2021-03-15 14:59:29 +01:00
|
|
|
|
2023-07-09 11:58:20 +02:00
|
|
|
/* Acquire once and release at the end */
|
|
|
|
lcd_ll_acquire(dev);
|
2021-03-15 14:59:29 +01:00
|
|
|
|
2023-07-14 00:26:36 +02:00
|
|
|
/* Soft Reset (requires 120 ms if in Sleep In mode), default display off */
|
2023-07-09 11:58:20 +02:00
|
|
|
lcd_ll_write_cmd(dev, LCD_CMD_SWRESET, NULL, 0);
|
2021-03-15 14:59:29 +01:00
|
|
|
ztimer_sleep(ZTIMER_MSEC, 120);
|
|
|
|
|
2023-07-14 00:26:36 +02:00
|
|
|
/* Sleep Out command to leave Sleep In state after reset, requires 120 ms */
|
|
|
|
lcd_ll_write_cmd(dev, LCD_CMD_SLPOUT, NULL, 0);
|
|
|
|
ztimer_sleep(ZTIMER_MSEC, 120);
|
2021-03-15 14:59:29 +01:00
|
|
|
|
2023-07-14 00:26:36 +02:00
|
|
|
/* COLMOD (3Ah): Interface Pixel Format */
|
|
|
|
command_params[0] = 0x55; /* 16 bit mode RGB & Control */
|
|
|
|
lcd_ll_write_cmd(dev, LCD_CMD_COLMOD, command_params, 1);
|
2021-03-15 14:59:29 +01:00
|
|
|
|
2023-07-14 00:26:36 +02:00
|
|
|
/* controller specific initialization part called */
|
|
|
|
if (IS_USED(MODULE_ST7735) && (params->cntrl == ST77XX_CNTRL_ST7735)) {
|
|
|
|
DEBUG("ST7735 used ...\n");
|
|
|
|
st7735_init(dev, params);
|
|
|
|
}
|
|
|
|
else if (IS_USED(MODULE_ST7789) && (params->cntrl == ST77XX_CNTRL_ST7789)) {
|
|
|
|
DEBUG("ST7789 used ...\n");
|
|
|
|
st7789_init(dev, params);
|
|
|
|
}
|
2023-09-20 07:40:33 +02:00
|
|
|
else if (IS_USED(MODULE_ST7796) && (params->cntrl == ST77XX_CNTRL_ST7796)) {
|
|
|
|
DEBUG("ST7796 used ...\n");
|
|
|
|
st7796_init(dev, params);
|
2023-07-14 00:26:36 +02:00
|
|
|
}
|
2021-03-15 14:59:29 +01:00
|
|
|
|
2023-07-14 00:26:36 +02:00
|
|
|
#if 0 /* no need to write reset defaults, just for documentation purpose */
|
2021-03-15 14:59:29 +01:00
|
|
|
|
2023-07-14 00:26:36 +02:00
|
|
|
/* GAMSET (26h): Gamma Set (== reset defaults) */
|
2021-03-15 14:59:29 +01:00
|
|
|
command_params[0] = 0x01;
|
2023-07-09 11:58:20 +02:00
|
|
|
lcd_ll_write_cmd(dev, LCD_CMD_GAMSET, command_params, 1);
|
2021-03-15 14:59:29 +01:00
|
|
|
|
2023-07-14 00:26:36 +02:00
|
|
|
/* TEON (35h): Tearing Effect Line ON (== reset defaults) */
|
|
|
|
command_params[0] = 0x00; /* TEM=0 (only V-Blanking) */
|
|
|
|
lcd_ll_write_cmd(dev, LCD_CMD_VCOMS, command_params, 1);
|
|
|
|
|
|
|
|
#endif /* no need to write reset defaults, just for documentation purpose */
|
2021-03-15 14:59:29 +01:00
|
|
|
|
2023-07-14 00:26:36 +02:00
|
|
|
/* MADCTL (36h): Memory Data Access Control */
|
|
|
|
command_params[0] = dev->params->rotation;
|
|
|
|
command_params[0] |= dev->params->rgb ? 0 : LCD_MADCTL_BGR;
|
|
|
|
lcd_ll_write_cmd(dev, LCD_CMD_MADCTL, command_params, 1);
|
|
|
|
|
|
|
|
/* enable Inversion if configured, reset default is off */
|
2021-03-15 14:59:29 +01:00
|
|
|
if (dev->params->inverted) {
|
2023-07-14 00:26:36 +02:00
|
|
|
/* INVON (21h): Display Inversion On */
|
2023-07-09 11:58:20 +02:00
|
|
|
lcd_ll_write_cmd(dev, LCD_CMD_DINVON, NULL, 0);
|
2021-03-15 14:59:29 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/* Normal display mode on */
|
2023-07-09 11:58:20 +02:00
|
|
|
lcd_ll_write_cmd(dev, LCD_CMD_NORON, NULL, 0);
|
2021-03-15 14:59:29 +01:00
|
|
|
ztimer_sleep(ZTIMER_MSEC, 1);
|
|
|
|
|
|
|
|
/* Display on */
|
2023-07-09 11:58:20 +02:00
|
|
|
lcd_ll_write_cmd(dev, LCD_CMD_DISPON, NULL, 0);
|
|
|
|
|
|
|
|
/* Finally release the device */
|
|
|
|
lcd_ll_release(dev);
|
2021-03-15 14:59:29 +01:00
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2023-07-14 00:14:24 +02:00
|
|
|
const lcd_driver_t lcd_st77xx_driver = {
|
2021-03-15 14:59:29 +01:00
|
|
|
.init = _init,
|
2023-07-10 12:12:10 +02:00
|
|
|
.set_area = NULL, /* default implementation is used */
|
2021-03-15 14:59:29 +01:00
|
|
|
};
|