114 lines
2.9 KiB
C
114 lines
2.9 KiB
C
/* SPDX-License-Identifier: GPL-2.0-or-later */
|
|
/*
|
|
* ST stm32 Chrom-Art - 2D Graphics Accelerator Driver
|
|
*
|
|
* Copyright (c) 2021 Dillon Min
|
|
* Dillon Min, <dillon.minfei@gmail.com>
|
|
*
|
|
* based on s5p-g2d
|
|
*
|
|
* Copyright (c) 2011 Samsung Electronics Co., Ltd.
|
|
* Kamil Debski, <k.debski@samsung.com>
|
|
*/
|
|
|
|
#ifndef __DMA2D_REGS_H__
|
|
#define __DMA2D_REGS_H__
|
|
|
|
#define DMA2D_CR_REG 0x0000
|
|
#define CR_MODE_MASK GENMASK(17, 16)
|
|
#define CR_MODE_SHIFT 16
|
|
#define CR_M2M 0x0000
|
|
#define CR_M2M_PFC BIT(16)
|
|
#define CR_M2M_BLEND BIT(17)
|
|
#define CR_R2M (BIT(17) | BIT(16))
|
|
#define CR_CEIE BIT(13)
|
|
#define CR_CTCIE BIT(12)
|
|
#define CR_CAEIE BIT(11)
|
|
#define CR_TWIE BIT(10)
|
|
#define CR_TCIE BIT(9)
|
|
#define CR_TEIE BIT(8)
|
|
#define CR_ABORT BIT(2)
|
|
#define CR_SUSP BIT(1)
|
|
#define CR_START BIT(0)
|
|
|
|
#define DMA2D_ISR_REG 0x0004
|
|
#define ISR_CEIF BIT(5)
|
|
#define ISR_CTCIF BIT(4)
|
|
#define ISR_CAEIF BIT(3)
|
|
#define ISR_TWIF BIT(2)
|
|
#define ISR_TCIF BIT(1)
|
|
#define ISR_TEIF BIT(0)
|
|
|
|
#define DMA2D_IFCR_REG 0x0008
|
|
#define IFCR_CCEIF BIT(5)
|
|
#define IFCR_CCTCIF BIT(4)
|
|
#define IFCR_CAECIF BIT(3)
|
|
#define IFCR_CTWIF BIT(2)
|
|
#define IFCR_CTCIF BIT(1)
|
|
#define IFCR_CTEIF BIT(0)
|
|
|
|
#define DMA2D_FGMAR_REG 0x000c
|
|
#define DMA2D_FGOR_REG 0x0010
|
|
#define FGOR_LO_MASK GENMASK(13, 0)
|
|
|
|
#define DMA2D_BGMAR_REG 0x0014
|
|
#define DMA2D_BGOR_REG 0x0018
|
|
#define BGOR_LO_MASK GENMASK(13, 0)
|
|
|
|
#define DMA2D_FGPFCCR_REG 0x001c
|
|
#define FGPFCCR_ALPHA_MASK GENMASK(31, 24)
|
|
#define FGPFCCR_AM_MASK GENMASK(17, 16)
|
|
#define FGPFCCR_CS_MASK GENMASK(15, 8)
|
|
#define FGPFCCR_START BIT(5)
|
|
#define FGPFCCR_CCM_RGB888 BIT(4)
|
|
#define FGPFCCR_CM_MASK GENMASK(3, 0)
|
|
|
|
#define DMA2D_FGCOLR_REG 0x0020
|
|
#define FGCOLR_REG_MASK GENMASK(23, 16)
|
|
#define FGCOLR_GREEN_MASK GENMASK(15, 8)
|
|
#define FGCOLR_BLUE_MASK GENMASK(7, 0)
|
|
|
|
#define DMA2D_BGPFCCR_REG 0x0024
|
|
#define BGPFCCR_ALPHA_MASK GENMASK(31, 24)
|
|
#define BGPFCCR_AM_MASK GENMASK(17, 16)
|
|
#define BGPFCCR_CS_MASK GENMASK(15, 8)
|
|
#define BGPFCCR_START BIT(5)
|
|
#define BGPFCCR_CCM_RGB888 BIT(4)
|
|
#define BGPFCCR_CM_MASK GENMASK(3, 0)
|
|
|
|
#define DMA2D_BGCOLR_REG 0x0028
|
|
#define BGCOLR_REG_MASK GENMASK(23, 16)
|
|
#define BGCOLR_GREEN_MASK GENMASK(15, 8)
|
|
#define BGCOLR_BLUE_MASK GENMASK(7, 0)
|
|
|
|
#define DMA2D_OPFCCR_REG 0x0034
|
|
#define OPFCCR_CM_MASK GENMASK(2, 0)
|
|
|
|
#define DMA2D_OCOLR_REG 0x0038
|
|
#define OCOLR_ALPHA_MASK GENMASK(31, 24)
|
|
#define OCOLR_RED_MASK GENMASK(23, 16)
|
|
#define OCOLR_GREEN_MASK GENMASK(15, 8)
|
|
#define OCOLR_BLUE_MASK GENMASK(7, 0)
|
|
|
|
#define DMA2D_OMAR_REG 0x003c
|
|
|
|
#define DMA2D_OOR_REG 0x0040
|
|
#define OOR_LO_MASK GENMASK(13, 0)
|
|
|
|
#define DMA2D_NLR_REG 0x0044
|
|
#define NLR_PL_MASK GENMASK(29, 16)
|
|
#define NLR_NL_MASK GENMASK(15, 0)
|
|
|
|
/* Hardware limits */
|
|
#define MAX_WIDTH 2592
|
|
#define MAX_HEIGHT 2592
|
|
|
|
#define DEFAULT_WIDTH 240
|
|
#define DEFAULT_HEIGHT 320
|
|
#define DEFAULT_SIZE 307200
|
|
|
|
#define CM_MODE_ARGB8888 0x00
|
|
#define CM_MODE_ARGB4444 0x04
|
|
#define CM_MODE_A4 0x0a
|
|
#endif /* __DMA2D_REGS_H__ */
|