drivers: added support for ili9225 controller
Signed-off-by: Michal Lenc <michallenc@seznam.cz>
This commit is contained in:
parent
1473c12403
commit
cf7cfa682b
@ -958,6 +958,39 @@ config LCD_LPM013M091A
|
||||
Recommended to use DMA to transfer data or displayed image would be
|
||||
broken.
|
||||
|
||||
config LCD_ILI9225
|
||||
bool "ILI9225 LCD Single Chip Driver"
|
||||
default n
|
||||
---help---
|
||||
LCD Single Chip Driver, ILI9225, ILI Technology Corp.
|
||||
|
||||
if LCD_ILI9225
|
||||
config LCD_ILI9225_XRES
|
||||
int "ILI9225 X Resolution"
|
||||
default 176
|
||||
---help---
|
||||
Specifies the X resolution of the LCD.
|
||||
|
||||
config LCD_ILI9225_YRES
|
||||
int "ILI9225 Y Resolution"
|
||||
default 220
|
||||
---help---
|
||||
Specifies the Y resolution of the LCD.
|
||||
|
||||
config LCD_ILI9225_BPP
|
||||
int "Bit Per Pixel (16)"
|
||||
default 16
|
||||
|
||||
config LCD_ILI9225_SPIMODE
|
||||
int "SPI Mode"
|
||||
default 0
|
||||
|
||||
config LCD_ILI9225_FREQUENCY
|
||||
int "SPI Frequency"
|
||||
default 1000000
|
||||
|
||||
endif # LCD_ILI9225
|
||||
|
||||
config LCD_ILI9340
|
||||
bool "ILI9340 LCD Single Chip Driver"
|
||||
default n
|
||||
|
@ -105,6 +105,10 @@ ifeq ($(CONFIG_LCD_SHARP_MEMLCD),y)
|
||||
CSRCS += memlcd.c
|
||||
endif
|
||||
|
||||
ifeq ($(CONFIG_LCD_ILI9225),y)
|
||||
CSRCS += ili9225.c
|
||||
endif
|
||||
|
||||
ifeq ($(CONFIG_LCD_ILI9340),y)
|
||||
CSRCS += ili9340.c
|
||||
endif
|
||||
|
744
drivers/lcd/ili9225.c
Normal file
744
drivers/lcd/ili9225.c
Normal file
@ -0,0 +1,744 @@
|
||||
/****************************************************************************
|
||||
* drivers/lcd/ili9225.c
|
||||
*
|
||||
* 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.
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Included Files
|
||||
****************************************************************************/
|
||||
|
||||
#include <nuttx/config.h>
|
||||
|
||||
#include <sys/types.h>
|
||||
#include <stdint.h>
|
||||
#include <stdbool.h>
|
||||
#include <string.h>
|
||||
#include <errno.h>
|
||||
#include <debug.h>
|
||||
|
||||
#include <nuttx/arch.h>
|
||||
#include <nuttx/spi/spi.h>
|
||||
#include <nuttx/lcd/lcd.h>
|
||||
#include <nuttx/lcd/ili9225.h>
|
||||
|
||||
#ifdef CONFIG_LCD_ILI9225
|
||||
|
||||
/****************************************************************************
|
||||
* Pre-processor Definitions
|
||||
****************************************************************************/
|
||||
|
||||
/* Verify that all configuration requirements have been met */
|
||||
|
||||
#ifndef CONFIG_LCD_ILI9225_SPIMODE
|
||||
# define CONFIG_LCD_ILI9225_SPIMODE SPIDEV_MODE0
|
||||
#endif
|
||||
|
||||
/* SPI frequency */
|
||||
|
||||
#ifndef CONFIG_LCD_ILI9225_FREQUENCY
|
||||
# define CONFIG_LCD_ILI9225_FREQUENCY 1000000
|
||||
#endif
|
||||
|
||||
/* Check contrast selection */
|
||||
|
||||
#if !defined(CONFIG_LCD_MAXCONTRAST)
|
||||
# define CONFIG_LCD_MAXCONTRAST 1
|
||||
#endif
|
||||
|
||||
/* Check power setting */
|
||||
|
||||
#if !defined(CONFIG_LCD_MAXPOWER) || CONFIG_LCD_MAXPOWER < 1
|
||||
# define CONFIG_LCD_MAXPOWER 1
|
||||
#endif
|
||||
|
||||
#if CONFIG_LCD_MAXPOWER > 255
|
||||
# error "CONFIG_LCD_MAXPOWER must be less than 256 to fit in uint8_t"
|
||||
#endif
|
||||
|
||||
/* Check orientation */
|
||||
|
||||
#if defined(CONFIG_LCD_PORTRAIT)
|
||||
# if defined(CONFIG_LCD_LANDSCAPE) || defined(CONFIG_LCD_RLANDSCAPE) ||\
|
||||
defined(CONFIG_LCD_RPORTRAIT)
|
||||
# error "Cannot define both portrait and any other orientations"
|
||||
# endif
|
||||
#elif defined(CONFIG_LCD_RPORTRAIT)
|
||||
# if defined(CONFIG_LCD_LANDSCAPE) || defined(CONFIG_LCD_RLANDSCAPE)
|
||||
# error "Cannot define both rportrait and any other orientations"
|
||||
# endif
|
||||
#elif defined(CONFIG_LCD_LANDSCAPE)
|
||||
# ifdef CONFIG_LCD_RLANDSCAPE
|
||||
# error "Cannot define both landscape and any other orientations"
|
||||
# endif
|
||||
#elif !defined(CONFIG_LCD_RLANDSCAPE)
|
||||
# define CONFIG_LCD_LANDSCAPE 1
|
||||
#endif
|
||||
|
||||
/* Display Resolution */
|
||||
|
||||
#if !defined(CONFIG_LCD_ILI9225_XRES)
|
||||
# define CONFIG_LCD_ILI9225_XRES 176
|
||||
#endif
|
||||
|
||||
#if !defined(CONFIG_LCD_ILI9225_YRES)
|
||||
# define CONFIG_LCD_ILI9225_YRES 220
|
||||
#endif
|
||||
|
||||
#define ILI9225_LUT_SIZE CONFIG_LCD_ILI9225_YRES
|
||||
|
||||
#if defined(CONFIG_LCD_LANDSCAPE) || defined(CONFIG_LCD_RLANDSCAPE)
|
||||
# define ILI9225_XRES CONFIG_LCD_ILI9225_YRES
|
||||
# define ILI9225_YRES CONFIG_LCD_ILI9225_XRES
|
||||
#else
|
||||
# define ILI9225_XRES CONFIG_LCD_ILI9225_XRES
|
||||
# define ILI9225_YRES CONFIG_LCD_ILI9225_YRES
|
||||
#endif
|
||||
|
||||
/* Color depth and format */
|
||||
|
||||
#ifdef CONFIG_LCD_ILI9225_BPP
|
||||
# if (CONFIG_LCD_ILI9225_BPP == 16)
|
||||
# define ILI9225_BPP 16
|
||||
# define ILI9225_COLORFMT FB_FMT_RGB16_565
|
||||
# define ILI9225_BYTESPP 2
|
||||
# else
|
||||
# define ILI9225_BPP 16
|
||||
# define ILI9225_COLORFMT FB_FMT_RGB16_565
|
||||
# define ILI9225_BYTESPP 2
|
||||
# warning "Invalid color depth. Falling back to 16bpp"
|
||||
# endif
|
||||
#endif
|
||||
|
||||
/****************************************************************************
|
||||
* Private Types
|
||||
****************************************************************************/
|
||||
|
||||
/* This structure describes the state of this driver */
|
||||
|
||||
struct ili9225_dev_s
|
||||
{
|
||||
/* Publicly visible device structure */
|
||||
|
||||
struct lcd_dev_s dev;
|
||||
|
||||
/* Private LCD-specific information follows */
|
||||
|
||||
FAR struct spi_dev_s *spi; /* SPI device */
|
||||
uint8_t bpp; /* Selected color depth */
|
||||
uint8_t power; /* Current power setting */
|
||||
|
||||
/* This is working memory allocated by the LCD driver for each LCD device
|
||||
* and for each color plane. This memory will hold one raster line of data.
|
||||
* The size of the allocated run buffer must therefore be at least
|
||||
* (bpp * xres / 8). Actual alignment of the buffer must conform to the
|
||||
* bitwidth of the underlying pixel type.
|
||||
*
|
||||
* If there are multiple planes, they may share the same working buffer
|
||||
* because different planes will not be operate on concurrently. However,
|
||||
* if there are multiple LCD devices, they must each have unique run
|
||||
* buffers.
|
||||
*/
|
||||
|
||||
uint16_t runbuffer[ILI9225_LUT_SIZE];
|
||||
};
|
||||
|
||||
/****************************************************************************
|
||||
* Private Function Protototypes
|
||||
****************************************************************************/
|
||||
|
||||
/* Misc. Helpers */
|
||||
|
||||
static void ili9225_select(FAR struct spi_dev_s *spi, int bits);
|
||||
static void ili9225_deselect(FAR struct spi_dev_s *spi);
|
||||
|
||||
static inline void ili9225_sendcmd(FAR struct ili9225_dev_s *dev,
|
||||
uint16_t cmd);
|
||||
static inline void ili9225_writereg(FAR struct ili9225_dev_s *dev,
|
||||
uint16_t reg, uint16_t data);
|
||||
static void ili9225_display(FAR struct ili9225_dev_s *dev, bool on);
|
||||
static void ili9225_setarea(FAR struct ili9225_dev_s *dev,
|
||||
uint16_t x0, uint16_t y0,
|
||||
uint16_t x1, uint16_t y1);
|
||||
static void ili9225_bpp(FAR struct ili9225_dev_s *dev, int bpp);
|
||||
static void ili9225_wrram(FAR struct ili9225_dev_s *dev,
|
||||
FAR const uint16_t *buff, size_t size);
|
||||
#ifndef CONFIG_LCD_NOGETRUN
|
||||
static void ili9225_rdram(FAR struct ili9225_dev_s *dev,
|
||||
FAR uint16_t *buff, size_t size);
|
||||
#endif
|
||||
static void ili9225_fill(FAR struct ili9225_dev_s *dev, uint16_t color);
|
||||
|
||||
/* LCD Data Transfer Methods */
|
||||
|
||||
static int ili9225_putrun(fb_coord_t row, fb_coord_t col,
|
||||
FAR const uint8_t *buffer, size_t npixels);
|
||||
#ifndef CONFIG_LCD_NOGETRUN
|
||||
static int ili9225_getrun(fb_coord_t row, fb_coord_t col,
|
||||
FAR uint8_t *buffer, size_t npixels);
|
||||
#endif
|
||||
|
||||
/* LCD Configuration */
|
||||
|
||||
static int ili9225_getvideoinfo(FAR struct lcd_dev_s *dev,
|
||||
FAR struct fb_videoinfo_s *vinfo);
|
||||
static int ili9225_getplaneinfo(FAR struct lcd_dev_s *dev,
|
||||
unsigned int planeno,
|
||||
FAR struct lcd_planeinfo_s *pinfo);
|
||||
|
||||
/* LCD Specific Controls */
|
||||
|
||||
static int ili9225_getpower(FAR struct lcd_dev_s *dev);
|
||||
static int ili9225_setpower(FAR struct lcd_dev_s *dev, int power);
|
||||
|
||||
/****************************************************************************
|
||||
* Private Data
|
||||
****************************************************************************/
|
||||
|
||||
static struct ili9225_dev_s g_lcddev;
|
||||
|
||||
/****************************************************************************
|
||||
* Private Functions
|
||||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Name: ili9225_select
|
||||
*
|
||||
* Description:
|
||||
* Select the SPI, locking and re-configuring if necessary
|
||||
*
|
||||
* Input Parameters:
|
||||
* spi - Reference to the SPI driver structure
|
||||
* bits - Number of SPI bits
|
||||
*
|
||||
* Returned Value:
|
||||
* None
|
||||
*
|
||||
* Assumptions:
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
static void ili9225_select(FAR struct spi_dev_s *spi, int bits)
|
||||
{
|
||||
/* Select ILI9225 chip (locking the SPI bus in case there are multiple
|
||||
* devices competing for the SPI bus
|
||||
*/
|
||||
|
||||
SPI_LOCK(spi, true);
|
||||
SPI_SELECT(spi, SPIDEV_DISPLAY(0), true);
|
||||
|
||||
/* Now make sure that the SPI bus is configured for the ILI9225 (it
|
||||
* might have gotten configured for a different device while unlocked)
|
||||
*/
|
||||
|
||||
SPI_SETMODE(spi, CONFIG_LCD_ILI9225_SPIMODE);
|
||||
SPI_SETBITS(spi, bits);
|
||||
SPI_SETFREQUENCY(spi, CONFIG_LCD_ILI9225_FREQUENCY);
|
||||
}
|
||||
|
||||
/****************************************************************************
|
||||
* Name: ili9225_deselect
|
||||
*
|
||||
* Description:
|
||||
* De-select the SPI
|
||||
*
|
||||
* Input Parameters:
|
||||
* spi - Reference to the SPI driver structure
|
||||
*
|
||||
* Returned Value:
|
||||
* None
|
||||
*
|
||||
* Assumptions:
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
static void ili9225_deselect(FAR struct spi_dev_s *spi)
|
||||
{
|
||||
/* De-select ILI9225 chip and relinquish the SPI bus. */
|
||||
|
||||
SPI_SELECT(spi, SPIDEV_DISPLAY(0), false);
|
||||
SPI_LOCK(spi, false);
|
||||
}
|
||||
|
||||
/****************************************************************************
|
||||
* Name: ili9225_sendcmd
|
||||
*
|
||||
* Description:
|
||||
* Write data into register.
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
static inline void ili9225_writereg(FAR struct ili9225_dev_s *dev,
|
||||
uint16_t reg, uint16_t data)
|
||||
{
|
||||
ili9225_select(dev->spi, ILI9225_BYTESPP * 8);
|
||||
SPI_CMDDATA(dev->spi, SPIDEV_DISPLAY(0), true);
|
||||
SPI_SEND(dev->spi, reg);
|
||||
SPI_CMDDATA(dev->spi, SPIDEV_DISPLAY(0), false);
|
||||
SPI_SEND(dev->spi, data);
|
||||
ili9225_deselect(dev->spi);
|
||||
}
|
||||
|
||||
/****************************************************************************
|
||||
* Name: ili9225_sendcmd
|
||||
*
|
||||
* Description:
|
||||
* Send a data to the driver.
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
static inline void ili9225_sendcmd(FAR struct ili9225_dev_s *dev,
|
||||
uint16_t cmd)
|
||||
{
|
||||
ili9225_select(dev->spi, ILI9225_BYTESPP * 8);
|
||||
SPI_CMDDATA(dev->spi, SPIDEV_DISPLAY(0), true);
|
||||
SPI_SEND(dev->spi, cmd);
|
||||
SPI_CMDDATA(dev->spi, SPIDEV_DISPLAY(0), false);
|
||||
ili9225_deselect(dev->spi);
|
||||
}
|
||||
|
||||
/****************************************************************************
|
||||
* Name: ili9225_display
|
||||
*
|
||||
* Description:
|
||||
* Turn on or off the display.
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
static void ili9225_display(FAR struct ili9225_dev_s *dev, bool on)
|
||||
{
|
||||
if (!on)
|
||||
{
|
||||
/* Start turn off sequence */
|
||||
|
||||
ili9225_writereg(dev, ILI9225_DISP_CTRL1, ILI9225_DISP_CTRL1_GON |
|
||||
ILI9225_DISP_CTRL1_D(2));
|
||||
up_mdelay(20);
|
||||
ili9225_writereg(dev, ILI9225_DISP_CTRL1, 0);
|
||||
up_mdelay(20);
|
||||
ili9225_writereg(dev, ILI9225_POWER_CTRL1, ILI9225_POWER_CTRL1_SAP(0));
|
||||
ili9225_writereg(dev, ILI9225_POWER_CTRL2, ~ILI9225_POWER_CTRL2_PON);
|
||||
ili9225_writereg(dev, ILI9225_POWER_CTRL5, 0);
|
||||
}
|
||||
else
|
||||
{
|
||||
/* Turn on sequence and settings */
|
||||
|
||||
ili9225_writereg(dev, ILI9225_POWER_CTRL2, ILI9225_POWER_CTRL2_VC(8) |
|
||||
ILI9225_POWER_CTRL2_VC_EN
|
||||
);
|
||||
ili9225_writereg(dev, ILI9225_POWER_CTRL3, ILI9225_POWER_CTRL3_DC3(1) |
|
||||
ILI9225_POWER_CTRL3_DC2(2) |
|
||||
ILI9225_POWER_CTRL3_DC1(1) |
|
||||
ILI9225_POWER_CTRL3_BT(6)
|
||||
);
|
||||
ili9225_writereg(dev, ILI9225_POWER_CTRL4,
|
||||
ILI9225_POWER_CTRL4_GVD(111)
|
||||
);
|
||||
ili9225_writereg(dev, ILI9225_POWER_CTRL5,
|
||||
ILI9225_POWER_CTRL5_VML(95) |
|
||||
ILI9225_POWER_CTRL5_VCM(9) |
|
||||
ILI9225_POWER_CTRL5_VCOMG
|
||||
);
|
||||
ili9225_writereg(dev, ILI9225_POWER_CTRL1, ILI9225_POWER_CTRL1_SAP(8));
|
||||
ili9225_writereg(dev, ILI9225_POWER_CTRL2, ILI9225_POWER_CTRL2_VC(11) |
|
||||
ILI9225_POWER_CTRL2_VC_EN |
|
||||
ILI9225_POWER_CTRL2_AON |
|
||||
ILI9225_POWER_CTRL2_APON
|
||||
);
|
||||
ili9225_writereg(dev, ILI9225_DRIVER_OUTPUT_CTRL,
|
||||
ILI9225_DRIVER_OUTPUT_CTRL_NL(28) |
|
||||
ILI9225_DRIVER_OUTPUT_CTRL_SS
|
||||
);
|
||||
ili9225_writereg(dev, ILI9225_LCD_DRIVING_CTRL,
|
||||
ILI9225_LCD_DRIVING_CTRL_INV0);
|
||||
ili9225_writereg(dev, ILI9225_ENTRY_MODE, ILI9225_ENTRY_MODE_AM |
|
||||
ILI9225_ENTRY_MODE_ID(3) |
|
||||
ILI9225_ENTRY_MODE_BGR
|
||||
);
|
||||
ili9225_writereg(dev, ILI9225_DISP_CTRL2, ILI9225_DISP_CTRL2_BP(8) |
|
||||
ILI9225_DISP_CTRL2_FP(8)
|
||||
);
|
||||
ili9225_writereg(dev, ILI9225_FRAME_CYCLE_CTRL,
|
||||
ILI9225_FRAME_CYCLE_CTRL_STD(1) |
|
||||
ILI9225_FRAME_CYCLE_CTRL_NO(1)
|
||||
);
|
||||
ili9225_writereg(dev, ILI9225_RGB_DISP_INT_CTRL1,
|
||||
ILI9225_RGB_DISP_INT_CTRL1_RIM(1));
|
||||
ili9225_writereg(dev, ILI9225_OSC_CTRL, ILI9225_OSC_CTRL_EN |
|
||||
ILI9225_OSC_CTRL_FOSC(13)
|
||||
);
|
||||
ili9225_writereg(dev, ILI9225_VCI_REC, ILI9225_VCI_REC_VCIR(2));
|
||||
|
||||
ili9225_writereg(dev, ILI9225_VER_SCROLL_CTRL1,
|
||||
ILI9225_VER_SCROLL_CTRL1_SEA(219)
|
||||
);
|
||||
ili9225_writereg(dev, ILI9225_PART_SCR_DRIV_POS1,
|
||||
ILI9225_PART_SCR_DRIV_POS1_SE(219)
|
||||
);
|
||||
ili9225_writereg(dev, ILI9225_HORIZONTAL_ADDR_END,
|
||||
ILI9225_HORIZONTAL_ADDR_END_HEA(175)
|
||||
);
|
||||
ili9225_writereg(dev, ILI9225_VERTICAL_ADDR_END,
|
||||
ILI9225_VERTICAL_ADDR_END_VEA(219)
|
||||
);
|
||||
|
||||
ili9225_writereg(dev, ILI9225_GAMMA_CTRL2, ILI9225_GAMMA_CTRL2_KP2(8) |
|
||||
ILI9225_GAMMA_CTRL2_KP3(8)
|
||||
);
|
||||
ili9225_writereg(dev, ILI9225_GAMMA_CTRL3,
|
||||
ILI9225_GAMMA_CTRL3_KP4(10) |
|
||||
ILI9225_GAMMA_CTRL3_KP5(8)
|
||||
);
|
||||
ili9225_writereg(dev, ILI9225_GAMMA_CTRL4,
|
||||
ILI9225_GAMMA_CTRL4_RP0(10)
|
||||
);
|
||||
ili9225_writereg(dev, ILI9225_GAMMA_CTRL5, ILI9225_GAMMA_CTRL5_KN0(8) |
|
||||
ILI9225_GAMMA_CTRL5_KN1(10)
|
||||
);
|
||||
ili9225_writereg(dev, ILI9225_GAMMA_CTRL6, ILI9225_GAMMA_CTRL6_KN2(8) |
|
||||
ILI9225_GAMMA_CTRL6_KN3(8)
|
||||
);
|
||||
ili9225_writereg(dev, ILI9225_GAMMA_CTRL8,
|
||||
ILI9225_GAMMA_CTRL8_RN1(10)
|
||||
);
|
||||
ili9225_writereg(dev, ILI9225_GAMMA_CTRL9,
|
||||
ILI9225_GAMMA_CTRL9_VRP0(16) |
|
||||
ILI9225_GAMMA_CTRL9_VRP1(7)
|
||||
);
|
||||
ili9225_writereg(dev, ILI9225_GAMMA_CTRL10,
|
||||
ILI9225_GAMMA_CTRL10_VRN0(10) |
|
||||
ILI9225_GAMMA_CTRL10_VRN1(7)
|
||||
);
|
||||
ili9225_writereg(dev, ILI9225_DISP_CTRL1, ILI9225_DISP_CTRL1_D(2) |
|
||||
ILI9225_DISP_CTRL1_GON
|
||||
);
|
||||
|
||||
ili9225_writereg(dev, ILI9225_DISP_CTRL1, ILI9225_DISP_CTRL1_D(3) |
|
||||
ILI9225_DISP_CTRL1_REV |
|
||||
ILI9225_DISP_CTRL1_GON |
|
||||
ILI9225_DISP_CTRL1_TEMON
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
/****************************************************************************
|
||||
* Name: ili9225_setarea
|
||||
*
|
||||
* Description:
|
||||
* Set the rectangular area for an upcoming read or write from RAM.
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
static void ili9225_setarea(FAR struct ili9225_dev_s *dev,
|
||||
uint16_t x0, uint16_t y0,
|
||||
uint16_t x1, uint16_t y1)
|
||||
{
|
||||
/* Set row address */
|
||||
|
||||
ili9225_writereg(dev, ILI9225_HORIZONTAL_ADDR_START,
|
||||
ILI9225_HORIZONTAL_ADDR_START_HSA(x0));
|
||||
ili9225_writereg(dev, ILI9225_HORIZONTAL_ADDR_END,
|
||||
ILI9225_HORIZONTAL_ADDR_END_HEA(x1));
|
||||
|
||||
/* Set column address */
|
||||
|
||||
ili9225_writereg(dev, ILI9225_VERTICAL_ADDR_START,
|
||||
ILI9225_VERTICAL_ADDR_START_VSA(y0));
|
||||
ili9225_writereg(dev, ILI9225_VERTICAL_ADDR_END,
|
||||
ILI9225_VERTICAL_ADDR_END_VEA(y1));
|
||||
}
|
||||
|
||||
/****************************************************************************
|
||||
* Name: ili9225_bpp
|
||||
*
|
||||
* Description:
|
||||
* Set the color depth of the device.
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
static void ili9225_bpp(FAR struct ili9225_dev_s *dev, int bpp)
|
||||
{
|
||||
if (dev->bpp != bpp)
|
||||
{
|
||||
dev->bpp = bpp;
|
||||
}
|
||||
}
|
||||
|
||||
/****************************************************************************
|
||||
* Name: ili9225_wrram
|
||||
*
|
||||
* Description:
|
||||
* Write to the driver's RAM.
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
static void ili9225_wrram(FAR struct ili9225_dev_s *dev,
|
||||
FAR const uint16_t *buff, size_t size)
|
||||
{
|
||||
ili9225_sendcmd(dev, ILI9225_GRAM_DATA_REG);
|
||||
|
||||
ili9225_select(dev->spi, ILI9225_BYTESPP * 8);
|
||||
SPI_SNDBLOCK(dev->spi, buff, size);
|
||||
ili9225_deselect(dev->spi);
|
||||
}
|
||||
|
||||
/****************************************************************************
|
||||
* Name: ili9225_rdram
|
||||
*
|
||||
* Description:
|
||||
* Read from the driver's RAM.
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
#ifndef CONFIG_LCD_NOGETRUN
|
||||
static void ili9225_rdram(FAR struct ili9225_dev_s *dev,
|
||||
FAR uint16_t *buff, size_t size)
|
||||
{
|
||||
ili9225_sendcmd(dev, ILI9225_GRAM_DATA_REG);
|
||||
|
||||
ili9225_select(dev->spi, ILI9225_BYTESPP * 8);
|
||||
SPI_RECVBLOCK(dev->spi, buff, size);
|
||||
ili9225_deselect(dev->spi);
|
||||
}
|
||||
#endif
|
||||
|
||||
/****************************************************************************
|
||||
* Name: ili9225_fill
|
||||
*
|
||||
* Description:
|
||||
* Fill the display with the specified color.
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
static void ili9225_fill(FAR struct ili9225_dev_s *dev, uint16_t color)
|
||||
{
|
||||
int i;
|
||||
|
||||
ili9225_setarea(dev, 0, 0, ILI9225_XRES - 1, ILI9225_YRES - 1);
|
||||
ili9225_sendcmd(dev, ILI9225_GRAM_DATA_REG);
|
||||
ili9225_select(dev->spi, ILI9225_BYTESPP * 8);
|
||||
for (i = 0; i < ILI9225_XRES * ILI9225_YRES; i++)
|
||||
{
|
||||
SPI_SEND(dev->spi, color);
|
||||
}
|
||||
|
||||
ili9225_deselect(dev->spi);
|
||||
}
|
||||
|
||||
/****************************************************************************
|
||||
* Name: ili9225_putrun
|
||||
*
|
||||
* Description:
|
||||
* This method can be used to write a partial raster line to the LCD:
|
||||
*
|
||||
* row - Starting row to write to (range: 0 <= row < yres)
|
||||
* col - Starting column to write to (range: 0 <= col <= xres-npixels)
|
||||
* buffer - The buffer containing the run to be written to the LCD
|
||||
* npixels - The number of pixels to write to the LCD
|
||||
* (range: 0 < npixels <= xres-col)
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
static int ili9225_putrun(fb_coord_t row, fb_coord_t col,
|
||||
FAR const uint8_t *buffer, size_t npixels)
|
||||
{
|
||||
FAR struct ili9225_dev_s *priv = &g_lcddev;
|
||||
FAR const uint16_t *src = (FAR const uint16_t *)buffer;
|
||||
|
||||
ginfo("row: %d col: %d npixels: %d\n", row, col, npixels);
|
||||
DEBUGASSERT(buffer && ((uintptr_t)buffer & 1) == 0);
|
||||
|
||||
ili9225_setarea(priv, col, row, col + npixels - 1, row);
|
||||
ili9225_wrram(priv, src, npixels);
|
||||
|
||||
return OK;
|
||||
}
|
||||
|
||||
/****************************************************************************
|
||||
* Name: ili9225_getrun
|
||||
*
|
||||
* Description:
|
||||
* This method can be used to read a partial raster line from the LCD:
|
||||
*
|
||||
* row - Starting row to read from (range: 0 <= row < yres)
|
||||
* col - Starting column to read read (range: 0 <= col <= xres-npixels)
|
||||
* buffer - The buffer in which to return the run read from the LCD
|
||||
* npixels - The number of pixels to read from the LCD
|
||||
* (range: 0 < npixels <= xres-col)
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
#ifndef CONFIG_LCD_NOGETRUN
|
||||
static int ili9225_getrun(fb_coord_t row, fb_coord_t col,
|
||||
FAR uint8_t *buffer, size_t npixels)
|
||||
{
|
||||
FAR struct ili9225_dev_s *priv = &g_lcddev;
|
||||
FAR uint16_t *dest = (FAR uint16_t *)buffer;
|
||||
|
||||
ginfo("row: %d col: %d npixels: %d\n", row, col, npixels);
|
||||
DEBUGASSERT(buffer && ((uintptr_t)buffer & 1) == 0);
|
||||
|
||||
ili9225_setarea(priv, col, row, col + npixels - 1, row);
|
||||
ili9225_rdram(priv, dest, npixels);
|
||||
|
||||
return OK;
|
||||
}
|
||||
#endif
|
||||
|
||||
/****************************************************************************
|
||||
* Name: ili9225_getvideoinfo
|
||||
*
|
||||
* Description:
|
||||
* Get information about the LCD video controller configuration.
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
static int ili9225_getvideoinfo(FAR struct lcd_dev_s *dev,
|
||||
FAR struct fb_videoinfo_s *vinfo)
|
||||
{
|
||||
DEBUGASSERT(dev && vinfo);
|
||||
lcdinfo("fmt: %d xres: %d yres: %d nplanes: 1\n",
|
||||
ILI9225_COLORFMT, ILI9225_XRES, ILI9225_YRES);
|
||||
|
||||
vinfo->fmt = ILI9225_COLORFMT; /* Color format: RGB16-565: RRRR RGGG GGGB BBBB */
|
||||
vinfo->xres = ILI9225_XRES; /* Horizontal resolution in pixel columns */
|
||||
vinfo->yres = ILI9225_YRES; /* Vertical resolution in pixel rows */
|
||||
vinfo->nplanes = 1; /* Number of color planes supported */
|
||||
return OK;
|
||||
}
|
||||
|
||||
/****************************************************************************
|
||||
* Name: ili9225_getplaneinfo
|
||||
*
|
||||
* Description:
|
||||
* Get information about the configuration of each LCD color plane.
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
static int ili9225_getplaneinfo(FAR struct lcd_dev_s *dev,
|
||||
unsigned int planeno,
|
||||
FAR struct lcd_planeinfo_s *pinfo)
|
||||
{
|
||||
FAR struct ili9225_dev_s *priv = (FAR struct ili9225_dev_s *)dev;
|
||||
|
||||
DEBUGASSERT(dev && pinfo && planeno == 0);
|
||||
lcdinfo("planeno: %d bpp: %d\n", planeno, ILI9225_BPP);
|
||||
|
||||
pinfo->putrun = ili9225_putrun; /* Put a run into LCD memory */
|
||||
#ifndef CONFIG_LCD_NOGETRUN
|
||||
pinfo->getrun = ili9225_getrun; /* Get a run from LCD memory */
|
||||
#endif
|
||||
pinfo->buffer = (FAR uint8_t *)priv->runbuffer; /* Run scratch buffer */
|
||||
pinfo->bpp = priv->bpp; /* Bits-per-pixel */
|
||||
return OK;
|
||||
}
|
||||
|
||||
/****************************************************************************
|
||||
* Name: ili9225_getpower
|
||||
****************************************************************************/
|
||||
|
||||
static int ili9225_getpower(FAR struct lcd_dev_s *dev)
|
||||
{
|
||||
FAR struct ili9225_dev_s *priv = (FAR struct ili9225_dev_s *)dev;
|
||||
|
||||
lcdinfo("power: %d\n", priv->power);
|
||||
return priv->power;
|
||||
}
|
||||
|
||||
/****************************************************************************
|
||||
* Name: ili9225_setpower
|
||||
****************************************************************************/
|
||||
|
||||
static int ili9225_setpower(FAR struct lcd_dev_s *dev, int power)
|
||||
{
|
||||
FAR struct ili9225_dev_s *priv = (FAR struct ili9225_dev_s *)dev;
|
||||
|
||||
lcdinfo("power: %d\n", power);
|
||||
DEBUGASSERT((unsigned)power <= CONFIG_LCD_MAXPOWER);
|
||||
|
||||
/* Set new power level */
|
||||
|
||||
if (power > 0)
|
||||
{
|
||||
/* Turn on the display */
|
||||
|
||||
ili9225_display(priv, true);
|
||||
|
||||
/* Save the power */
|
||||
|
||||
priv->power = power;
|
||||
}
|
||||
else
|
||||
{
|
||||
/* Turn off the display */
|
||||
|
||||
ili9225_display(priv, false);
|
||||
|
||||
/* Save the power */
|
||||
|
||||
priv->power = 0;
|
||||
}
|
||||
|
||||
return OK;
|
||||
}
|
||||
|
||||
/****************************************************************************
|
||||
* Public Functions
|
||||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Name: ili9225_initialize
|
||||
*
|
||||
* Description:
|
||||
* Initialize the ILI9225 video hardware. The initial state of the
|
||||
* LCD is fully initialized, display memory cleared, and the LCD ready
|
||||
* to use, but with the power setting at 0 (full off == sleep mode).
|
||||
*
|
||||
* Returned Value:
|
||||
*
|
||||
* On success, this function returns a reference to the LCD object for
|
||||
* the specified LCD. NULL is returned on any failure.
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
FAR struct lcd_dev_s *ili9225_lcdinitialize(FAR struct spi_dev_s *spi)
|
||||
{
|
||||
FAR struct ili9225_dev_s *priv = &g_lcddev;
|
||||
|
||||
/* Initialize the driver data structure */
|
||||
|
||||
priv->dev.getvideoinfo = ili9225_getvideoinfo;
|
||||
priv->dev.getplaneinfo = ili9225_getplaneinfo;
|
||||
priv->dev.getpower = ili9225_getpower;
|
||||
priv->dev.setpower = ili9225_setpower;
|
||||
priv->spi = spi;
|
||||
|
||||
/* Init the hardware and clear the display */
|
||||
|
||||
ili9225_display(priv, true);
|
||||
|
||||
ili9225_bpp(priv, ILI9225_BPP);
|
||||
|
||||
/* Set background color */
|
||||
|
||||
ili9225_fill(priv, 0x07ff);
|
||||
|
||||
return &priv->dev;
|
||||
}
|
||||
|
||||
#endif /* CONFIG_LCD_ILI9225 */
|
496
include/nuttx/lcd/ili9225.h
Normal file
496
include/nuttx/lcd/ili9225.h
Normal file
@ -0,0 +1,496 @@
|
||||
/****************************************************************************
|
||||
* include/nuttx/lcd/ili9225.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 __INCLUDE_NUTTX_LCD_ILI9225_H
|
||||
#define __INCLUDE_NUTTX_LCD_ILI9225_H
|
||||
|
||||
/****************************************************************************
|
||||
* Included Files
|
||||
****************************************************************************/
|
||||
|
||||
#include <nuttx/config.h>
|
||||
|
||||
/****************************************************************************
|
||||
* Pre-processor Definitions
|
||||
****************************************************************************/
|
||||
|
||||
/* ILI9225 ID code */
|
||||
|
||||
#define ILI9225_DEVICE_CODE 0x9225
|
||||
|
||||
/* ILI9225 LCD Register Addresses *******************************************/
|
||||
|
||||
#define ILI9225_DEVICE_CODE_REG 0x00 /* Driver Code Register */
|
||||
#define ILI9225_START_OSC_CTRL 0x00 /* Start Oscillator Control */
|
||||
#define ILI9225_DRIVER_OUTPUT_CTRL 0x01 /* Start Oscillator Control */
|
||||
#define ILI9225_LCD_DRIVING_CTRL 0x02 /* LCD Driving Control */
|
||||
#define ILI9225_ENTRY_MODE 0x03 /* Entry Mode */
|
||||
#define ILI9225_DISP_CTRL1 0x07 /* Display Control 1 */
|
||||
#define ILI9225_DISP_CTRL2 0x08 /* Display Control 2 */
|
||||
#define ILI9225_FRAME_CYCLE_CTRL 0x0b /* Frame Cyce Control */
|
||||
#define ILI9225_RGB_DISP_INT_CTRL1 0x0c /* RGB Display Interface Control 1 */
|
||||
#define ILI9225_OSC_CTRL 0x0f /* Oscillator Control */
|
||||
#define ILI9225_POWER_CTRL1 0x10 /* Power Control 1 */
|
||||
#define ILI9225_POWER_CTRL2 0x11 /* Power Control 2 */
|
||||
#define ILI9225_POWER_CTRL3 0x12 /* Power Control 3 */
|
||||
#define ILI9225_POWER_CTRL4 0x13 /* Power Control 4 */
|
||||
#define ILI9225_POWER_CTRL5 0x14 /* Power Control 5 */
|
||||
#define ILI9225_VCI_REC 0x15 /* VCI Recycling */
|
||||
#define ILI9225_HORIZONTAL_GRAM_ADDR_SET 0x20 /* Horizontal GRAM Address Set */
|
||||
#define ILI9225_VERTICAL_GRAM_ADDR_SET 0x21 /* Vertical GRAM Address Set */
|
||||
#define ILI9225_GRAM_DATA_REG 0x22 /* GRAM Data Register */
|
||||
#define ILI9225_SOFT_RESET 0x28 /* Software Reset */
|
||||
#define ILI9225_GATE_SCAN_CTRL 0x30 /* Gate Scan Control */
|
||||
#define ILI9225_VER_SCROLL_CTRL1 0x31 /* Vertical Scroll Control 1 */
|
||||
#define ILI9225_VER_SCROLL_CTRL2 0x32 /* Vertical Scroll Control 2 */
|
||||
#define ILI9225_VER_SCROLL_CTRL3 0x33 /* Vertical Scroll Control 3 */
|
||||
#define ILI9225_PART_SCR_DRIV_POS1 0x34 /* Partial Screen Driving Position 1 */
|
||||
#define ILI9225_PART_SCR_DRIV_POS2 0x35 /* Partial Screen Driving Position 2 */
|
||||
#define ILI9225_HORIZONTAL_ADDR_END 0x36 /* Horizontal Address Start Position */
|
||||
#define ILI9225_HORIZONTAL_ADDR_START 0x37 /* Horizontal Address End Position */
|
||||
#define ILI9225_VERTICAL_ADDR_END 0x38 /* Vertical Address Start Position */
|
||||
#define ILI9225_VERTICAL_ADDR_START 0x39 /* Vertical Address End Position */
|
||||
#define ILI9225_GAMMA_CTRL1 0x50 /* Gamma Control 1 */
|
||||
#define ILI9225_GAMMA_CTRL2 0x51 /* Gamma Control 2 */
|
||||
#define ILI9225_GAMMA_CTRL3 0x52 /* Gamma Control 3 */
|
||||
#define ILI9225_GAMMA_CTRL4 0x53 /* Gamma Control 4 */
|
||||
#define ILI9225_GAMMA_CTRL5 0x54 /* Gamma Control 5 */
|
||||
#define ILI9225_GAMMA_CTRL6 0x55 /* Gamma Control 6 */
|
||||
#define ILI9225_GAMMA_CTRL7 0x56 /* Gamma Control 7 */
|
||||
#define ILI9225_GAMMA_CTRL8 0x57 /* Gamma Control 8 */
|
||||
#define ILI9225_GAMMA_CTRL9 0x58 /* Gamma Control 9 */
|
||||
#define ILI9225_GAMMA_CTRL10 0x59 /* Gamma Control 10 */
|
||||
#define ILI9225_NV_MEM_DATA 0x60 /* NV Memory Data Programming */
|
||||
#define ILI9225_NV_MEM_CTRL 0x61 /* NV Memory Control */
|
||||
#define ILI9225_NV_MEM_STS 0x62 /* NV Memory Status */
|
||||
#define ILI9225_NV_MEM_PROTECTION 0x63 /* NV Memory Protection Key */
|
||||
#define ILI9225_ID_CODE 0x65 /* ID Code */
|
||||
|
||||
/* ILI9225 LCD Register Bit Definitions *************************************/
|
||||
|
||||
/* ILI9225_START_OSC_CTRL, Start Oscillator Control, Offset: 0x00) */
|
||||
|
||||
#define ILI9225_START_OSC_CTRL_EN (1 << 0)
|
||||
|
||||
/* ILI9225_DRIVER_OUTPUT_CTRL, Start Oscillator Control, Offset: 0x01 */
|
||||
|
||||
#define ILI9225_DRIVER_OUTPUT_CTRL_NL_SHIFT (0)
|
||||
#define ILI9225_DRIVER_OUTPUT_CTRL_NL_MASK (0x1f << ILI9225_DRIVER_OUTPUT_CTRL_NL_SHIFT)
|
||||
#define ILI9225_DRIVER_OUTPUT_CTRL_NL(n) (((uint16_t)(n) << ILI9225_DRIVER_OUTPUT_CTRL_NL_SHIFT) & ILI9225_DRIVER_OUTPUT_CTRL_NL_MASK)
|
||||
#define ILI9225_DRIVER_OUTPUT_CTRL_SS (1 << 8) /* Select shift direction of outputs from source */
|
||||
#define ILI9225_DRIVER_OUTPUT_CTRL_GS (1 << 9) /* Select shift direction of outputs from gate */
|
||||
#define ILI9225_DRIVER_OUTPUT_CTRL_SM (1 << 10) /* Set the scan order by the gate driver */
|
||||
#define ILI9225_DRIVER_OUTPUT_CTRL_EPL (1 << 12) /* Inverts the polarity of signals from ENABLE pin */
|
||||
#define ILI9225_DRIVER_OUTPUT_CTRL_DPL (1 << 13) /* Inverts the polarity of signals from DOTCLK pin */
|
||||
#define ILI9225_DRIVER_OUTPUT_CTRL_HSPL (1 << 14) /* Inverts the polarity of signals from HSYNC pin */
|
||||
#define ILI9225_DRIVER_OUTPUT_CTRL_VSPL (1 << 15) /* Inverts the polarity of signals from VSYNC pin */
|
||||
|
||||
/* ILI9225_LCD_DRIVING_CTRL, LCD Driving Control, Offset: 0x02 */
|
||||
|
||||
#define ILI9225_LCD_DRIVING_CTRL_FLD (1 << 0)
|
||||
#define ILI9225_LCD_DRIVING_CTRL_INV0 (1 << 8)
|
||||
#define ILI9225_LCD_DRIVING_CTRL_INV1 (1 << 9)
|
||||
|
||||
/* ILI9225_ENTRY_MODE, Entry Mode, Offset: 0x03 */
|
||||
|
||||
#define ILI9225_ENTRY_MODE_AM (1 << 3) /* Control the GRAM update direction */
|
||||
#define ILI9225_ENTRY_MODE_ID_SHIFT (4) /* Control the address counter */
|
||||
#define ILI9225_ENTRY_MODE_ID_MASK (3 << ILI9225_ENTRY_MODE_ID_SHIFT)
|
||||
#define ILI9225_ENTRY_MODE_ID(n) (((uint16_t)(n) << ILI9225_ENTRY_MODE_ID_SHIFT) & ILI9225_ENTRY_MODE_ID_MASK)
|
||||
#define ILI9225_ENTRY_MODE_MDT_SHIFT (8)
|
||||
#define ILI9225_ENTRY_MODE_MDT_MASK (3 << ILI9225_ENTRY_MODE_MDT_SHIFT)
|
||||
#define ILI9225_ENTRY_MODE_MDT (((uint16_t)(n) << ILI9225_ENTRY_MODE_MDT_SHIFT) & ILI9225_ENTRY_MODE_MDT_MASK)
|
||||
#define ILI9225_ENTRY_MODE_BGR (1 << 12) /* Swap the R and B order of written data */
|
||||
|
||||
/* ILI9225_DISP_CTRL1, Display Control 1, Offset: 0x07 */
|
||||
|
||||
#define ILI9225_DISP_CTRL1_D_SHIFT (0) /* Turn on/off the display panel */
|
||||
#define ILI9225_DISP_CTRL1_D_MASK (3 << ILI9225_DISP_CTRL1_D_SHIFT)
|
||||
#define ILI9225_DISP_CTRL1_D(n) (((uint16_t)(n) << ILI9225_DISP_CTRL1_D_SHIFT) & ILI9225_DISP_CTRL1_D_MASK)
|
||||
#define ILI9225_DISP_CTRL1_REV (1 << 2) /* Invert grayscale levels */
|
||||
#define ILI9225_DISP_CTRL1_CL (1 << 3) /* Select 8-color display mode */
|
||||
#define ILI9225_DISP_CTRL1_GON (1 << 4) /* Set the output leve of gate driver */
|
||||
#define ILI9225_DISP_CTRL1_TEMON (1 << 12) /* Enable the frame flag output signal */
|
||||
|
||||
/* ILI9225_DISP_CTRL2, Display Control 2, Offset: 0x08 */
|
||||
|
||||
#define ILI9225_DISP_CTRL2_BP_SHIFT (0) /* Numbers of lines for Back Porch */
|
||||
#define ILI9225_DISP_CTRL2_BP_MASK (0xf << ILI9225_DISP_CTRL2_BP_SHIFT)
|
||||
#define ILI9225_DISP_CTRL2_BP(n) (((uint16_t)(n) << ILI9225_DISP_CTRL2_BP_SHIFT) & ILI9225_DISP_CTRL2_BP_MASK)
|
||||
#define ILI9225_DISP_CTRL2_FP_SHIFT (8) /* Numbers of lines for Front Porch */
|
||||
#define ILI9225_DISP_CTRL2_FP_MASK (0xf << ILI9225_DISP_CTRL2_FP_SHIFT)
|
||||
#define ILI9225_DISP_CTRL2_FP(n) (((uint16_t)(n) << ILI9225_DISP_CTRL2_FP_SHIFT) & ILI9225_DISP_CTRL2_FP_MASK)
|
||||
|
||||
/* ILI9225_FRAME_CYCLE_CONTROL, Frame Cycle Control, Offset: 0x0b */
|
||||
|
||||
#define ILI9225_FRAME_CYCLE_CTRL_RTN_SHIFT (0) /* Set the clock cycle number */
|
||||
#define ILI9225_FRAME_CYCLE_CTRL_RTN_MASK (0xf << ILI9225_FRAME_CYCLE_CTRL_RTN_SHIFT)
|
||||
#define ILI9225_FRAME_CYCLE_CTRL_RTN(n) (((uint16_t)(n) << ILI9225_FRAME_CYCLE_CTRL_RTN_SHIFT) & ILI9225_FRAME_CYCLE_CTRL_RTN_MASK)
|
||||
#define ILI9225_FRAME_CYCLE_CTRL_STD_SHIFT (8) /* Set delay amount from gate edge */
|
||||
#define ILI9225_FRAME_CYCLE_CTRL_STD_MASK (0xf << ILI9225_FRAME_CYCLE_CTRL_STD_SHIFT)
|
||||
#define ILI9225_FRAME_CYCLE_CTRL_STD(n) (((uint16_t)(n) << ILI9225_FRAME_CYCLE_CTRL_STD_SHIFT) & ILI9225_FRAME_CYCLE_CTRL_STD_MASK)
|
||||
#define ILI9225_FRAME_CYCLE_CTRL_NO_SHIFT (12) /* Set amount of non-everlay for the gate output */
|
||||
#define ILI9225_FRAME_CYCLE_CTRL_NO_MASK (0xf << ILI9225_FRAME_CYCLE_CTRL_NO_SHIFT)
|
||||
#define ILI9225_FRAME_CYCLE_CTRL_NO(n) (((uint16_t)(n) << ILI9225_FRAME_CYCLE_CTRL_NO_SHIFT) & ILI9225_FRAME_CYCLE_CTRL_NO_MASK)
|
||||
|
||||
/* ILI9225_RGB_DISP_INT_CTRL1,
|
||||
* RGB Display Interface Control 1, Offset: 0x0c
|
||||
*/
|
||||
|
||||
#define ILI9225_RGB_DISP_INT_CTRL1_RIM_SHIFT (0) /* Selest the data bus width */
|
||||
#define ILI9225_RGB_DISP_INT_CTRL1_RIM_MASK (3 << ILI9225_RGB_DISP_INT_CTRL1_RIM_SHIFT)
|
||||
#define ILI9225_RGB_DISP_INT_CTRL1_RIM(n) (((uint16_t)(n) << ILI9225_RGB_DISP_INT_CTRL1_RIM_SHIFT) & ILI9225_RGB_DISP_INT_CTRL1_RIM_MASK)
|
||||
#define ILI9225_RGB_DISP_INT_CTRL1_DM (1 << 4) /* Select RGB interface */
|
||||
#define ILI9225_RGB_DISP_INT_CTRL1_RM (1 << 8) /* Select RGB interface acces to GRAM */
|
||||
|
||||
/* ILI9225_OSC_CTRL, Frame Maker Position, Offset: 0x0f */
|
||||
|
||||
#define ILI9225_OSC_CTRL_EN (1 << 0) /* Oscillator on */
|
||||
#define ILI9225_OSC_CTRL_FOSC_SHIFT (8) /* Select OSC frequency */
|
||||
#define ILI9225_OSC_CTRL_FOSC_MASK (0xf << ILI9225_OSC_CTRL_FOSC_SHIFT)
|
||||
#define ILI9225_OSC_CTRL_FOSC(n) (((uint16_t)(n) << ILI9225_OSC_CTRL_FOSC_SHIFT) & ILI9225_OSC_CTRL_FOSC_MASK)
|
||||
|
||||
/* ILI9225_POWER_CTRL1, Power Control 1, Offset: 0x10 */
|
||||
|
||||
#define ILI9225_POWER_CTRL1_STB (1 << 0) /* Enter sleep mode */
|
||||
#define ILI9225_POWER_CTRL1_DSTB (1 << 1) /* Enter deep standby mode */
|
||||
#define ILI9225_POWER_CTRL1_SAP_SHIFT (8) /* Set the driving capability of source driver */
|
||||
#define ILI9225_POWER_CTRL1_SAP_MASK (0xf << ILI9225_POWER_CTRL1_SAP_SHIFT)
|
||||
#define ILI9225_POWER_CTRL1_SAP(n) (((uint16_t)(n) << ILI9225_POWER_CTRL1_SAP_SHIFT) & ILI9225_POWER_CTRL1_SAP_MASK)
|
||||
|
||||
/* ILI9225_POWER_CTRL2, Power Control 2, Offset: 0x11 */
|
||||
|
||||
#define ILI9225_POWER_CTRL2_VC_SHIFT (0) /* Set the VCI1 voltage */
|
||||
#define ILI9225_POWER_CTRL2_VC_MASK (0xf << ILI9225_POWER_CTRL2_VC_SHIFT)
|
||||
#define ILI9225_POWER_CTRL2_VC(n) (((uint16_t)(n) << ILI9225_POWER_CTRL2_VC_SHIFT) & ILI9225_POWER_CTRL2_VC_MASK)
|
||||
#define ILI9225_POWER_CTRL2_VC_EN (1 << 3) /* Enable VCI1 generation amp */
|
||||
#define ILI9225_POWER_CTRL2_AON (1 << 4) /* Operation starting bit for amp */
|
||||
#define ILI9225_POWER_CTRL2_PON (1 << 8) /* Operation starting bit for booster circuit 1 */
|
||||
#define ILI9225_POWER_CTRL2_PON1 (1 << 9) /* Operation starting bit for booster circuit 2 (VGH) */
|
||||
#define ILI9225_POWER_CTRL2_PON2 (1 << 10) /* Operation starting bit for booster circuit 2 (VGL) */
|
||||
#define ILI9225_POWER_CTRL2_PON3 (1 << 11) /* Operation starting bit for booster circout 3 (VCL) */
|
||||
#define ILI9225_POWER_CTRL2_APON (1 << 12) /* Automatic boosting operatio starting bit */
|
||||
|
||||
/* ILI9225_POWER_CTRL3, Power Control 3, Offset: 0x12 */
|
||||
|
||||
#define ILI9225_POWER_CTRL3_DC3_SHIFT (0) /* Operating frequency in circuit 3 */
|
||||
#define ILI9225_POWER_CTRL3_DC3_MASK (0x7 << ILI9225_POWER_CTRL3_DC3_SHIFT)
|
||||
#define ILI9225_POWER_CTRL3_DC3(n) (((uint16_t)(n) << ILI9225_POWER_CTRL3_DC3_SHIFT) & ILI9225_POWER_CTRL3_DC3_MASK)
|
||||
#define ILI9225_POWER_CTRL3_DC2_SHIFT (4) /* Operating frequency in circuit 2 */
|
||||
#define ILI9225_POWER_CTRL3_DC2_MASK (0x7 << ILI9225_POWER_CTRL3_DC2_SHIFT)
|
||||
#define ILI9225_POWER_CTRL3_DC2(n) (((uint16_t)(n) << ILI9225_POWER_CTRL3_DC2_SHIFT) & ILI9225_POWER_CTRL3_DC2_MASK)
|
||||
#define ILI9225_POWER_CTRL3_DC1_SHIFT (8) /* Operating frequency in circuit 1 */
|
||||
#define ILI9225_POWER_CTRL3_DC1_MASK (0x7 << ILI9225_POWER_CTRL3_DC1_SHIFT)
|
||||
#define ILI9225_POWER_CTRL3_DC1(n) (((uint16_t)(n) << ILI9225_POWER_CTRL3_DC1_SHIFT) & ILI9225_POWER_CTRL3_DC1_MASK)
|
||||
#define ILI9225_POWER_CTRL3_BT_SHIFT (12) /* Output factor of step-up circuit */
|
||||
#define ILI9225_POWER_CTRL3_BT_MASK (0x7 << ILI9225_POWER_CTRL3_BT_SHIFT)
|
||||
#define ILI9225_POWER_CTRL3_BT(n) (((uint16_t)(n) << ILI9225_POWER_CTRL3_BT_SHIFT) & ILI9225_POWER_CTRL3_BT_MASK)
|
||||
|
||||
/* ILI9225_POWER_CTRL4, Power Control 4, Offset: 0x13 */
|
||||
|
||||
#define ILI9225_POWER_CTRL4_GVD_SHIFT (0) /* Amplifying factor for the GVGG voltage */
|
||||
#define ILI9225_POWER_CTRL4_GVD_MASK (0x7f << ILI9225_POWER_CTRL4_GVD_SHIFT)
|
||||
#define ILI9225_POWER_CTRL4_GVD(n) (((uint16_t)(n) << ILI9225_POWER_CTRL4_GVD_SHIFT) & ILI9225_POWER_CTRL4_GVD_MASK)
|
||||
|
||||
/* ILI9225_POWER_CTRL5, Power Control 5, Offset: 0x14 */
|
||||
|
||||
#define ILI9225_POWER_CTRL5_VML_SHIFT (0) /* Alternating amplitudes of VCOM at the VCOM drive */
|
||||
#define ILI9225_POWER_CTRL5_VML_MASK (0x7f << ILI9225_POWER_CTRL5_VML_SHIFT)
|
||||
#define ILI9225_POWER_CTRL5_VML(n) (((uint16_t)(n) << ILI9225_POWER_CTRL5_VML_SHIFT) & ILI9225_POWER_CTRL5_VML_MASK)
|
||||
#define ILI9225_POWER_CTRL5_VCM_SHIFT (8) /* Set the VCOMG voltage */
|
||||
#define ILI9225_POWER_CTRL5_VCM_MASK (0x7f << ILI9225_POWER_CTRL5_VCM_SHIFT)
|
||||
#define ILI9225_POWER_CTRL5_VCM(n) (((uint16_t)(n) << ILI9225_POWER_CTRL5_VCM_SHIFT) & ILI9225_POWER_CTRL5_VCM_MASK)
|
||||
#define ILI9225_POWER_CTRL5_VCOMG (1 << 15) /* Fix VCOM signal at AVSS */
|
||||
|
||||
/* ILI9225_VCI_REC, VCI Recycling, Offset: 0x15 */
|
||||
|
||||
#define ILI9225_VCI_REC_VCIR_SHIFT (4) /* Set CVI recycling period */
|
||||
#define ILI9225_VCI_REC_VCIR_MASK (0x7 << ILI9225_VCI_REC_VCIR_SHIFT)
|
||||
#define ILI9225_VCI_REC_VCIR(n) (((uint16_t)(n) << ILI9225_VCI_REC_VCIR_MASK) & ILI9225_VCI_REC_VCIR_SHIFT)
|
||||
|
||||
/* ILI9225_HORIZONTAL_GRAM_ADDR_SET,
|
||||
* Horizontal GRAM Address Set, Offset: 0x20
|
||||
*/
|
||||
|
||||
#define ILI9225_HORIZONTAL_GRAM_ADDR_SET_AD_SHIFT (0) /* Set the initial vaue of adress counter */
|
||||
#define ILI9225_HORIZONTAL_GRAM_ADDR_SET_AD_MASK (0xff << ILI9225_HORIZONTAL_GRAM_ADDR_SET_AD_SHIFT)
|
||||
#define ILI9225_HORIZONTAL_GRAM_ADDR_SET_AD(n) (((uint16_t)(n) << ILI9225_HORIZONTAL_GRAM_ADDR_SET_AD_SHIFT) & ILI9225_HORIZONTAL_GRAM_ADDR_SET_AD_MASK)
|
||||
|
||||
/* ILI9225_VERTICAL_GRAM_ADDR_SET,
|
||||
* Vertical GRAM Address Set, Offset: 0x21
|
||||
*/
|
||||
|
||||
#define ILI9225_VERTICAL_GRAM_ADDR_SET_AD_SHIFT (0) /* Set the initial vaue of adress counter */
|
||||
#define ILI9225_VERTICAL_GRAM_ADDR_SET_AD_MASK (0xff << ILI9225_VERTICAL_GRAM_ADDR_SET_AD_SHIFT)
|
||||
#define ILI9225_VERTICAL_GRAM_ADDR_SET_AD(n) (((uint16_t)(n) << ILI9225_VERTICAL_GRAM_ADDR_SET_AD_SHIFT) & ILI9225_VERTICAL_GRAM_ADDR_SET_AD_MASK)
|
||||
|
||||
/* ILI9225_GRAM_DATA_REG, Read/Write Data from/to GRAM, Offset: 0x22 */
|
||||
|
||||
#define ILI9225_GRAM_DATA_REG_WD_SHIFT (0)
|
||||
#define ILI9225_GRAM_DATA_REG_WD_MASK (0xffff << ILI9225_GRAM_DATA_REGWD_SHIFT)
|
||||
#define ILI9225_GRAM_DATA_REG_WD(n) (((uint16_t)(n) << ILI9225_GRAM_DATA_REG_WD_SHIFT) & ILI9225_GRAM_DATA_REG_WD_MASK)
|
||||
|
||||
#define ILI9225_GRAM_DATA_REG_RD_SHIFT (0)
|
||||
#define ILI9225_GRAM_DATA_REG_RD_MASK (0xffff << ILI9225_GRAM_DATA_REG_RD_SHIFT)
|
||||
#define ILI9225_GRAM_DATA_REG_RD(n) (((uint16_t)(n) << ILI9225_GRAM_DATA_REG_RD_SHIFT) & ILI9225_GRAM_DATA_REG_RD_MASK)
|
||||
|
||||
/* ILI9225_SOFT_RESET, Software Reset, Offset: 0x28 */
|
||||
|
||||
#define ILI9225_SOFT_RESET_CODE_SHIFT (0) /* Soft reset parameter is 0x00CE */
|
||||
#define ILI9225_SOFT_RESET_CODE_MASK (0xffff << ILI9225_SOFT_RESET_CODE_SHIFT)
|
||||
#define ILI9225_SOFT_RESET_CODE(n) (((uint16_t)(n) << ILI9225_SOFT_RESET_CODE_SHIFT) & ILI9225_SOFT_RESET_CODE_MASK)
|
||||
|
||||
/* ILI9225_GATE_SCAN_CTRL, Gate Scan Control, Offset: 0x30 */
|
||||
|
||||
#define ILI9225_GATE_SCAN_CTRL_SCN_SHIFT (0) /* Specify the gate line from which the draver starts scan */
|
||||
#define ILI9225_GATE_SCAN_CTRL_SCN_MASK (0x1f << ILI9225_GATE_SCAN_CTRL_SCN_SHIFT)
|
||||
#define ILI9225_GATE_SCAN_CTRL_SCN(n) (((uint16_t)(n) << ILI9225_GATE_SCAN_CTRL_SCN_SHIFT) & ILI9225_GATE_SCAN_CTRL_SCN_MASK)
|
||||
|
||||
/* ILI9225_VER_SCROLL_CTRL1, Vertical Scroll Control 1, Offset: 0x31 */
|
||||
|
||||
#define ILI9225_VER_SCROLL_CTRL1_SEA_SHIFT (0) /* Specify scroll start address */
|
||||
#define ILI9225_VER_SCROLL_CTRL1_SEA_MASK (0xff << ILI9225_VER_SCROLL_CTRL1_SEA_SHIFT)
|
||||
#define ILI9225_VER_SCROLL_CTRL1_SEA(n) (((uint16_t)(n) << ILI9225_VER_SCROLL_CTRL1_SEA_SHIFT) & ILI9225_VER_SCROLL_CTRL1_SEA_MASK)
|
||||
|
||||
/* ILI9225_VER_SCROLL_CTRL2, Vertical Scroll Control 2, Offset: 0x32 */
|
||||
|
||||
#define ILI9225_VER_SCROLL_CTRL2_SSA_SHIFT (0) /* Specify scroll end address */
|
||||
#define ILI9225_VER_SCROLL_CTRL2_SSA_MASK (0xff << ILI9225_VER_SCROLL_CTRL2_SSA_SHIFT)
|
||||
#define ILI9225_VER_SCROLL_CTRL2_SSA(n) (((uint16_t)(n) << ILI9225_VER_SCROLL_CTRL2_SSA_SHIFT) & ILI9225_VER_SCROLL_CTRL2_SSA_MASK)
|
||||
|
||||
/* ILI9225_VER_SCROLL_CTRL3, Vertical Scroll Control 3, Offset: 0x33 */
|
||||
|
||||
#define ILI9225_VER_SCROLL_CTRL3_SST_SHIFT (0) /* Specify scroll start and step */
|
||||
#define ILI9225_VER_SCROLL_CTRL3_SST_MASK (0xff << ILI9225_VER_SCROLL_CTRL3_SST_SHIFT)
|
||||
#define ILI9225_VER_SCROLL_CTRL3_SST(n) (((uint16_t)(n) << ILI9225_VER_SCROLL_CTRL3_SST_SHIFT) & ILI9225_VER_SCROLL_CTRL3_SST_MASK)
|
||||
|
||||
/* ILI9225_PART_SCR_DRIV_POS1, Partial Screen Driving Position 1,
|
||||
* Offset: 0x34
|
||||
*/
|
||||
|
||||
#define ILI9225_PART_SCR_DRIV_POS1_SE_SHIFT (0) /* Specify the driving end position for the screen */
|
||||
#define ILI9225_PART_SCR_DRIV_POS1_SE_MASK (0xff << ILI9225_PART_SCR_DRIV_POS1_SE_SHIFT)
|
||||
#define ILI9225_PART_SCR_DRIV_POS1_SE(n) (((uint16_t)(n) << ILI9225_PART_SCR_DRIV_POS1_SE_SHIFT) & ILI9225_PART_SCR_DRIV_POS1_SE_MASK)
|
||||
|
||||
/* ILI9225_PART_SCR_DRIV_POS2, Partial Screen Driving Position 2,
|
||||
* Offset: 0x35
|
||||
*/
|
||||
|
||||
#define ILI9225_PART_SCR_DRIV_POS2_SS_SHIFT (0) /* Specify the driving start position for the screen */
|
||||
#define ILI9225_PART_SCR_DRIV_POS2_SS_MASK (0xff << ILI9225_PART_SCR_DRIV_POS2_SS_SHIFT)
|
||||
#define ILI9225_PART_SCR_DRIV_POS2_SS(n) (((uint16_t)(n) << ILI9225_PART_SCR_DRIV_POS2_SS_SHIFT) & ILI9225_PART_SCR_DRIV_POS2_SS_MASK)
|
||||
|
||||
/* ILI9225_HORIZONTAL_ADDR_END,
|
||||
* Horizontal Address End Position, Offset: 0x36
|
||||
*/
|
||||
|
||||
#define ILI9225_HORIZONTAL_ADDR_END_HEA_SHIFT (0) /* End of the window address area in horizontal direction */
|
||||
#define ILI9225_HORIZONTAL_ADDR_END_HEA_MASK (0xff << ILI9225_HORIZONTAL_ADDR_END_HEA_SHIFT)
|
||||
#define ILI9225_HORIZONTAL_ADDR_END_HEA(n) (((uint16_t)(n) << ILI9225_HORIZONTAL_ADDR_END_HEA_SHIFT) & ILI9225_HORIZONTAL_ADDR_END_HEA_MASK)
|
||||
|
||||
/* ILI9225_HORIZONTAL_ADDR_START,
|
||||
* Horizontal Address Start Position, Offset: 0x37
|
||||
*/
|
||||
|
||||
#define ILI9225_HORIZONTAL_ADDR_START_HSA_SHIFT (0) /* Start of the window address area in horizontal direction */
|
||||
#define ILI9225_HORIZONTAL_ADDR_START_HSA_MASK (0xff << ILI9225_HORIZONTAL_ADDR_START_HSA_SHIFT)
|
||||
#define ILI9225_HORIZONTAL_ADDR_START_HSA(n) (((uint16_t)(n) << ILI9225_HORIZONTAL_ADDR_START_HSA_SHIFT) & ILI9225_HORIZONTAL_ADDR_START_HSA_MASK)
|
||||
|
||||
/* ILI9225_VERTICAL_ADDR_END,
|
||||
* Vertical Address End Position, Offset: 0x38
|
||||
*/
|
||||
|
||||
#define ILI9225_VERTICAL_ADDR_END_VEA_SHIFT (0) /* End of the window address area in vertical direction */
|
||||
#define ILI9225_VERTICAL_ADDR_END_VEA_MASK (0xff << ILI9225_VERTICAL_ADDR_END_VEA_SHIFT)
|
||||
#define ILI9225_VERTICAL_ADDR_END_VEA(n) (((uint16_t)(n) << ILI9225_VERTICAL_ADDR_END_VEA_SHIFT) & ILI9225_VERTICAL_ADDR_END_VEA_MASK)
|
||||
|
||||
/* ILI9225_VERTICAL_ADDR_START,
|
||||
* Vertical Address Start Position, Offset: 0x39
|
||||
*/
|
||||
|
||||
#define ILI9225_VERTICAL_ADDR_START_VSA_SHIFT (0) /* Start of the window address area in vertical direction */
|
||||
#define ILI9225_VERTICAL_ADDR_START_VSA_MASK (0xff << ILI9225_VERTICAL_ADDR_START_VSA_SHIFT)
|
||||
#define ILI9225_VERTICAL_ADDR_START_VSA(n) (((uint16_t)(n) << ILI9225_VERTICAL_ADDR_START_VSA_SHIFT) & ILI9225_VERTICAL_ADDR_START_VSA_MASK)
|
||||
|
||||
/* ILI9225_GAMMA_CTRL1, Gamma Control 1, Offset: 0x50 */
|
||||
|
||||
#define ILI9225_GAMMA_CTRL1_KP0_SHIFT (0)
|
||||
#define ILI9225_GAMMA_CTRL1_KP0_MASK (0xf << ILI9225_GAMMA_CTRL1_KP0_SHIFT)
|
||||
#define ILI9225_GAMMA_CTRL1_KP0(n) (((uint16_t)(n) << ILI9225_GAMMA_CTRL1_KP0_SHIFT) & ILI9225_GAMMA_CTRL1_KP0_MASK)
|
||||
#define ILI9225_GAMMA_CTRL1_KP1_SHIFT (8)
|
||||
#define ILI9225_GAMMA_CTRL1_KP1_MASK (0xf << ILI9225_GAMMA_CTRL1_KP1_SHIFT)
|
||||
#define ILI9225_GAMMA_CTRL1_KP1(n) (((uint16_t)(n) << ILI9225_GAMMA_CTRL1_KP1_SHIFT) & ILI9225_GAMMA_CTRL1_KP1_MASK)
|
||||
|
||||
/* ILI9225_GAMMA_CTRL2, Gamma Control 2, Offset: 0x51 */
|
||||
|
||||
#define ILI9225_GAMMA_CTRL2_KP2_SHIFT (0)
|
||||
#define ILI9225_GAMMA_CTRL2_KP2_MASK (0xf << ILI9225_GAMMA_CTRL2_KP2_SHIFT)
|
||||
#define ILI9225_GAMMA_CTRL2_KP2(n) (((uint16_t)(n) << ILI9225_GAMMA_CTRL2_KP2_SHIFT) & ILI9225_GAMMA_CTRL2_KP2_MASK)
|
||||
#define ILI9225_GAMMA_CTRL2_KP3_SHIFT (8)
|
||||
#define ILI9225_GAMMA_CTRL2_KP3_MASK (0xf << ILI9225_GAMMA_CTRL2_KP3_SHIFT)
|
||||
#define ILI9225_GAMMA_CTRL2_KP3(n) (((uint16_t)(n) << ILI9225_GAMMA_CTRL2_KP3_SHIFT) & ILI9225_GAMMA_CTRL2_KP3_MASK)
|
||||
|
||||
/* ILI9225_GAMMA_CTRL3, Gamma Control 3, Offset: 0x52 */
|
||||
|
||||
#define ILI9225_GAMMA_CTRL3_KP4_SHIFT (0)
|
||||
#define ILI9225_GAMMA_CTRL3_KP4_MASK (0xf << ILI9225_GAMMA_CTRL3_KP4_SHIFT)
|
||||
#define ILI9225_GAMMA_CTRL3_KP4(n) (((uint16_t)(n) << ILI9225_GAMMA_CTRL3_KP4_SHIFT) & ILI9225_GAMMA_CTRL3_KP4_MASK)
|
||||
#define ILI9225_GAMMA_CTRL3_KP5_SHIFT (8)
|
||||
#define ILI9225_GAMMA_CTRL3_KP5_MASK (0xf << ILI9225_GAMMA_CTRL3_KP5_SHIFT)
|
||||
#define ILI9225_GAMMA_CTRL3_KP5(n) (((uint16_t)(n) << ILI9225_GAMMA_CTRL3_KP5_SHIFT) & ILI9225_GAMMA_CTRL3_KP5_MASK)
|
||||
|
||||
/* ILI9225_GAMMA_CTRL4, Gamma Control 4, Offset: 0x53 */
|
||||
|
||||
#define ILI9225_GAMMA_CTRL4_RP0_SHIFT (0)
|
||||
#define ILI9225_GAMMA_CTRL4_RP0_MASK (0xf << ILI9225_GAMMA_CTRL4_RP0_SHIFT)
|
||||
#define ILI9225_GAMMA_CTRL4_RP0(n) (((uint16_t)(n) << ILI9225_GAMMA_CTRL4_RP0_SHIFT) & ILI9225_GAMMA_CTRL4_RP0_MASK)
|
||||
#define ILI9225_GAMMA_CTRL4_RP1_SHIFT (8)
|
||||
#define ILI9225_GAMMA_CTRL4_RP1_MASK (0xf << ILI9225_GAMMA_CTRL4_RP1_SHIFT)
|
||||
#define ILI9225_GAMMA_CTRL4_RP1(n) (((uint16_t)(n) << ILI9225_GAMMA_CTRL4_RP1_SHIFT) & ILI9225_GAMMA_CTR4_RP1_MASK)
|
||||
|
||||
/* ILI9225_GAMMA_CTRL5, Gamma Control 5, Offset: 0x54 */
|
||||
|
||||
#define ILI9225_GAMMA_CTRL5_KN0_SHIFT (0)
|
||||
#define ILI9225_GAMMA_CTRL5_KN0_MASK (0xf << ILI9225_GAMMA_CTRL5_KN0_SHIFT)
|
||||
#define ILI9225_GAMMA_CTRL5_KN0(n) (((uint16_t)(n) << ILI9225_GAMMA_CTRL5_KN0_SHIFT) & ILI9225_GAMMA_CTRL5_KN0_MASK)
|
||||
#define ILI9225_GAMMA_CTRL5_KN1_SHIFT (8)
|
||||
#define ILI9225_GAMMA_CTRL5_KN1_MASK (0xf << ILI9225_GAMMA_CTRL5_KN1_SHIFT)
|
||||
#define ILI9225_GAMMA_CTRL5_KN1(n) (((uint16_t)(n) << ILI9225_GAMMA_CTRL5_KN1_SHIFT) & ILI9225_GAMMA_CTRL5_KN1_MASK)
|
||||
|
||||
/* ILI9225_GAMMA_CTRL6, Gamma Control 6, Offset: 0x55 */
|
||||
|
||||
#define ILI9225_GAMMA_CTRL6_KN2_SHIFT (0)
|
||||
#define ILI9225_GAMMA_CTRL6_KN2_MASK (0xf << ILI9225_GAMMA_CTRL6_KN2_SHIFT)
|
||||
#define ILI9225_GAMMA_CTRL6_KN2(n) (((uint16_t)(n) << ILI9225_GAMMA_CTRL6_KN2_SHIFT) & ILI9225_GAMMA_CTRL6_KN2_MASK)
|
||||
#define ILI9225_GAMMA_CTRL6_KN3_SHIFT (8)
|
||||
#define ILI9225_GAMMA_CTRL6_KN3_MASK (0xf << ILI9225_GAMMA_CTRL6_KN3_SHIFT)
|
||||
#define ILI9225_GAMMA_CTRL6_KN3(n) (((uint16_t)(n) << ILI9225_GAMMA_CTRL6_KN3_SHIFT) & ILI9225_GAMMA_CTRL6_KN3_MASK)
|
||||
|
||||
/* ILI9225_GAMMA_CTRL7, Gamma Control 7, Offset: 0x56 */
|
||||
|
||||
#define ILI9225_GAMMA_CTRL7_KN4_SHIFT (0)
|
||||
#define ILI9225_GAMMA_CTRL7_KN4_MASK (0xf << ILI9225_GAMMA_CTRL7_KN4_SHIFT)
|
||||
#define ILI9225_GAMMA_CTRL7_KN4(n) (((uint16_t)(n) << ILI9225_GAMMA_CTRL7_KN4_SHIFT) & ILI9225_GAMMA_CTRL7_KN4_MASK)
|
||||
#define ILI9225_GAMMA_CTRL7_KN5_SHIFT (8)
|
||||
#define ILI9225_GAMMA_CTRL7_KN5_MASK (0xf << ILI9225_GAMMA_CTRL7_KN5_SHIFT)
|
||||
#define ILI9225_GAMMA_CTRL7_KN5(n) (((uint16_t)(n) << ILI9225_GAMMA_CTRL7_KN5_SHIFT) & ILI9225_GAMMA_CTRL7_KN5_MASK)
|
||||
|
||||
/* ILI9225_GAMMA_CTRL8, Gamma Control 8, Offset: 0x57 */
|
||||
|
||||
#define ILI9225_GAMMA_CTRL8_RN0_SHIFT (0)
|
||||
#define ILI9225_GAMMA_CTRL8_RN0_MASK (0xf << ILI9225_GAMMA_CTRL8_RN0_SHIFT)
|
||||
#define ILI9225_GAMMA_CTRL8_RN0(n) (((uint16_t)(n) << ILI9225_GAMMA_CTRL8_RN0_SHIFT) & ILI9225_GAMMA_CTRL8_RN0_MASK)
|
||||
#define ILI9225_GAMMA_CTRL8_RN1_SHIFT (8)
|
||||
#define ILI9225_GAMMA_CTRL8_RN1_MASK (0xf << ILI9225_GAMMA_CTRL8_RN1_SHIFT)
|
||||
#define ILI9225_GAMMA_CTRL8_RN1(n) (((uint16_t)(n) << ILI9225_GAMMA_CTRL8_RN1_SHIFT) & ILI9225_GAMMA_CTRL8_RN1_MASK)
|
||||
|
||||
/* ILI9225_GAMMA_CTR9, Gamma Control 9, Offset: 0x58 */
|
||||
|
||||
#define ILI9225_GAMMA_CTRL9_VRP0_SHIFT (0)
|
||||
#define ILI9225_GAMMA_CTRL9_VRP0_MASK (0x1f << ILI9225_GAMMA_CTRL9_VRP0_SHIFT)
|
||||
#define ILI9225_GAMMA_CTRL9_VRP0(n) (((uint16_t)(n) << ILI9225_GAMMA_CTRL9_VRP0_SHIFT) & ILI9225_GAMMA_CTRL9_VRP0_MASK)
|
||||
#define ILI9225_GAMMA_CTRL9_VRP1_SHIFT (8)
|
||||
#define ILI9225_GAMMA_CTRL9_VRP1_MASK (0x1f << ILI9225_GAMMA_CTRL9_VRP1_SHIFT)
|
||||
#define ILI9225_GAMMA_CTRL9_VRP1(n) (((uint16_t)(n) << ILI9225_GAMMA_CTRL9_VRP1_SHIFT) & ILI9225_GAMMA_CTRL9_VRP1_MASK)
|
||||
|
||||
/* ILI9225_GAMMA_CTR10, Gamma Control 10, Offset: 0x59 */
|
||||
|
||||
#define ILI9225_GAMMA_CTRL10_VRN0_SHIFT (0)
|
||||
#define ILI9225_GAMMA_CTRL10_VRN0_MASK (0x1f << ILI9225_GAMMA_CTRL10_VRN0_SHIFT)
|
||||
#define ILI9225_GAMMA_CTRL10_VRN0(n) (((uint16_t)(n) << ILI9225_GAMMA_CTRL10_VRN0_SHIFT) & ILI9225_GAMMA_CTRL10_VRN0_MASK)
|
||||
#define ILI9225_GAMMA_CTRL10_VRN1_SHIFT (8)
|
||||
#define ILI9225_GAMMA_CTRL10_VRN1_MASK (0x1f << ILI9225_GAMMA_CTRL10_VRN1_SHIFT)
|
||||
#define ILI9225_GAMMA_CTRL10_VRN1(n) (((uint16_t)(n) << ILI9225_GAMMA_CTRL10_VRN1_SHIFT) & ILI9225_GAMMA_CTRL10_VRN1_MASK)
|
||||
|
||||
/* ILI9225_NV_MEM_DATA, NV Memory Data Programming, Offset: 0x60 */
|
||||
|
||||
#define ILI9225_NV_MEM_DATA_VM_SHIFT (0)
|
||||
#define ILI9225_NV_MEM_DATA_VM_MASK (0xff << ILI9225_NV_MEM_DATA_VM_SHIFT)
|
||||
#define ILI9225_NV_MEM_DATA_VM(n) (((uint16_t)(n) << ILI9225_NV_MEM_DATA_VM_SHIFT) & ILI9225_NV_MEM_DATA_VM_MASK)
|
||||
|
||||
/* ILI9225_NV_MEM_CTRL, NV Memory Data Control, Offset: 0x61 */
|
||||
|
||||
#define ILI9225_NV_MEM_CTRL_VCM_PGM_EN (1 << 0)
|
||||
#define ILI9225_NV_MEM_CTRL_ID_PGM_EN (1 << 1)
|
||||
#define ILI9225_NV_MEM_CTRL_VCM_SEL (1 << 8)
|
||||
|
||||
/* ILI9225_NV_MEM_STS, NV Memory Data Status, Offset: 0x62 */
|
||||
|
||||
#define ILI9225_NV_MEM_STS_VCM_SHIFT (0)
|
||||
#define ILI9225_NV_MEM_STS_VCM_MASK (0x7f << ILI9225_NV_MEM_STS_VCM_SHIFT)
|
||||
#define ILI9225_NV_MEM_DATA_VM(n) (((uint16_t)(n) << ILI9225_NV_MEM_STS_VCM_SHIFT) & ILI9225_NV_MEM_STS_VCM_MASK)
|
||||
#define ILI9225_NV_MEM_STS_PGM_CNT_SHIFT (0)
|
||||
#define ILI9225_NV_MEM_STS_PGM_CNT_MASK (0x3 << ILI9225_NV_MEM_STS_PGM_CNT_SHIFT)
|
||||
#define ILI9225_NV_MEM_DATA_PGM_CNT(n) (((uint16_t)(n) << ILI9225_NV_MEM_STS_PGM_CNT_SHIFT) & ILI9225_NV_MEM_STS_PGM_CNT_MASK)
|
||||
|
||||
/* ILI9225_NV_MEM_PROTECTION, NV Memory Protection Key, Offset: 0x63 */
|
||||
|
||||
#define ILI9225_NV_MEM_PROTECTION_KEY_SHIFT (0)
|
||||
#define ILI9225_NV_MEM_PROTECTION_KEY_MASK (0xffff << ILI9225_NV_MEM_PROTECTION_KEY_SHIFT)
|
||||
#define ILI9225_NV_MEM_PROTECTION_KEY(n) (((uint16_t)(n) << ILI9225_NV_MEM_PROTECTION_KEY_SHIFT) & ILI9225_NV_MEM_PROTECTION_KEY_MASK)
|
||||
|
||||
/* ILI9225_ID_CODE, ID Code, Offset: 0x65 */
|
||||
|
||||
#define ILI9225_ID_CODE_ID_SHIFT (0)
|
||||
#define ILI9225_ID_CODE_ID_MASK (0xffff << ILI9225_ID_CODE_ID_SHIFT)
|
||||
#define ILI9225_ID_CODE_ID(n) (((uint16_t)(n) << ILI9225_ID_CODE_ID_SHIFT) & ILI9225_ID_CODE_ID_MASK)
|
||||
|
||||
/****************************************************************************
|
||||
* Public Types
|
||||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Public Data
|
||||
****************************************************************************/
|
||||
|
||||
#ifdef __cplusplus
|
||||
#define EXTERN extern "C"
|
||||
extern "C"
|
||||
{
|
||||
#else
|
||||
#define EXTERN extern
|
||||
#endif
|
||||
|
||||
/****************************************************************************
|
||||
* Public Function Prototypes
|
||||
****************************************************************************/
|
||||
|
||||
/****************************************************************************
|
||||
* Name: ili9225_initialize
|
||||
*
|
||||
* Description:
|
||||
* Initialize the LCD video driver internal structure. Also initialize the
|
||||
* lcd hardware if not done.
|
||||
*
|
||||
* Returned Value:
|
||||
*
|
||||
* On success, this function returns a reference to the LCD driver object
|
||||
* for the specified LCD driver. NULL is returned on any failure.
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
FAR struct lcd_dev_s *ili9225_lcdinitialize(FAR struct spi_dev_s *spi);
|
||||
|
||||
#undef EXTERN
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif /* __INCLUDE_NUTTX_LCD_ILI9225_H */
|
Loading…
x
Reference in New Issue
Block a user