xref: /linux/drivers/gpu/drm/arm/display/komeda/d71/d71_regs.h (revision 8dd06ef34b6e2f41b29fbf5fc1663780f2524285)
11f2367a3Sjames qian wang (Arm Technology China) /* SPDX-License-Identifier: GPL-2.0 */
21f2367a3Sjames qian wang (Arm Technology China) /*
31f2367a3Sjames qian wang (Arm Technology China)  * (C) COPYRIGHT 2018 ARM Limited. All rights reserved.
41f2367a3Sjames qian wang (Arm Technology China)  * Author: James.Qian.Wang <james.qian.wang@arm.com>
51f2367a3Sjames qian wang (Arm Technology China)  *
61f2367a3Sjames qian wang (Arm Technology China)  */
71f2367a3Sjames qian wang (Arm Technology China) #ifndef _D71_REG_H_
81f2367a3Sjames qian wang (Arm Technology China) #define _D71_REG_H_
91f2367a3Sjames qian wang (Arm Technology China) 
101f2367a3Sjames qian wang (Arm Technology China) /* Common block registers offset */
111f2367a3Sjames qian wang (Arm Technology China) #define BLK_BLOCK_INFO		0x000
121f2367a3Sjames qian wang (Arm Technology China) #define BLK_PIPELINE_INFO	0x004
132b2510daSLowry Li (Arm Technology China) #define BLK_MAX_LINE_SIZE	0x008
141f2367a3Sjames qian wang (Arm Technology China) #define BLK_VALID_INPUT_ID0	0x020
151f2367a3Sjames qian wang (Arm Technology China) #define BLK_OUTPUT_ID0		0x060
161f2367a3Sjames qian wang (Arm Technology China) #define BLK_INPUT_ID0		0x080
171f2367a3Sjames qian wang (Arm Technology China) #define BLK_IRQ_RAW_STATUS	0x0A0
181f2367a3Sjames qian wang (Arm Technology China) #define BLK_IRQ_CLEAR		0x0A4
191f2367a3Sjames qian wang (Arm Technology China) #define BLK_IRQ_MASK		0x0A8
201f2367a3Sjames qian wang (Arm Technology China) #define BLK_IRQ_STATUS		0x0AC
211f2367a3Sjames qian wang (Arm Technology China) #define BLK_STATUS		0x0B0
221f2367a3Sjames qian wang (Arm Technology China) #define BLK_INFO		0x0C0
231f2367a3Sjames qian wang (Arm Technology China) #define BLK_CONTROL		0x0D0
241f2367a3Sjames qian wang (Arm Technology China) #define BLK_SIZE		0x0D4
251f2367a3Sjames qian wang (Arm Technology China) #define BLK_IN_SIZE		0x0E0
261f2367a3Sjames qian wang (Arm Technology China) 
271f2367a3Sjames qian wang (Arm Technology China) #define BLK_P0_PTR_LOW		0x100
281f2367a3Sjames qian wang (Arm Technology China) #define BLK_P0_PTR_HIGH		0x104
291f2367a3Sjames qian wang (Arm Technology China) #define BLK_P0_STRIDE		0x108
301f2367a3Sjames qian wang (Arm Technology China) #define BLK_P1_PTR_LOW		0x110
311f2367a3Sjames qian wang (Arm Technology China) #define BLK_P1_PTR_HIGH		0x114
321f2367a3Sjames qian wang (Arm Technology China) #define BLK_P1_STRIDE		0x118
331f2367a3Sjames qian wang (Arm Technology China) #define BLK_P2_PTR_LOW		0x120
341f2367a3Sjames qian wang (Arm Technology China) #define BLK_P2_PTR_HIGH		0x124
351f2367a3Sjames qian wang (Arm Technology China) 
361f2367a3Sjames qian wang (Arm Technology China) #define BLOCK_INFO_N_SUBBLKS(x)	((x) & 0x000F)
371f2367a3Sjames qian wang (Arm Technology China) #define BLOCK_INFO_BLK_ID(x)	(((x) & 0x00F0) >> 4)
381f2367a3Sjames qian wang (Arm Technology China) #define BLOCK_INFO_BLK_TYPE(x)	(((x) & 0xFF00) >> 8)
391f2367a3Sjames qian wang (Arm Technology China) #define BLOCK_INFO_INPUT_ID(x)	((x) & 0xFFF0)
401f2367a3Sjames qian wang (Arm Technology China) #define BLOCK_INFO_TYPE_ID(x)	(((x) & 0x0FF0) >> 4)
411f2367a3Sjames qian wang (Arm Technology China) 
421f2367a3Sjames qian wang (Arm Technology China) #define PIPELINE_INFO_N_OUTPUTS(x)	((x) & 0x000F)
431f2367a3Sjames qian wang (Arm Technology China) #define PIPELINE_INFO_N_VALID_INPUTS(x)	(((x) & 0x0F00) >> 8)
441f2367a3Sjames qian wang (Arm Technology China) 
451f2367a3Sjames qian wang (Arm Technology China) /* Common block control register bits */
461f2367a3Sjames qian wang (Arm Technology China) #define BLK_CTRL_EN		BIT(0)
471f2367a3Sjames qian wang (Arm Technology China) /* Common size macro */
481f2367a3Sjames qian wang (Arm Technology China) #define HV_SIZE(h, v)		(((h) & 0x1FFF) + (((v) & 0x1FFF) << 16))
491f2367a3Sjames qian wang (Arm Technology China) #define HV_OFFSET(h, v)		(((h) & 0xFFF) + (((v) & 0xFFF) << 16))
501f2367a3Sjames qian wang (Arm Technology China) #define HV_CROP(h, v)		(((h) & 0xFFF) + (((v) & 0xFFF) << 16))
511f2367a3Sjames qian wang (Arm Technology China) 
521f2367a3Sjames qian wang (Arm Technology China) /* AD_CONTROL register */
531f2367a3Sjames qian wang (Arm Technology China) #define AD_CONTROL		0x160
541f2367a3Sjames qian wang (Arm Technology China) 
551f2367a3Sjames qian wang (Arm Technology China) /* AD_CONTROL register bits */
561f2367a3Sjames qian wang (Arm Technology China) #define AD_AEN			BIT(0)
571f2367a3Sjames qian wang (Arm Technology China) #define AD_YT			BIT(1)
581f2367a3Sjames qian wang (Arm Technology China) #define AD_BS			BIT(2)
591f2367a3Sjames qian wang (Arm Technology China) #define AD_WB			BIT(3)
601f2367a3Sjames qian wang (Arm Technology China) #define AD_TH			BIT(4)
611f2367a3Sjames qian wang (Arm Technology China) 
621f2367a3Sjames qian wang (Arm Technology China) /* Global Control Unit */
631f2367a3Sjames qian wang (Arm Technology China) #define GLB_ARCH_ID		0x000
641f2367a3Sjames qian wang (Arm Technology China) #define GLB_CORE_ID		0x004
651f2367a3Sjames qian wang (Arm Technology China) #define GLB_CORE_INFO		0x008
661f2367a3Sjames qian wang (Arm Technology China) #define GLB_IRQ_STATUS		0x010
671f2367a3Sjames qian wang (Arm Technology China) 
681f2367a3Sjames qian wang (Arm Technology China) #define GCU_CONFIG_VALID0	0x0D4
691f2367a3Sjames qian wang (Arm Technology China) #define GCU_CONFIG_VALID1	0x0D8
701f2367a3Sjames qian wang (Arm Technology China) 
711f2367a3Sjames qian wang (Arm Technology China) /* GCU_CONTROL_BITS */
721f2367a3Sjames qian wang (Arm Technology China) #define GCU_CONTROL_MODE(x)	((x) & 0x7)
731f2367a3Sjames qian wang (Arm Technology China) #define GCU_CONTROL_SRST	BIT(16)
741f2367a3Sjames qian wang (Arm Technology China) 
7517cfcb68Sjames qian wang (Arm Technology China) /* GCU_CONFIGURATION registers */
7617cfcb68Sjames qian wang (Arm Technology China) #define GCU_CONFIGURATION_ID0	0x100
7717cfcb68Sjames qian wang (Arm Technology China) #define GCU_CONFIGURATION_ID1	0x104
7817cfcb68Sjames qian wang (Arm Technology China) 
7917cfcb68Sjames qian wang (Arm Technology China) /* GCU configuration */
8017cfcb68Sjames qian wang (Arm Technology China) #define GCU_MAX_LINE_SIZE(x)	((x) & 0xFFFF)
8117cfcb68Sjames qian wang (Arm Technology China) #define GCU_MAX_NUM_LINES(x)	((x) >> 16)
8217cfcb68Sjames qian wang (Arm Technology China) #define GCU_NUM_RICH_LAYERS(x)	((x) & 0x7)
8317cfcb68Sjames qian wang (Arm Technology China) #define GCU_NUM_PIPELINES(x)	(((x) >> 3) & 0x7)
8417cfcb68Sjames qian wang (Arm Technology China) #define GCU_NUM_SCALERS(x)	(((x) >> 6) & 0x7)
8517cfcb68Sjames qian wang (Arm Technology China) #define GCU_DISPLAY_SPLIT_EN(x)	(((x) >> 16) & 0x1)
8617cfcb68Sjames qian wang (Arm Technology China) #define GCU_DISPLAY_TBU_EN(x)	(((x) >> 17) & 0x1)
8717cfcb68Sjames qian wang (Arm Technology China) 
881f2367a3Sjames qian wang (Arm Technology China) /* GCU opmode */
891f2367a3Sjames qian wang (Arm Technology China) #define INACTIVE_MODE		0
901f2367a3Sjames qian wang (Arm Technology China) #define TBU_CONNECT_MODE	1
911f2367a3Sjames qian wang (Arm Technology China) #define TBU_DISCONNECT_MODE	2
921f2367a3Sjames qian wang (Arm Technology China) #define DO0_ACTIVE_MODE		3
931f2367a3Sjames qian wang (Arm Technology China) #define DO1_ACTIVE_MODE		4
941f2367a3Sjames qian wang (Arm Technology China) #define DO01_ACTIVE_MODE	5
951f2367a3Sjames qian wang (Arm Technology China) 
961f2367a3Sjames qian wang (Arm Technology China) /* GLB_IRQ_STATUS bits */
971f2367a3Sjames qian wang (Arm Technology China) #define GLB_IRQ_STATUS_GCU	BIT(0)
981f2367a3Sjames qian wang (Arm Technology China) #define GLB_IRQ_STATUS_LPU0	BIT(8)
991f2367a3Sjames qian wang (Arm Technology China) #define GLB_IRQ_STATUS_LPU1	BIT(9)
1001f2367a3Sjames qian wang (Arm Technology China) #define GLB_IRQ_STATUS_ATU0	BIT(10)
1011f2367a3Sjames qian wang (Arm Technology China) #define GLB_IRQ_STATUS_ATU1	BIT(11)
1021f2367a3Sjames qian wang (Arm Technology China) #define GLB_IRQ_STATUS_ATU2	BIT(12)
1031f2367a3Sjames qian wang (Arm Technology China) #define GLB_IRQ_STATUS_ATU3	BIT(13)
1041f2367a3Sjames qian wang (Arm Technology China) #define GLB_IRQ_STATUS_CU0	BIT(16)
1051f2367a3Sjames qian wang (Arm Technology China) #define GLB_IRQ_STATUS_CU1	BIT(17)
1061f2367a3Sjames qian wang (Arm Technology China) #define GLB_IRQ_STATUS_DOU0	BIT(24)
1071f2367a3Sjames qian wang (Arm Technology China) #define GLB_IRQ_STATUS_DOU1	BIT(25)
1081f2367a3Sjames qian wang (Arm Technology China) 
1091f2367a3Sjames qian wang (Arm Technology China) #define GLB_IRQ_STATUS_PIPE0	(GLB_IRQ_STATUS_LPU0 |\
1101f2367a3Sjames qian wang (Arm Technology China) 				 GLB_IRQ_STATUS_ATU0 |\
1111f2367a3Sjames qian wang (Arm Technology China) 				 GLB_IRQ_STATUS_ATU1 |\
1121f2367a3Sjames qian wang (Arm Technology China) 				 GLB_IRQ_STATUS_CU0 |\
1131f2367a3Sjames qian wang (Arm Technology China) 				 GLB_IRQ_STATUS_DOU0)
1141f2367a3Sjames qian wang (Arm Technology China) 
1151f2367a3Sjames qian wang (Arm Technology China) #define GLB_IRQ_STATUS_PIPE1	(GLB_IRQ_STATUS_LPU1 |\
1161f2367a3Sjames qian wang (Arm Technology China) 				 GLB_IRQ_STATUS_ATU2 |\
1171f2367a3Sjames qian wang (Arm Technology China) 				 GLB_IRQ_STATUS_ATU3 |\
1181f2367a3Sjames qian wang (Arm Technology China) 				 GLB_IRQ_STATUS_CU1 |\
1191f2367a3Sjames qian wang (Arm Technology China) 				 GLB_IRQ_STATUS_DOU1)
1201f2367a3Sjames qian wang (Arm Technology China) 
1211f2367a3Sjames qian wang (Arm Technology China) #define GLB_IRQ_STATUS_ATU	(GLB_IRQ_STATUS_ATU0 |\
1221f2367a3Sjames qian wang (Arm Technology China) 				 GLB_IRQ_STATUS_ATU1 |\
1231f2367a3Sjames qian wang (Arm Technology China) 				 GLB_IRQ_STATUS_ATU2 |\
1241f2367a3Sjames qian wang (Arm Technology China) 				 GLB_IRQ_STATUS_ATU3)
1251f2367a3Sjames qian wang (Arm Technology China) 
1261f2367a3Sjames qian wang (Arm Technology China) /* GCU_IRQ_BITS */
1271f2367a3Sjames qian wang (Arm Technology China) #define GCU_IRQ_CVAL0		BIT(0)
1281f2367a3Sjames qian wang (Arm Technology China) #define GCU_IRQ_CVAL1		BIT(1)
1291f2367a3Sjames qian wang (Arm Technology China) #define GCU_IRQ_MODE		BIT(4)
1301f2367a3Sjames qian wang (Arm Technology China) #define GCU_IRQ_ERR		BIT(11)
1311f2367a3Sjames qian wang (Arm Technology China) 
1321f2367a3Sjames qian wang (Arm Technology China) /* GCU_STATUS_BITS */
1331f2367a3Sjames qian wang (Arm Technology China) #define GCU_STATUS_MODE(x)	((x) & 0x7)
1341f2367a3Sjames qian wang (Arm Technology China) #define GCU_STATUS_MERR		BIT(4)
1351f2367a3Sjames qian wang (Arm Technology China) #define GCU_STATUS_TCS0		BIT(8)
1361f2367a3Sjames qian wang (Arm Technology China) #define GCU_STATUS_TCS1		BIT(9)
1371f2367a3Sjames qian wang (Arm Technology China) #define GCU_STATUS_ACTIVE	BIT(31)
1381f2367a3Sjames qian wang (Arm Technology China) 
1391f2367a3Sjames qian wang (Arm Technology China) /* GCU_CONFIG_VALIDx BITS */
1401f2367a3Sjames qian wang (Arm Technology China) #define GCU_CONFIG_CVAL		BIT(0)
1411f2367a3Sjames qian wang (Arm Technology China) 
1421f2367a3Sjames qian wang (Arm Technology China) /* PERIPHERAL registers */
1431f2367a3Sjames qian wang (Arm Technology China) #define PERIPH_MAX_LINE_SIZE	BIT(0)
1441f2367a3Sjames qian wang (Arm Technology China) #define PERIPH_NUM_RICH_LAYERS	BIT(4)
1451f2367a3Sjames qian wang (Arm Technology China) #define PERIPH_SPLIT_EN		BIT(8)
1461f2367a3Sjames qian wang (Arm Technology China) #define PERIPH_TBU_EN		BIT(12)
1471f2367a3Sjames qian wang (Arm Technology China) #define PERIPH_AFBC_DMA_EN	BIT(16)
1481f2367a3Sjames qian wang (Arm Technology China) #define PERIPH_CONFIGURATION_ID	0x1D4
1491f2367a3Sjames qian wang (Arm Technology China) 
1501f2367a3Sjames qian wang (Arm Technology China) /* LPU register */
1511f2367a3Sjames qian wang (Arm Technology China) #define LPU_TBU_STATUS		0x0B4
1521f2367a3Sjames qian wang (Arm Technology China) #define LPU_RAXI_CONTROL	0x0D0
1531f2367a3Sjames qian wang (Arm Technology China) #define LPU_WAXI_CONTROL	0x0D4
1541f2367a3Sjames qian wang (Arm Technology China) #define LPU_TBU_CONTROL		0x0D8
1551f2367a3Sjames qian wang (Arm Technology China) 
1561f2367a3Sjames qian wang (Arm Technology China) /* LPU_xAXI_CONTROL_BITS */
1571f2367a3Sjames qian wang (Arm Technology China) #define TO_RAXI_AOUTSTDCAPB(x)	(x)
1581f2367a3Sjames qian wang (Arm Technology China) #define TO_RAXI_BOUTSTDCAPB(x)	((x) << 8)
1591f2367a3Sjames qian wang (Arm Technology China) #define TO_RAXI_BEN(x)		((x) << 15)
1601f2367a3Sjames qian wang (Arm Technology China) #define TO_xAXI_BURSTLEN(x)	((x) << 16)
1611f2367a3Sjames qian wang (Arm Technology China) #define TO_xAXI_AxQOS(x)	((x) << 24)
1621f2367a3Sjames qian wang (Arm Technology China) #define TO_xAXI_ORD(x)		((x) << 31)
1631f2367a3Sjames qian wang (Arm Technology China) #define TO_WAXI_OUTSTDCAPB(x)	(x)
1641f2367a3Sjames qian wang (Arm Technology China) 
1651f2367a3Sjames qian wang (Arm Technology China) #define RAXI_AOUTSTDCAPB_MASK	0x7F
1661f2367a3Sjames qian wang (Arm Technology China) #define RAXI_BOUTSTDCAPB_MASK	0x7F00
1671f2367a3Sjames qian wang (Arm Technology China) #define RAXI_BEN_MASK		BIT(15)
1681f2367a3Sjames qian wang (Arm Technology China) #define xAXI_BURSTLEN_MASK	0x3F0000
1691f2367a3Sjames qian wang (Arm Technology China) #define xAXI_AxQOS_MASK		0xF000000
1701f2367a3Sjames qian wang (Arm Technology China) #define xAXI_ORD_MASK		BIT(31)
1711f2367a3Sjames qian wang (Arm Technology China) #define WAXI_OUTSTDCAPB_MASK	0x3F
1721f2367a3Sjames qian wang (Arm Technology China) 
1731f2367a3Sjames qian wang (Arm Technology China) /* LPU_TBU_CONTROL BITS */
1741f2367a3Sjames qian wang (Arm Technology China) #define TO_TBU_DOUTSTDCAPB(x)	(x)
1751f2367a3Sjames qian wang (Arm Technology China) #define TBU_DOUTSTDCAPB_MASK	0x3F
1761f2367a3Sjames qian wang (Arm Technology China) 
1771f2367a3Sjames qian wang (Arm Technology China) /* LPU_IRQ_BITS */
178*8f902dbdSjames qian wang (Arm Technology China) #define LPU_IRQ_OVR		BIT(9)
1791f2367a3Sjames qian wang (Arm Technology China) #define LPU_IRQ_IBSY		BIT(10)
1801f2367a3Sjames qian wang (Arm Technology China) #define LPU_IRQ_ERR		BIT(11)
1811f2367a3Sjames qian wang (Arm Technology China) #define LPU_IRQ_EOW		BIT(12)
1821f2367a3Sjames qian wang (Arm Technology China) #define LPU_IRQ_PL0		BIT(13)
1831f2367a3Sjames qian wang (Arm Technology China) 
1841f2367a3Sjames qian wang (Arm Technology China) /* LPU_STATUS_BITS */
1851f2367a3Sjames qian wang (Arm Technology China) #define LPU_STATUS_AXIED(x)	((x) & 0xF)
1861f2367a3Sjames qian wang (Arm Technology China) #define LPU_STATUS_AXIE		BIT(4)
1871f2367a3Sjames qian wang (Arm Technology China) #define LPU_STATUS_AXIRP	BIT(5)
1881f2367a3Sjames qian wang (Arm Technology China) #define LPU_STATUS_AXIWP	BIT(6)
189*8f902dbdSjames qian wang (Arm Technology China) #define LPU_STATUS_FEMPTY	BIT(11)
190*8f902dbdSjames qian wang (Arm Technology China) #define LPU_STATUS_FFULL	BIT(14)
1911f2367a3Sjames qian wang (Arm Technology China) #define LPU_STATUS_ACE0		BIT(16)
1921f2367a3Sjames qian wang (Arm Technology China) #define LPU_STATUS_ACE1		BIT(17)
1931f2367a3Sjames qian wang (Arm Technology China) #define LPU_STATUS_ACE2		BIT(18)
1941f2367a3Sjames qian wang (Arm Technology China) #define LPU_STATUS_ACE3		BIT(19)
1951f2367a3Sjames qian wang (Arm Technology China) #define LPU_STATUS_ACTIVE	BIT(31)
1961f2367a3Sjames qian wang (Arm Technology China) 
1971f2367a3Sjames qian wang (Arm Technology China) #define AXIEID_MASK		0xF
1981f2367a3Sjames qian wang (Arm Technology China) #define AXIE_MASK		LPU_STATUS_AXIE
1991f2367a3Sjames qian wang (Arm Technology China) #define AXIRP_MASK		LPU_STATUS_AXIRP
2001f2367a3Sjames qian wang (Arm Technology China) #define AXIWP_MASK		LPU_STATUS_AXIWP
2011f2367a3Sjames qian wang (Arm Technology China) 
2021f2367a3Sjames qian wang (Arm Technology China) #define FROM_AXIEID(reg)	((reg) & AXIEID_MASK)
2031f2367a3Sjames qian wang (Arm Technology China) #define TO_AXIE(x)		((x) << 4)
2041f2367a3Sjames qian wang (Arm Technology China) #define FROM_AXIRP(reg)		(((reg) & AXIRP_MASK) >> 5)
2051f2367a3Sjames qian wang (Arm Technology China) #define FROM_AXIWP(reg)		(((reg) & AXIWP_MASK) >> 6)
2061f2367a3Sjames qian wang (Arm Technology China) 
2071f2367a3Sjames qian wang (Arm Technology China) /* LPU_TBU_STATUS_BITS */
2081f2367a3Sjames qian wang (Arm Technology China) #define LPU_TBU_STATUS_TCF	BIT(1)
2091f2367a3Sjames qian wang (Arm Technology China) #define LPU_TBU_STATUS_TTNG	BIT(2)
2101f2367a3Sjames qian wang (Arm Technology China) #define LPU_TBU_STATUS_TITR	BIT(8)
2111f2367a3Sjames qian wang (Arm Technology China) #define LPU_TBU_STATUS_TEMR	BIT(16)
2121f2367a3Sjames qian wang (Arm Technology China) #define LPU_TBU_STATUS_TTF	BIT(31)
2131f2367a3Sjames qian wang (Arm Technology China) 
2141f2367a3Sjames qian wang (Arm Technology China) /* LPU_TBU_CONTROL BITS */
2151f2367a3Sjames qian wang (Arm Technology China) #define LPU_TBU_CTRL_TLBPEN	BIT(16)
2161f2367a3Sjames qian wang (Arm Technology China) 
2171f2367a3Sjames qian wang (Arm Technology China) /* CROSSBAR CONTROL BITS */
2181f2367a3Sjames qian wang (Arm Technology China) #define CBU_INPUT_CTRL_EN	BIT(0)
2191f2367a3Sjames qian wang (Arm Technology China) #define CBU_NUM_INPUT_IDS	5
2201f2367a3Sjames qian wang (Arm Technology China) #define CBU_NUM_OUTPUT_IDS	5
2211f2367a3Sjames qian wang (Arm Technology China) 
2221f2367a3Sjames qian wang (Arm Technology China) /* CU register */
2231f2367a3Sjames qian wang (Arm Technology China) #define CU_BG_COLOR		0x0DC
2241f2367a3Sjames qian wang (Arm Technology China) #define CU_INPUT0_SIZE		0x0E0
2251f2367a3Sjames qian wang (Arm Technology China) #define CU_INPUT0_OFFSET	0x0E4
2261f2367a3Sjames qian wang (Arm Technology China) #define CU_INPUT0_CONTROL	0x0E8
2271f2367a3Sjames qian wang (Arm Technology China) #define CU_INPUT1_SIZE		0x0F0
2281f2367a3Sjames qian wang (Arm Technology China) #define CU_INPUT1_OFFSET	0x0F4
2291f2367a3Sjames qian wang (Arm Technology China) #define CU_INPUT1_CONTROL	0x0F8
2301f2367a3Sjames qian wang (Arm Technology China) #define CU_INPUT2_SIZE		0x100
2311f2367a3Sjames qian wang (Arm Technology China) #define CU_INPUT2_OFFSET	0x104
2321f2367a3Sjames qian wang (Arm Technology China) #define CU_INPUT2_CONTROL	0x108
2331f2367a3Sjames qian wang (Arm Technology China) #define CU_INPUT3_SIZE		0x110
2341f2367a3Sjames qian wang (Arm Technology China) #define CU_INPUT3_OFFSET	0x114
2351f2367a3Sjames qian wang (Arm Technology China) #define CU_INPUT3_CONTROL	0x118
2361f2367a3Sjames qian wang (Arm Technology China) #define CU_INPUT4_SIZE		0x120
2371f2367a3Sjames qian wang (Arm Technology China) #define CU_INPUT4_OFFSET	0x124
2381f2367a3Sjames qian wang (Arm Technology China) #define CU_INPUT4_CONTROL	0x128
2391f2367a3Sjames qian wang (Arm Technology China) 
2401f2367a3Sjames qian wang (Arm Technology China) #define CU_PER_INPUT_REGS	4
2411f2367a3Sjames qian wang (Arm Technology China) 
2421f2367a3Sjames qian wang (Arm Technology China) #define CU_NUM_INPUT_IDS	5
2431f2367a3Sjames qian wang (Arm Technology China) #define CU_NUM_OUTPUT_IDS	1
2441f2367a3Sjames qian wang (Arm Technology China) 
2451f2367a3Sjames qian wang (Arm Technology China) /* CU control register bits */
2461f2367a3Sjames qian wang (Arm Technology China) #define CU_CTRL_COPROC		BIT(0)
2471f2367a3Sjames qian wang (Arm Technology China) 
2481f2367a3Sjames qian wang (Arm Technology China) /* CU_IRQ_BITS */
2491f2367a3Sjames qian wang (Arm Technology China) #define CU_IRQ_OVR		BIT(9)
2501f2367a3Sjames qian wang (Arm Technology China) #define CU_IRQ_ERR		BIT(11)
2511f2367a3Sjames qian wang (Arm Technology China) 
2521f2367a3Sjames qian wang (Arm Technology China) /* CU_STATUS_BITS */
2531f2367a3Sjames qian wang (Arm Technology China) #define CU_STATUS_CPE		BIT(0)
2541f2367a3Sjames qian wang (Arm Technology China) #define CU_STATUS_ZME		BIT(1)
2551f2367a3Sjames qian wang (Arm Technology China) #define CU_STATUS_CFGE		BIT(2)
2561f2367a3Sjames qian wang (Arm Technology China) #define CU_STATUS_ACTIVE	BIT(31)
2571f2367a3Sjames qian wang (Arm Technology China) 
2581f2367a3Sjames qian wang (Arm Technology China) /* CU input control register bits */
2591f2367a3Sjames qian wang (Arm Technology China) #define CU_INPUT_CTRL_EN	BIT(0)
2601f2367a3Sjames qian wang (Arm Technology China) #define CU_INPUT_CTRL_PAD	BIT(1)
2611f2367a3Sjames qian wang (Arm Technology China) #define CU_INPUT_CTRL_PMUL	BIT(2)
2621f2367a3Sjames qian wang (Arm Technology China) #define CU_INPUT_CTRL_ALPHA(x)	(((x) & 0xFF) << 8)
2631f2367a3Sjames qian wang (Arm Technology China) 
2641f2367a3Sjames qian wang (Arm Technology China) /* DOU register */
2651f2367a3Sjames qian wang (Arm Technology China) 
2661f2367a3Sjames qian wang (Arm Technology China) /* DOU_IRQ_BITS */
2671f2367a3Sjames qian wang (Arm Technology China) #define DOU_IRQ_UND		BIT(8)
2681f2367a3Sjames qian wang (Arm Technology China) #define DOU_IRQ_ERR		BIT(11)
2691f2367a3Sjames qian wang (Arm Technology China) #define DOU_IRQ_PL0		BIT(13)
2701f2367a3Sjames qian wang (Arm Technology China) #define DOU_IRQ_PL1		BIT(14)
2711f2367a3Sjames qian wang (Arm Technology China) 
2721f2367a3Sjames qian wang (Arm Technology China) /* DOU_STATUS_BITS */
2731f2367a3Sjames qian wang (Arm Technology China) #define DOU_STATUS_DRIFTTO	BIT(0)
2741f2367a3Sjames qian wang (Arm Technology China) #define DOU_STATUS_FRAMETO	BIT(1)
2751f2367a3Sjames qian wang (Arm Technology China) #define DOU_STATUS_TETO		BIT(2)
2761f2367a3Sjames qian wang (Arm Technology China) #define DOU_STATUS_CSCE		BIT(8)
2771f2367a3Sjames qian wang (Arm Technology China) #define DOU_STATUS_ACTIVE	BIT(31)
2781f2367a3Sjames qian wang (Arm Technology China) 
2791f2367a3Sjames qian wang (Arm Technology China) /* Layer registers */
2801f2367a3Sjames qian wang (Arm Technology China) #define LAYER_INFO		0x0C0
2811f2367a3Sjames qian wang (Arm Technology China) #define LAYER_R_CONTROL		0x0D4
2821f2367a3Sjames qian wang (Arm Technology China) #define LAYER_FMT		0x0D8
2831f2367a3Sjames qian wang (Arm Technology China) #define LAYER_LT_COEFFTAB	0x0DC
2841f2367a3Sjames qian wang (Arm Technology China) #define LAYER_PALPHA		0x0E4
2851f2367a3Sjames qian wang (Arm Technology China) 
2861f2367a3Sjames qian wang (Arm Technology China) #define LAYER_YUV_RGB_COEFF0	0x130
2871f2367a3Sjames qian wang (Arm Technology China) 
2881f2367a3Sjames qian wang (Arm Technology China) #define LAYER_AD_H_CROP		0x164
2891f2367a3Sjames qian wang (Arm Technology China) #define LAYER_AD_V_CROP		0x168
2901f2367a3Sjames qian wang (Arm Technology China) 
2911f2367a3Sjames qian wang (Arm Technology China) #define LAYER_RGB_RGB_COEFF0	0x170
2921f2367a3Sjames qian wang (Arm Technology China) 
2931f2367a3Sjames qian wang (Arm Technology China) /* L_CONTROL_BITS */
2941f2367a3Sjames qian wang (Arm Technology China) #define L_EN			BIT(0)
2951f2367a3Sjames qian wang (Arm Technology China) #define L_IT			BIT(4)
2961f2367a3Sjames qian wang (Arm Technology China) #define L_R2R			BIT(5)
2971f2367a3Sjames qian wang (Arm Technology China) #define L_FT			BIT(6)
2981f2367a3Sjames qian wang (Arm Technology China) #define L_ROT(x)		(((x) & 3) << 8)
2991f2367a3Sjames qian wang (Arm Technology China) #define L_HFLIP			BIT(10)
3001f2367a3Sjames qian wang (Arm Technology China) #define L_VFLIP			BIT(11)
3011f2367a3Sjames qian wang (Arm Technology China) #define L_TBU_EN		BIT(16)
3021f2367a3Sjames qian wang (Arm Technology China) #define L_A_RCACHE(x)		(((x) & 0xF) << 28)
3031f2367a3Sjames qian wang (Arm Technology China) #define L_ROT_R0		0
3041f2367a3Sjames qian wang (Arm Technology China) #define L_ROT_R90		1
3051f2367a3Sjames qian wang (Arm Technology China) #define L_ROT_R180		2
3061f2367a3Sjames qian wang (Arm Technology China) #define L_ROT_R270		3
3071f2367a3Sjames qian wang (Arm Technology China) 
3081f2367a3Sjames qian wang (Arm Technology China) /* LAYER_R_CONTROL BITS */
3091f2367a3Sjames qian wang (Arm Technology China) #define LR_CHI422_BILINEAR	0
3101f2367a3Sjames qian wang (Arm Technology China) #define LR_CHI422_REPLICATION	1
3111f2367a3Sjames qian wang (Arm Technology China) #define LR_CHI420_JPEG		(0 << 2)
3121f2367a3Sjames qian wang (Arm Technology China) #define LR_CHI420_MPEG		(1 << 2)
3131f2367a3Sjames qian wang (Arm Technology China) 
3141f2367a3Sjames qian wang (Arm Technology China) #define L_ITSEL(x)		((x) & 0xFFF)
3151f2367a3Sjames qian wang (Arm Technology China) #define L_FTSEL(x)		(((x) & 0xFFF) << 16)
3161f2367a3Sjames qian wang (Arm Technology China) 
3171f2367a3Sjames qian wang (Arm Technology China) #define LAYER_PER_PLANE_REGS	4
3181f2367a3Sjames qian wang (Arm Technology China) 
3191f2367a3Sjames qian wang (Arm Technology China) /* Layer_WR registers */
3201f2367a3Sjames qian wang (Arm Technology China) #define LAYER_WR_PROG_LINE	0x0D4
3211f2367a3Sjames qian wang (Arm Technology China) #define LAYER_WR_FORMAT		0x0D8
3221f2367a3Sjames qian wang (Arm Technology China) 
3231f2367a3Sjames qian wang (Arm Technology China) /* Layer_WR control bits */
3241f2367a3Sjames qian wang (Arm Technology China) #define LW_OFM			BIT(4)
3251f2367a3Sjames qian wang (Arm Technology China) #define LW_LALPHA(x)		(((x) & 0xFF) << 8)
3261f2367a3Sjames qian wang (Arm Technology China) #define LW_A_WCACHE(x)		(((x) & 0xF) << 28)
3271f2367a3Sjames qian wang (Arm Technology China) #define LW_TBU_EN		BIT(16)
3281f2367a3Sjames qian wang (Arm Technology China) 
3291f2367a3Sjames qian wang (Arm Technology China) #define AxCACHE_MASK		0xF0000000
3301f2367a3Sjames qian wang (Arm Technology China) 
3311f2367a3Sjames qian wang (Arm Technology China) /* Layer AXI R/W cache setting */
3321f2367a3Sjames qian wang (Arm Technology China) #define AxCACHE_B		BIT(0)	/* Bufferable */
3331f2367a3Sjames qian wang (Arm Technology China) #define AxCACHE_M		BIT(1)	/* Modifiable */
3341f2367a3Sjames qian wang (Arm Technology China) #define AxCACHE_RA		BIT(2)	/* Read-Allocate */
3351f2367a3Sjames qian wang (Arm Technology China) #define AxCACHE_WA		BIT(3)	/* Write-Allocate */
3361f2367a3Sjames qian wang (Arm Technology China) 
3371f2367a3Sjames qian wang (Arm Technology China) /* Layer info bits */
3381f2367a3Sjames qian wang (Arm Technology China) #define L_INFO_RF		BIT(0)
3391f2367a3Sjames qian wang (Arm Technology China) #define L_INFO_CM		BIT(1)
3401f2367a3Sjames qian wang (Arm Technology China) #define L_INFO_ABUF_SIZE(x)	(((x) >> 4) & 0x7)
3412b2510daSLowry Li (Arm Technology China) #define L_INFO_YUV_MAX_LINESZ(x)	(((x) >> 16) & 0xFFFF)
3421f2367a3Sjames qian wang (Arm Technology China) 
3431f2367a3Sjames qian wang (Arm Technology China) /* Scaler registers */
3441f2367a3Sjames qian wang (Arm Technology China) #define SC_COEFFTAB		0x0DC
3451f2367a3Sjames qian wang (Arm Technology China) #define SC_OUT_SIZE		0x0E4
3461f2367a3Sjames qian wang (Arm Technology China) #define SC_H_CROP		0x0E8
3471f2367a3Sjames qian wang (Arm Technology China) #define SC_V_CROP		0x0EC
3481f2367a3Sjames qian wang (Arm Technology China) #define SC_H_INIT_PH		0x0F0
3491f2367a3Sjames qian wang (Arm Technology China) #define SC_H_DELTA_PH		0x0F4
3501f2367a3Sjames qian wang (Arm Technology China) #define SC_V_INIT_PH		0x0F8
3511f2367a3Sjames qian wang (Arm Technology China) #define SC_V_DELTA_PH		0x0FC
3521f2367a3Sjames qian wang (Arm Technology China) #define SC_ENH_LIMITS		0x130
3531f2367a3Sjames qian wang (Arm Technology China) #define SC_ENH_COEFF0		0x134
3541f2367a3Sjames qian wang (Arm Technology China) 
3551f2367a3Sjames qian wang (Arm Technology China) #define SC_MAX_ENH_COEFF	9
3561f2367a3Sjames qian wang (Arm Technology China) 
3571f2367a3Sjames qian wang (Arm Technology China) /* SC_CTRL_BITS */
3581f2367a3Sjames qian wang (Arm Technology China) #define SC_CTRL_SCL		BIT(0)
3591f2367a3Sjames qian wang (Arm Technology China) #define SC_CTRL_LS		BIT(1)
3601f2367a3Sjames qian wang (Arm Technology China) #define SC_CTRL_AP		BIT(4)
3611f2367a3Sjames qian wang (Arm Technology China) #define SC_CTRL_IENH		BIT(8)
3621f2367a3Sjames qian wang (Arm Technology China) #define SC_CTRL_RGBSM		BIT(16)
3631f2367a3Sjames qian wang (Arm Technology China) #define SC_CTRL_ASM		BIT(17)
3641f2367a3Sjames qian wang (Arm Technology China) 
3651f2367a3Sjames qian wang (Arm Technology China) #define SC_VTSEL(vtal)		((vtal) << 16)
3661f2367a3Sjames qian wang (Arm Technology China) 
3671f2367a3Sjames qian wang (Arm Technology China) #define SC_NUM_INPUTS_IDS	1
3681f2367a3Sjames qian wang (Arm Technology China) #define SC_NUM_OUTPUTS_IDS	1
3691f2367a3Sjames qian wang (Arm Technology China) 
3701f2367a3Sjames qian wang (Arm Technology China) #define MG_NUM_INPUTS_IDS	2
3711f2367a3Sjames qian wang (Arm Technology China) #define MG_NUM_OUTPUTS_IDS	1
3721f2367a3Sjames qian wang (Arm Technology China) 
3731f2367a3Sjames qian wang (Arm Technology China) /* Merger registers */
3741f2367a3Sjames qian wang (Arm Technology China) #define MG_INPUT_ID0		BLK_INPUT_ID0
3751f2367a3Sjames qian wang (Arm Technology China) #define MG_INPUT_ID1		(MG_INPUT_ID0 + 4)
3761f2367a3Sjames qian wang (Arm Technology China) #define MG_SIZE			BLK_SIZE
3771f2367a3Sjames qian wang (Arm Technology China) 
3781f2367a3Sjames qian wang (Arm Technology China) /* Splitter registers */
3791f2367a3Sjames qian wang (Arm Technology China) #define SP_OVERLAP_SIZE		0xD8
3801f2367a3Sjames qian wang (Arm Technology China) 
3811f2367a3Sjames qian wang (Arm Technology China) /* Backend registers */
3821f2367a3Sjames qian wang (Arm Technology China) #define BS_INFO			0x0C0
3831f2367a3Sjames qian wang (Arm Technology China) #define BS_PROG_LINE		0x0D4
3841f2367a3Sjames qian wang (Arm Technology China) #define BS_PREFETCH_LINE	0x0D8
3851f2367a3Sjames qian wang (Arm Technology China) #define BS_BG_COLOR		0x0DC
3861f2367a3Sjames qian wang (Arm Technology China) #define BS_ACTIVESIZE		0x0E0
3871f2367a3Sjames qian wang (Arm Technology China) #define BS_HINTERVALS		0x0E4
3881f2367a3Sjames qian wang (Arm Technology China) #define BS_VINTERVALS		0x0E8
3891f2367a3Sjames qian wang (Arm Technology China) #define BS_SYNC			0x0EC
3901f2367a3Sjames qian wang (Arm Technology China) #define BS_DRIFT_TO		0x100
3911f2367a3Sjames qian wang (Arm Technology China) #define BS_FRAME_TO		0x104
3921f2367a3Sjames qian wang (Arm Technology China) #define BS_TE_TO		0x108
3931f2367a3Sjames qian wang (Arm Technology China) #define BS_T0_INTERVAL		0x110
3941f2367a3Sjames qian wang (Arm Technology China) #define BS_T1_INTERVAL		0x114
3951f2367a3Sjames qian wang (Arm Technology China) #define BS_T2_INTERVAL		0x118
3961f2367a3Sjames qian wang (Arm Technology China) #define BS_CRC0_LOW		0x120
3971f2367a3Sjames qian wang (Arm Technology China) #define BS_CRC0_HIGH		0x124
3981f2367a3Sjames qian wang (Arm Technology China) #define BS_CRC1_LOW		0x128
3991f2367a3Sjames qian wang (Arm Technology China) #define BS_CRC1_HIGH		0x12C
4001f2367a3Sjames qian wang (Arm Technology China) #define BS_USER			0x130
4011f2367a3Sjames qian wang (Arm Technology China) 
4021f2367a3Sjames qian wang (Arm Technology China) /* BS control register bits */
4031f2367a3Sjames qian wang (Arm Technology China) #define BS_CTRL_EN		BIT(0)
4041f2367a3Sjames qian wang (Arm Technology China) #define BS_CTRL_VM		BIT(1)
4051f2367a3Sjames qian wang (Arm Technology China) #define BS_CTRL_BM		BIT(2)
4061f2367a3Sjames qian wang (Arm Technology China) #define BS_CTRL_HMASK		BIT(4)
4071f2367a3Sjames qian wang (Arm Technology China) #define BS_CTRL_VD		BIT(5)
4081f2367a3Sjames qian wang (Arm Technology China) #define BS_CTRL_TE		BIT(8)
4091f2367a3Sjames qian wang (Arm Technology China) #define BS_CTRL_TS		BIT(9)
4101f2367a3Sjames qian wang (Arm Technology China) #define BS_CTRL_TM		BIT(12)
4111f2367a3Sjames qian wang (Arm Technology China) #define BS_CTRL_DL		BIT(16)
4121f2367a3Sjames qian wang (Arm Technology China) #define BS_CTRL_SBS		BIT(17)
4131f2367a3Sjames qian wang (Arm Technology China) #define BS_CTRL_CRC		BIT(18)
4141f2367a3Sjames qian wang (Arm Technology China) #define BS_CTRL_PM		BIT(20)
4151f2367a3Sjames qian wang (Arm Technology China) 
4161f2367a3Sjames qian wang (Arm Technology China) /* BS active size/intervals */
4171f2367a3Sjames qian wang (Arm Technology China) #define BS_H_INTVALS(hfp, hbp)	(((hfp) & 0xFFF) + (((hbp) & 0x3FF) << 16))
4181f2367a3Sjames qian wang (Arm Technology China) #define BS_V_INTVALS(vfp, vbp)  (((vfp) & 0x3FFF) + (((vbp) & 0xFF) << 16))
4191f2367a3Sjames qian wang (Arm Technology China) 
4201f2367a3Sjames qian wang (Arm Technology China) /* BS_SYNC bits */
4211f2367a3Sjames qian wang (Arm Technology China) #define BS_SYNC_HSW(x)		((x) & 0x3FF)
4221f2367a3Sjames qian wang (Arm Technology China) #define BS_SYNC_HSP		BIT(12)
4231f2367a3Sjames qian wang (Arm Technology China) #define BS_SYNC_VSW(x)		(((x) & 0xFF) << 16)
4241f2367a3Sjames qian wang (Arm Technology China) #define BS_SYNC_VSP		BIT(28)
4251f2367a3Sjames qian wang (Arm Technology China) 
4261f2367a3Sjames qian wang (Arm Technology China) #define BS_NUM_INPUT_IDS	0
4271f2367a3Sjames qian wang (Arm Technology China) #define BS_NUM_OUTPUT_IDS	0
4281f2367a3Sjames qian wang (Arm Technology China) 
4291f2367a3Sjames qian wang (Arm Technology China) /* Image process registers */
4301f2367a3Sjames qian wang (Arm Technology China) #define IPS_DEPTH		0x0D8
4311f2367a3Sjames qian wang (Arm Technology China) #define IPS_RGB_RGB_COEFF0	0x130
4321f2367a3Sjames qian wang (Arm Technology China) #define IPS_RGB_YUV_COEFF0	0x170
4331f2367a3Sjames qian wang (Arm Technology China) 
4341f2367a3Sjames qian wang (Arm Technology China) #define IPS_DEPTH_MARK		0xF
4351f2367a3Sjames qian wang (Arm Technology China) 
4361f2367a3Sjames qian wang (Arm Technology China) /* IPS control register bits */
4371f2367a3Sjames qian wang (Arm Technology China) #define IPS_CTRL_RGB		BIT(0)
4381f2367a3Sjames qian wang (Arm Technology China) #define IPS_CTRL_FT		BIT(4)
4391f2367a3Sjames qian wang (Arm Technology China) #define IPS_CTRL_YUV		BIT(8)
4401f2367a3Sjames qian wang (Arm Technology China) #define IPS_CTRL_CHD422		BIT(9)
4411f2367a3Sjames qian wang (Arm Technology China) #define IPS_CTRL_CHD420		BIT(10)
4421f2367a3Sjames qian wang (Arm Technology China) #define IPS_CTRL_LPF		BIT(11)
4431f2367a3Sjames qian wang (Arm Technology China) #define IPS_CTRL_DITH		BIT(12)
4441f2367a3Sjames qian wang (Arm Technology China) #define IPS_CTRL_CLAMP		BIT(16)
4451f2367a3Sjames qian wang (Arm Technology China) #define IPS_CTRL_SBS		BIT(17)
4461f2367a3Sjames qian wang (Arm Technology China) 
4471f2367a3Sjames qian wang (Arm Technology China) /* IPS info register bits */
4481f2367a3Sjames qian wang (Arm Technology China) #define IPS_INFO_CHD420		BIT(10)
4491f2367a3Sjames qian wang (Arm Technology China) 
4501f2367a3Sjames qian wang (Arm Technology China) #define IPS_NUM_INPUT_IDS	2
4511f2367a3Sjames qian wang (Arm Technology China) #define IPS_NUM_OUTPUT_IDS	1
4521f2367a3Sjames qian wang (Arm Technology China) 
4531f2367a3Sjames qian wang (Arm Technology China) /* FT_COEFF block registers */
4541f2367a3Sjames qian wang (Arm Technology China) #define FT_COEFF0		0x80
4551f2367a3Sjames qian wang (Arm Technology China) #define GLB_IT_COEFF		0x80
4561f2367a3Sjames qian wang (Arm Technology China) 
4571f2367a3Sjames qian wang (Arm Technology China) /* GLB_SC_COEFF registers */
4581f2367a3Sjames qian wang (Arm Technology China) #define GLB_SC_COEFF_ADDR	0x0080
4591f2367a3Sjames qian wang (Arm Technology China) #define GLB_SC_COEFF_DATA	0x0084
4601f2367a3Sjames qian wang (Arm Technology China) #define GLB_LT_COEFF_DATA	0x0080
4611f2367a3Sjames qian wang (Arm Technology China) 
4621f2367a3Sjames qian wang (Arm Technology China) #define GLB_SC_COEFF_MAX_NUM	1024
4631f2367a3Sjames qian wang (Arm Technology China) #define GLB_LT_COEFF_NUM	65
4641f2367a3Sjames qian wang (Arm Technology China) /* GLB_SC_ADDR */
4651f2367a3Sjames qian wang (Arm Technology China) #define SC_COEFF_R_ADDR		BIT(18)
4661f2367a3Sjames qian wang (Arm Technology China) #define SC_COEFF_G_ADDR		BIT(17)
4671f2367a3Sjames qian wang (Arm Technology China) #define SC_COEFF_B_ADDR		BIT(16)
4681f2367a3Sjames qian wang (Arm Technology China) 
4691f2367a3Sjames qian wang (Arm Technology China) #define SC_COEFF_DATA(x, y)	(((y) & 0xFFFF) | (((x) & 0xFFFF) << 16))
4701f2367a3Sjames qian wang (Arm Technology China) 
4711f2367a3Sjames qian wang (Arm Technology China) enum d71_blk_type {
4721f2367a3Sjames qian wang (Arm Technology China) 	D71_BLK_TYPE_GCU		= 0x00,
4731f2367a3Sjames qian wang (Arm Technology China) 	D71_BLK_TYPE_LPU		= 0x01,
4741f2367a3Sjames qian wang (Arm Technology China) 	D71_BLK_TYPE_CU			= 0x02,
4751f2367a3Sjames qian wang (Arm Technology China) 	D71_BLK_TYPE_DOU		= 0x03,
4761f2367a3Sjames qian wang (Arm Technology China) 	D71_BLK_TYPE_AEU		= 0x04,
4771f2367a3Sjames qian wang (Arm Technology China) 	D71_BLK_TYPE_GLB_LT_COEFF	= 0x05,
4781f2367a3Sjames qian wang (Arm Technology China) 	D71_BLK_TYPE_GLB_SCL_COEFF	= 0x06, /* SH/SV scaler coeff */
4791f2367a3Sjames qian wang (Arm Technology China) 	D71_BLK_TYPE_GLB_SC_COEFF	= 0x07,
4801f2367a3Sjames qian wang (Arm Technology China) 	D71_BLK_TYPE_PERIPH		= 0x08,
4811f2367a3Sjames qian wang (Arm Technology China) 	D71_BLK_TYPE_LPU_TRUSTED	= 0x09,
4821f2367a3Sjames qian wang (Arm Technology China) 	D71_BLK_TYPE_AEU_TRUSTED	= 0x0A,
4831f2367a3Sjames qian wang (Arm Technology China) 	D71_BLK_TYPE_LPU_LAYER		= 0x10,
4841f2367a3Sjames qian wang (Arm Technology China) 	D71_BLK_TYPE_LPU_WB_LAYER	= 0x11,
4851f2367a3Sjames qian wang (Arm Technology China) 	D71_BLK_TYPE_CU_SPLITTER	= 0x20,
4861f2367a3Sjames qian wang (Arm Technology China) 	D71_BLK_TYPE_CU_SCALER		= 0x21,
4871f2367a3Sjames qian wang (Arm Technology China) 	D71_BLK_TYPE_CU_MERGER		= 0x22,
4881f2367a3Sjames qian wang (Arm Technology China) 	D71_BLK_TYPE_DOU_IPS		= 0x30,
4891f2367a3Sjames qian wang (Arm Technology China) 	D71_BLK_TYPE_DOU_BS		= 0x31,
4901f2367a3Sjames qian wang (Arm Technology China) 	D71_BLK_TYPE_DOU_FT_COEFF	= 0x32,
4911f2367a3Sjames qian wang (Arm Technology China) 	D71_BLK_TYPE_AEU_DS		= 0x40,
4921f2367a3Sjames qian wang (Arm Technology China) 	D71_BLK_TYPE_AEU_AES		= 0x41,
4931f2367a3Sjames qian wang (Arm Technology China) 	D71_BLK_TYPE_RESERVED		= 0xFF
4941f2367a3Sjames qian wang (Arm Technology China) };
4951f2367a3Sjames qian wang (Arm Technology China) 
4961f2367a3Sjames qian wang (Arm Technology China) /* Constant of components */
4971f2367a3Sjames qian wang (Arm Technology China) #define D71_MAX_PIPELINE		2
4981f2367a3Sjames qian wang (Arm Technology China) #define D71_PIPELINE_MAX_SCALERS	2
4991f2367a3Sjames qian wang (Arm Technology China) #define D71_PIPELINE_MAX_LAYERS		4
5001f2367a3Sjames qian wang (Arm Technology China) 
5011f2367a3Sjames qian wang (Arm Technology China) #define D71_MAX_GLB_IT_COEFF		3
5021f2367a3Sjames qian wang (Arm Technology China) #define D71_MAX_GLB_SCL_COEFF		4
5031f2367a3Sjames qian wang (Arm Technology China) 
5041f2367a3Sjames qian wang (Arm Technology China) #define D71_MAX_LAYERS_PER_LPU		4
5051f2367a3Sjames qian wang (Arm Technology China) #define D71_BLOCK_MAX_INPUT		9
5061f2367a3Sjames qian wang (Arm Technology China) #define D71_BLOCK_MAX_OUTPUT		5
5071f2367a3Sjames qian wang (Arm Technology China) #define D71_MAX_SC_PER_CU		2
5081f2367a3Sjames qian wang (Arm Technology China) 
5091f2367a3Sjames qian wang (Arm Technology China) #define D71_BLOCK_OFFSET_PERIPH		0xFE00
5101f2367a3Sjames qian wang (Arm Technology China) #define D71_BLOCK_SIZE			0x0200
5111f2367a3Sjames qian wang (Arm Technology China) 
5121f2367a3Sjames qian wang (Arm Technology China) #define D71_DEFAULT_PREPRETCH_LINE	5
5131f2367a3Sjames qian wang (Arm Technology China) #define D71_BUS_WIDTH_16_BYTES		16
5141f2367a3Sjames qian wang (Arm Technology China) 
5151f2367a3Sjames qian wang (Arm Technology China) #define D71_SC_MAX_UPSCALING		64
5161f2367a3Sjames qian wang (Arm Technology China) #define D71_SC_MAX_DOWNSCALING		6
5171f2367a3Sjames qian wang (Arm Technology China) #define D71_SC_SPLIT_OVERLAP		8
5181f2367a3Sjames qian wang (Arm Technology China) #define D71_SC_ENH_SPLIT_OVERLAP	1
5191f2367a3Sjames qian wang (Arm Technology China) 
5201f2367a3Sjames qian wang (Arm Technology China) #define D71_MG_MIN_MERGED_SIZE		4
5211f2367a3Sjames qian wang (Arm Technology China) #define D71_MG_MAX_MERGED_HSIZE		4032
5221f2367a3Sjames qian wang (Arm Technology China) #define D71_MG_MAX_MERGED_VSIZE		4096
5231f2367a3Sjames qian wang (Arm Technology China) 
5241f2367a3Sjames qian wang (Arm Technology China) #define D71_PALPHA_DEF_MAP		0xFFAA5500
5251f2367a3Sjames qian wang (Arm Technology China) #define D71_LAYER_CONTROL_DEFAULT	0x30000000
5261f2367a3Sjames qian wang (Arm Technology China) #define D71_WB_LAYER_CONTROL_DEFAULT	0x3000FF00
5271f2367a3Sjames qian wang (Arm Technology China) #define D71_BS_CONTROL_DEFAULT		0x00000002
5281f2367a3Sjames qian wang (Arm Technology China) 
5291f2367a3Sjames qian wang (Arm Technology China) struct block_header {
5301f2367a3Sjames qian wang (Arm Technology China) 	u32 block_info;
5311f2367a3Sjames qian wang (Arm Technology China) 	u32 pipeline_info;
5321f2367a3Sjames qian wang (Arm Technology China) 	u32 input_ids[D71_BLOCK_MAX_INPUT];
5331f2367a3Sjames qian wang (Arm Technology China) 	u32 output_ids[D71_BLOCK_MAX_OUTPUT];
5341f2367a3Sjames qian wang (Arm Technology China) };
5351f2367a3Sjames qian wang (Arm Technology China) 
get_block_type(struct block_header * blk)5361f2367a3Sjames qian wang (Arm Technology China) static inline u32 get_block_type(struct block_header *blk)
5371f2367a3Sjames qian wang (Arm Technology China) {
5381f2367a3Sjames qian wang (Arm Technology China) 	return BLOCK_INFO_BLK_TYPE(blk->block_info);
5391f2367a3Sjames qian wang (Arm Technology China) }
5401f2367a3Sjames qian wang (Arm Technology China) 
5411f2367a3Sjames qian wang (Arm Technology China) #endif /* !_D71_REG_H_ */
542