* drivers/lcd/ra8875.h
*
* SPDX-License-Identifier: BSD-3-Clause
* SPDX-FileCopyrightText: 2015 Intuitive Aerial AB. All rights reserved.
* SPDX-FileContributor: Marten Svanfeldt <marten@intuitiveaerial.com>
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
*
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in
* the documentation and/or other materials provided with the
* distribution.
* 3. Neither the name NuttX nor the names of its contributors may be
* used to endorse or promote products derived from this software
* without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGE.
*
****************************************************************************/
#ifndef __DRIVERS_LCD_RA8875_H
#define __DRIVERS_LCD_RA8875_H
* Included Files
****************************************************************************/
#include <nuttx/config.h>
#ifdef CONFIG_LCD_RA8875
* Pre-processor Definitions
****************************************************************************/
#define RA8875_PWRR 0x01
#define RA8875_MRWC 0x02
#define RA8875_PCSR 0x04
#define RA8875_SROC 0x05
#define RA8875_SFCLR 0x06
#define RA8875_SYSR 0x10
#define RA8875_GPI 0x12
#define RA8875_GPO 0x13
#define RA8875_HDWR 0x14
#define RA8875_HNDFTR 0x15
#define RA8875_HNDR 0x16
#define RA8875_HSTR 0x17
#define RA8875_HPWR 0x18
#define RA8875_VDHR0 0x19
#define RA8875_VDHR1 0x1A
#define RA8875_VNDR0 0x1B
#define RA8875_VNDR1 0x1C
#define RA8875_VSTR0 0x1D
#define RA8875_VSTR1 0x1E
#define RA8875_VPWR 0x1F
#define RA8875_DPCR 0x20
#define RA8875_HSAW0 0x30
#define RA8875_HSAW1 0x31
#define RA8875_VSAW0 0x32
#define RA8875_VSAW1 0x33
#define RA8875_HEAW0 0x34
#define RA8875_HEAW1 0x35
#define RA8875_VEAW0 0x36
#define RA8875_VEAW1 0x37
#define RA8875_MWCR0 0x40
#define RA8875_MWCR1 0x41
#define RA8875_BTCR 0x44
#define RA8875_MRDC 0x45
#define RA8875_CURH0 0x46
#define RA8875_CURH1 0x47
#define RA8875_CURV0 0x48
#define RA8875_CURV1 0x49
#define RA8875_RCURH0 0x4A
#define RA8875_RCURH1 0x4B
#define RA8875_RCURV0 0x4C
#define RA8875_RCURV1 0x4D
#define RA8875_LTPR0 0x50
#define RA8875_BGCR0 0x60
#define RA8875_BGCR1 0x61
#define RA8875_BGCR2 0x62
#define RA8875_FGCR0 0x63
#define RA8875_FGCR1 0x64
#define RA8875_FGCR2 0x65
#define RA8875_P1CR 0x8A
#define RA8875_P1DCR 0x8B
#define RA8875_MCLR 0x8E
#define RA8875_PLLC1 0x88
#define RA8875_PLLC2 0x89
#define RA8875_DCR 0x90
#define RA8875_DLHSR0 0x91
#define RA8875_DLHSR1 0x92
#define RA8875_DLVSR0 0x93
#define RA8875_DLVSR1 0x94
#define RA8875_DLHER0 0x95
#define RA8875_DLHER1 0x96
#define RA8875_DLVER0 0x97
#define RA8875_DLVER1 0x98
#define RA8875_DCHR0 0x99
#define RA8875_DCHR1 0x9A
#define RA8875_DCVR0 0x9B
#define RA8875_DCVR1 0x9C
#define RA8875_DCRR 0x9D
#define RA8875_DTPH0 0xA9
#define RA8875_DTPH1 0xAA
#define RA8875_DTPV0 0xAB
#define RA8875_DTPV1 0xAC
#define RA8875_PWRR_DISPLAY_OFF (0)
#define RA8875_PWRR_DISPLAY_ON (1<<7)
#define RA8875_PWRR_SLEEP (1<<1)
#define RA8875_PWRR_SWRESET (1<<0)
#define RA8875_PCSR_PCLK_INV (1<<7)
#define RA8875_PCSR_PERIOD_MASK (3)
# define RA8875_PCSR_PERIOD_SYS (0)
# define RA8875_PCSR_PERIOD_2SYS (1)
# define RA8875_PCSR_PERIOD_4SYS (2)
# define RA8875_PCSR_PERIOD_8SYS (3)
#define RA8875_SYSR_COLOR_SHIFT (2)
#define RA8875_SYSR_COLOR_MASK (3<<RA8875_SYSR_COLOR_SHIFT)
# define RA8875_SYSR_COLOR_256 (0<<RA8875_SYSR_COLOR_SHIFT)
# define RA8875_SYSR_COLOR_65K (3<<RA8875_SYSR_COLOR_SHIFT)
#define RA8875_SYSR_MCUIF_MASK (3)
# define RA8875_SYSR_MCUIF_8BIT (0)
# define RA8875_SYSR_MCUIF_16BIT (3)
#define RA8875_HDWR_WIDTH(p) ((p)/8 - 1)
#define RA8875_VDHR0_HEIGHT(p) (((p) - 1)&0xff)
#define RA8875_VDHR1_HEIGHT(p) (((p) - 1)>>8)
#define RA8875_DPCR_LAYERS_ONE (0)
#define RA8875_DPCR_LAYERS_TWO (1<<7)
#define RA8875_DPCR_HSCAN_INC (0)
#define RA8875_DPCR_HSCAN_DEC (1<<3)
#define RA8875_DPCR_VSCAN_INC (0)
#define RA8875_DPCR_VSCAN_DEC (1<<2)
#define RA8875_MWCR0_MODE_GRAPHICS (0)
#define RA8875_MWCR0_MODE_TEXT (1<<7)
#define RA8875_MWCR0_CURSOR_INVISIBLE (0)
#define RA8875_MWCR0_CURSOR_VISIBLE (1<<6)
#define RA8875_MWCR0_CURSOR_NORMAL (0)
#define RA8875_MWCR0_CURSOR_BLINK (1<<5)
#define RA8875_MWCR0_MEMDIR_SHIFT (2)
#define RA8875_MWCR0_MEMDIR_MASK (3<<RA8875_MWCR0_MEMDIR_SHIFT)
# define RA8875_MWCR0_MEMDIR_LEFTRIGHT (0<<RA8875_MWCR0_MEMDIR_SHIFT)
# define RA8875_MWCR0_MEMDIR_RIGHTLEFT (1<<RA8875_MWCR0_MEMDIR_SHIFT)
# define RA8875_MWCR0_MEMDIR_TOPDOWN (2<<RA8875_MWCR0_MEMDIR_SHIFT)
# define RA8875_MWCR0_MEMDIR_DOWNTOP (3<<RA8875_MWCR0_MEMDIR_SHIFT)
#define RA8875_MWCR0_WINC_ENABLE (0)
#define RA8875_MWCR0_WINC_DISABLE (1<<1)
#define RA8875_MWCR0_RINC_ENABLE (0)
#define RA8875_MWCR0_RINC_DISABLE (1<<0)
#define RA8875_MWCR1_LAYER_1 (0)
#define RA8875_MWCR1_LAYER_2 (1)
#define RA8875_MRCD_MEMDIR_SHIFT (0)
#define RA8875_MRCD_MEMDIR_MASK (3<<RA8875_MWCR0_MEMDIR_SHIFT)
# define RA8875_MRCD_MEMDIR_LEFTRIGHT (0<<RA8875_MWCR0_MEMDIR_SHIFT)
# define RA8875_MRCD_MEMDIR_RIGHTLEFT (1<<RA8875_MWCR0_MEMDIR_SHIFT)
# define RA8875_MRCD_MEMDIR_TOPDOWN (2<<RA8875_MWCR0_MEMDIR_SHIFT)
# define RA8875_MRCD_MEMDIR_DOWNTOP (3<<RA8875_MWCR0_MEMDIR_SHIFT)
#define RA8875_LTPR0_MODE_MASK (7)
# define RA8875_LTPR0_MODE_L1 (0)
# define RA8875_LTPR0_MODE_L2 (1)
#define RA8875_P1CR_PWM_DISABLE (0)
#define RA8875_P1CR_PWM_ENABLE (1<<7)
#define RA8875_P1CR_DISABLE_LOW (0)
#define RA8875_P1CR_DISABLE_HIGH (1<<6)
#define RA8875_P1CR_FUNC_PWM (0)
#define RA8875_P1CR_FUNC_FIXED (1<<4)
#define RA8875_P1CR_CSDIV_MASK (0xf)
# define RA8875_P1CR_CSDIV(p) ((p) & 0xf)
#define RA8875_MCLR_CLEAR (1<<7)
#define RA8875_MCLR_FULL (0)
#define RA8875_MCLR_ACTIVE (1<<6)
#define RA8875_PLLC1_PLLDIVM (1<<7)
#define RA8875_PLLC1_PLLDIVN(p) ((p)&0x1f)
#define RA8875_PLLC2_PLLDIVK(p) ((p)&0x7)
#define RA8875_DCR_LINE_START (1<<7)
#define RA8875_DCR_CIRCLE_START (1<<6)
#define RA8875_DCR_NOFILL (0)
#define RA8875_DCR_FILL (1<<5)
#define RA8875_DCR_LINE (0)
#define RA8875_DCR_SQUARE (1<<4)
#define RA8875_DCR_TRIANGLE (1<<0)
#endif
#endif