cachepc-linux

Fork of AMDESE/linux with modifications for CachePC side-channel attack
git clone https://git.sinitax.com/sinitax/cachepc-linux
Log | Files | Refs | README | LICENSE | sfeed.txt

d71_regs.h (14374B)


      1/* SPDX-License-Identifier: GPL-2.0 */
      2/*
      3 * (C) COPYRIGHT 2018 ARM Limited. All rights reserved.
      4 * Author: James.Qian.Wang <james.qian.wang@arm.com>
      5 *
      6 */
      7#ifndef _D71_REG_H_
      8#define _D71_REG_H_
      9
     10/* Common block registers offset */
     11#define BLK_BLOCK_INFO		0x000
     12#define BLK_PIPELINE_INFO	0x004
     13#define BLK_MAX_LINE_SIZE	0x008
     14#define BLK_VALID_INPUT_ID0	0x020
     15#define BLK_OUTPUT_ID0		0x060
     16#define BLK_INPUT_ID0		0x080
     17#define BLK_IRQ_RAW_STATUS	0x0A0
     18#define BLK_IRQ_CLEAR		0x0A4
     19#define BLK_IRQ_MASK		0x0A8
     20#define BLK_IRQ_STATUS		0x0AC
     21#define BLK_STATUS		0x0B0
     22#define BLK_INFO		0x0C0
     23#define BLK_CONTROL		0x0D0
     24#define BLK_SIZE		0x0D4
     25#define BLK_IN_SIZE		0x0E0
     26
     27#define BLK_P0_PTR_LOW		0x100
     28#define BLK_P0_PTR_HIGH		0x104
     29#define BLK_P0_STRIDE		0x108
     30#define BLK_P1_PTR_LOW		0x110
     31#define BLK_P1_PTR_HIGH		0x114
     32#define BLK_P1_STRIDE		0x118
     33#define BLK_P2_PTR_LOW		0x120
     34#define BLK_P2_PTR_HIGH		0x124
     35
     36#define BLOCK_INFO_N_SUBBLKS(x)	((x) & 0x000F)
     37#define BLOCK_INFO_BLK_ID(x)	(((x) & 0x00F0) >> 4)
     38#define BLOCK_INFO_BLK_TYPE(x)	(((x) & 0xFF00) >> 8)
     39#define BLOCK_INFO_INPUT_ID(x)	((x) & 0xFFF0)
     40#define BLOCK_INFO_TYPE_ID(x)	(((x) & 0x0FF0) >> 4)
     41
     42#define PIPELINE_INFO_N_OUTPUTS(x)	((x) & 0x000F)
     43#define PIPELINE_INFO_N_VALID_INPUTS(x)	(((x) & 0x0F00) >> 8)
     44
     45/* Common block control register bits */
     46#define BLK_CTRL_EN		BIT(0)
     47/* Common size macro */
     48#define HV_SIZE(h, v)		(((h) & 0x1FFF) + (((v) & 0x1FFF) << 16))
     49#define HV_OFFSET(h, v)		(((h) & 0xFFF) + (((v) & 0xFFF) << 16))
     50#define HV_CROP(h, v)		(((h) & 0xFFF) + (((v) & 0xFFF) << 16))
     51
     52/* AD_CONTROL register */
     53#define AD_CONTROL		0x160
     54
     55/* AD_CONTROL register bits */
     56#define AD_AEN			BIT(0)
     57#define AD_YT			BIT(1)
     58#define AD_BS			BIT(2)
     59#define AD_WB			BIT(3)
     60#define AD_TH			BIT(4)
     61
     62/* Global Control Unit */
     63#define GLB_ARCH_ID		0x000
     64#define GLB_CORE_ID		0x004
     65#define GLB_CORE_INFO		0x008
     66#define GLB_IRQ_STATUS		0x010
     67
     68#define GCU_CONFIG_VALID0	0x0D4
     69#define GCU_CONFIG_VALID1	0x0D8
     70
     71/* GCU_CONTROL_BITS */
     72#define GCU_CONTROL_MODE(x)	((x) & 0x7)
     73#define GCU_CONTROL_SRST	BIT(16)
     74
     75/* GCU_CONFIGURATION registers */
     76#define GCU_CONFIGURATION_ID0	0x100
     77#define GCU_CONFIGURATION_ID1	0x104
     78
     79/* GCU configuration */
     80#define GCU_MAX_LINE_SIZE(x)	((x) & 0xFFFF)
     81#define GCU_MAX_NUM_LINES(x)	((x) >> 16)
     82#define GCU_NUM_RICH_LAYERS(x)	((x) & 0x7)
     83#define GCU_NUM_PIPELINES(x)	(((x) >> 3) & 0x7)
     84#define GCU_NUM_SCALERS(x)	(((x) >> 6) & 0x7)
     85#define GCU_DISPLAY_SPLIT_EN(x)	(((x) >> 16) & 0x1)
     86#define GCU_DISPLAY_TBU_EN(x)	(((x) >> 17) & 0x1)
     87
     88/* GCU opmode */
     89#define INACTIVE_MODE		0
     90#define TBU_CONNECT_MODE	1
     91#define TBU_DISCONNECT_MODE	2
     92#define DO0_ACTIVE_MODE		3
     93#define DO1_ACTIVE_MODE		4
     94#define DO01_ACTIVE_MODE	5
     95
     96/* GLB_IRQ_STATUS bits */
     97#define GLB_IRQ_STATUS_GCU	BIT(0)
     98#define GLB_IRQ_STATUS_LPU0	BIT(8)
     99#define GLB_IRQ_STATUS_LPU1	BIT(9)
    100#define GLB_IRQ_STATUS_ATU0	BIT(10)
    101#define GLB_IRQ_STATUS_ATU1	BIT(11)
    102#define GLB_IRQ_STATUS_ATU2	BIT(12)
    103#define GLB_IRQ_STATUS_ATU3	BIT(13)
    104#define GLB_IRQ_STATUS_CU0	BIT(16)
    105#define GLB_IRQ_STATUS_CU1	BIT(17)
    106#define GLB_IRQ_STATUS_DOU0	BIT(24)
    107#define GLB_IRQ_STATUS_DOU1	BIT(25)
    108
    109#define GLB_IRQ_STATUS_PIPE0	(GLB_IRQ_STATUS_LPU0 |\
    110				 GLB_IRQ_STATUS_ATU0 |\
    111				 GLB_IRQ_STATUS_ATU1 |\
    112				 GLB_IRQ_STATUS_CU0 |\
    113				 GLB_IRQ_STATUS_DOU0)
    114
    115#define GLB_IRQ_STATUS_PIPE1	(GLB_IRQ_STATUS_LPU1 |\
    116				 GLB_IRQ_STATUS_ATU2 |\
    117				 GLB_IRQ_STATUS_ATU3 |\
    118				 GLB_IRQ_STATUS_CU1 |\
    119				 GLB_IRQ_STATUS_DOU1)
    120
    121#define GLB_IRQ_STATUS_ATU	(GLB_IRQ_STATUS_ATU0 |\
    122				 GLB_IRQ_STATUS_ATU1 |\
    123				 GLB_IRQ_STATUS_ATU2 |\
    124				 GLB_IRQ_STATUS_ATU3)
    125
    126/* GCU_IRQ_BITS */
    127#define GCU_IRQ_CVAL0		BIT(0)
    128#define GCU_IRQ_CVAL1		BIT(1)
    129#define GCU_IRQ_MODE		BIT(4)
    130#define GCU_IRQ_ERR		BIT(11)
    131
    132/* GCU_STATUS_BITS */
    133#define GCU_STATUS_MODE(x)	((x) & 0x7)
    134#define GCU_STATUS_MERR		BIT(4)
    135#define GCU_STATUS_TCS0		BIT(8)
    136#define GCU_STATUS_TCS1		BIT(9)
    137#define GCU_STATUS_ACTIVE	BIT(31)
    138
    139/* GCU_CONFIG_VALIDx BITS */
    140#define GCU_CONFIG_CVAL		BIT(0)
    141
    142/* PERIPHERAL registers */
    143#define PERIPH_MAX_LINE_SIZE	BIT(0)
    144#define PERIPH_NUM_RICH_LAYERS	BIT(4)
    145#define PERIPH_SPLIT_EN		BIT(8)
    146#define PERIPH_TBU_EN		BIT(12)
    147#define PERIPH_AFBC_DMA_EN	BIT(16)
    148#define PERIPH_CONFIGURATION_ID	0x1D4
    149
    150/* LPU register */
    151#define LPU_TBU_STATUS		0x0B4
    152#define LPU_RAXI_CONTROL	0x0D0
    153#define LPU_WAXI_CONTROL	0x0D4
    154#define LPU_TBU_CONTROL		0x0D8
    155
    156/* LPU_xAXI_CONTROL_BITS */
    157#define TO_RAXI_AOUTSTDCAPB(x)	(x)
    158#define TO_RAXI_BOUTSTDCAPB(x)	((x) << 8)
    159#define TO_RAXI_BEN(x)		((x) << 15)
    160#define TO_xAXI_BURSTLEN(x)	((x) << 16)
    161#define TO_xAXI_AxQOS(x)	((x) << 24)
    162#define TO_xAXI_ORD(x)		((x) << 31)
    163#define TO_WAXI_OUTSTDCAPB(x)	(x)
    164
    165#define RAXI_AOUTSTDCAPB_MASK	0x7F
    166#define RAXI_BOUTSTDCAPB_MASK	0x7F00
    167#define RAXI_BEN_MASK		BIT(15)
    168#define xAXI_BURSTLEN_MASK	0x3F0000
    169#define xAXI_AxQOS_MASK		0xF000000
    170#define xAXI_ORD_MASK		BIT(31)
    171#define WAXI_OUTSTDCAPB_MASK	0x3F
    172
    173/* LPU_TBU_CONTROL BITS */
    174#define TO_TBU_DOUTSTDCAPB(x)	(x)
    175#define TBU_DOUTSTDCAPB_MASK	0x3F
    176
    177/* LPU_IRQ_BITS */
    178#define LPU_IRQ_OVR		BIT(9)
    179#define LPU_IRQ_IBSY		BIT(10)
    180#define LPU_IRQ_ERR		BIT(11)
    181#define LPU_IRQ_EOW		BIT(12)
    182#define LPU_IRQ_PL0		BIT(13)
    183
    184/* LPU_STATUS_BITS */
    185#define LPU_STATUS_AXIED(x)	((x) & 0xF)
    186#define LPU_STATUS_AXIE		BIT(4)
    187#define LPU_STATUS_AXIRP	BIT(5)
    188#define LPU_STATUS_AXIWP	BIT(6)
    189#define LPU_STATUS_FEMPTY	BIT(11)
    190#define LPU_STATUS_FFULL	BIT(14)
    191#define LPU_STATUS_ACE0		BIT(16)
    192#define LPU_STATUS_ACE1		BIT(17)
    193#define LPU_STATUS_ACE2		BIT(18)
    194#define LPU_STATUS_ACE3		BIT(19)
    195#define LPU_STATUS_ACTIVE	BIT(31)
    196
    197#define AXIEID_MASK		0xF
    198#define AXIE_MASK		LPU_STATUS_AXIE
    199#define AXIRP_MASK		LPU_STATUS_AXIRP
    200#define AXIWP_MASK		LPU_STATUS_AXIWP
    201
    202#define FROM_AXIEID(reg)	((reg) & AXIEID_MASK)
    203#define TO_AXIE(x)		((x) << 4)
    204#define FROM_AXIRP(reg)		(((reg) & AXIRP_MASK) >> 5)
    205#define FROM_AXIWP(reg)		(((reg) & AXIWP_MASK) >> 6)
    206
    207/* LPU_TBU_STATUS_BITS */
    208#define LPU_TBU_STATUS_TCF	BIT(1)
    209#define LPU_TBU_STATUS_TTNG	BIT(2)
    210#define LPU_TBU_STATUS_TITR	BIT(8)
    211#define LPU_TBU_STATUS_TEMR	BIT(16)
    212#define LPU_TBU_STATUS_TTF	BIT(31)
    213
    214/* LPU_TBU_CONTROL BITS */
    215#define LPU_TBU_CTRL_TLBPEN	BIT(16)
    216
    217/* CROSSBAR CONTROL BITS */
    218#define CBU_INPUT_CTRL_EN	BIT(0)
    219#define CBU_NUM_INPUT_IDS	5
    220#define CBU_NUM_OUTPUT_IDS	5
    221
    222/* CU register */
    223#define CU_BG_COLOR		0x0DC
    224#define CU_INPUT0_SIZE		0x0E0
    225#define CU_INPUT0_OFFSET	0x0E4
    226#define CU_INPUT0_CONTROL	0x0E8
    227#define CU_INPUT1_SIZE		0x0F0
    228#define CU_INPUT1_OFFSET	0x0F4
    229#define CU_INPUT1_CONTROL	0x0F8
    230#define CU_INPUT2_SIZE		0x100
    231#define CU_INPUT2_OFFSET	0x104
    232#define CU_INPUT2_CONTROL	0x108
    233#define CU_INPUT3_SIZE		0x110
    234#define CU_INPUT3_OFFSET	0x114
    235#define CU_INPUT3_CONTROL	0x118
    236#define CU_INPUT4_SIZE		0x120
    237#define CU_INPUT4_OFFSET	0x124
    238#define CU_INPUT4_CONTROL	0x128
    239
    240#define CU_PER_INPUT_REGS	4
    241
    242#define CU_NUM_INPUT_IDS	5
    243#define CU_NUM_OUTPUT_IDS	1
    244
    245/* CU control register bits */
    246#define CU_CTRL_COPROC		BIT(0)
    247
    248/* CU_IRQ_BITS */
    249#define CU_IRQ_OVR		BIT(9)
    250#define CU_IRQ_ERR		BIT(11)
    251
    252/* CU_STATUS_BITS */
    253#define CU_STATUS_CPE		BIT(0)
    254#define CU_STATUS_ZME		BIT(1)
    255#define CU_STATUS_CFGE		BIT(2)
    256#define CU_STATUS_ACTIVE	BIT(31)
    257
    258/* CU input control register bits */
    259#define CU_INPUT_CTRL_EN	BIT(0)
    260#define CU_INPUT_CTRL_PAD	BIT(1)
    261#define CU_INPUT_CTRL_PMUL	BIT(2)
    262#define CU_INPUT_CTRL_ALPHA(x)	(((x) & 0xFF) << 8)
    263
    264/* DOU register */
    265
    266/* DOU_IRQ_BITS */
    267#define DOU_IRQ_UND		BIT(8)
    268#define DOU_IRQ_ERR		BIT(11)
    269#define DOU_IRQ_PL0		BIT(13)
    270#define DOU_IRQ_PL1		BIT(14)
    271
    272/* DOU_STATUS_BITS */
    273#define DOU_STATUS_DRIFTTO	BIT(0)
    274#define DOU_STATUS_FRAMETO	BIT(1)
    275#define DOU_STATUS_TETO		BIT(2)
    276#define DOU_STATUS_CSCE		BIT(8)
    277#define DOU_STATUS_ACTIVE	BIT(31)
    278
    279/* Layer registers */
    280#define LAYER_INFO		0x0C0
    281#define LAYER_R_CONTROL		0x0D4
    282#define LAYER_FMT		0x0D8
    283#define LAYER_LT_COEFFTAB	0x0DC
    284#define LAYER_PALPHA		0x0E4
    285
    286#define LAYER_YUV_RGB_COEFF0	0x130
    287
    288#define LAYER_AD_H_CROP		0x164
    289#define LAYER_AD_V_CROP		0x168
    290
    291#define LAYER_RGB_RGB_COEFF0	0x170
    292
    293/* L_CONTROL_BITS */
    294#define L_EN			BIT(0)
    295#define L_IT			BIT(4)
    296#define L_R2R			BIT(5)
    297#define L_FT			BIT(6)
    298#define L_ROT(x)		(((x) & 3) << 8)
    299#define L_HFLIP			BIT(10)
    300#define L_VFLIP			BIT(11)
    301#define L_TBU_EN		BIT(16)
    302#define L_A_RCACHE(x)		(((x) & 0xF) << 28)
    303#define L_ROT_R0		0
    304#define L_ROT_R90		1
    305#define L_ROT_R180		2
    306#define L_ROT_R270		3
    307
    308/* LAYER_R_CONTROL BITS */
    309#define LR_CHI422_BILINEAR	0
    310#define LR_CHI422_REPLICATION	1
    311#define LR_CHI420_JPEG		(0 << 2)
    312#define LR_CHI420_MPEG		(1 << 2)
    313
    314#define L_ITSEL(x)		((x) & 0xFFF)
    315#define L_FTSEL(x)		(((x) & 0xFFF) << 16)
    316
    317#define LAYER_PER_PLANE_REGS	4
    318
    319/* Layer_WR registers */
    320#define LAYER_WR_PROG_LINE	0x0D4
    321#define LAYER_WR_FORMAT		0x0D8
    322
    323/* Layer_WR control bits */
    324#define LW_OFM			BIT(4)
    325#define LW_LALPHA(x)		(((x) & 0xFF) << 8)
    326#define LW_A_WCACHE(x)		(((x) & 0xF) << 28)
    327#define LW_TBU_EN		BIT(16)
    328
    329#define AxCACHE_MASK		0xF0000000
    330
    331/* Layer AXI R/W cache setting */
    332#define AxCACHE_B		BIT(0)	/* Bufferable */
    333#define AxCACHE_M		BIT(1)	/* Modifiable */
    334#define AxCACHE_RA		BIT(2)	/* Read-Allocate */
    335#define AxCACHE_WA		BIT(3)	/* Write-Allocate */
    336
    337/* Layer info bits */
    338#define L_INFO_RF		BIT(0)
    339#define L_INFO_CM		BIT(1)
    340#define L_INFO_ABUF_SIZE(x)	(((x) >> 4) & 0x7)
    341#define L_INFO_YUV_MAX_LINESZ(x)	(((x) >> 16) & 0xFFFF)
    342
    343/* Scaler registers */
    344#define SC_COEFFTAB		0x0DC
    345#define SC_OUT_SIZE		0x0E4
    346#define SC_H_CROP		0x0E8
    347#define SC_V_CROP		0x0EC
    348#define SC_H_INIT_PH		0x0F0
    349#define SC_H_DELTA_PH		0x0F4
    350#define SC_V_INIT_PH		0x0F8
    351#define SC_V_DELTA_PH		0x0FC
    352#define SC_ENH_LIMITS		0x130
    353#define SC_ENH_COEFF0		0x134
    354
    355#define SC_MAX_ENH_COEFF	9
    356
    357/* SC_CTRL_BITS */
    358#define SC_CTRL_SCL		BIT(0)
    359#define SC_CTRL_LS		BIT(1)
    360#define SC_CTRL_AP		BIT(4)
    361#define SC_CTRL_IENH		BIT(8)
    362#define SC_CTRL_RGBSM		BIT(16)
    363#define SC_CTRL_ASM		BIT(17)
    364
    365#define SC_VTSEL(vtal)		((vtal) << 16)
    366
    367#define SC_NUM_INPUTS_IDS	1
    368#define SC_NUM_OUTPUTS_IDS	1
    369
    370#define MG_NUM_INPUTS_IDS	2
    371#define MG_NUM_OUTPUTS_IDS	1
    372
    373/* Merger registers */
    374#define MG_INPUT_ID0		BLK_INPUT_ID0
    375#define MG_INPUT_ID1		(MG_INPUT_ID0 + 4)
    376#define MG_SIZE			BLK_SIZE
    377
    378/* Splitter registers */
    379#define SP_OVERLAP_SIZE		0xD8
    380
    381/* Backend registers */
    382#define BS_INFO			0x0C0
    383#define BS_PROG_LINE		0x0D4
    384#define BS_PREFETCH_LINE	0x0D8
    385#define BS_BG_COLOR		0x0DC
    386#define BS_ACTIVESIZE		0x0E0
    387#define BS_HINTERVALS		0x0E4
    388#define BS_VINTERVALS		0x0E8
    389#define BS_SYNC			0x0EC
    390#define BS_DRIFT_TO		0x100
    391#define BS_FRAME_TO		0x104
    392#define BS_TE_TO		0x108
    393#define BS_T0_INTERVAL		0x110
    394#define BS_T1_INTERVAL		0x114
    395#define BS_T2_INTERVAL		0x118
    396#define BS_CRC0_LOW		0x120
    397#define BS_CRC0_HIGH		0x124
    398#define BS_CRC1_LOW		0x128
    399#define BS_CRC1_HIGH		0x12C
    400#define BS_USER			0x130
    401
    402/* BS control register bits */
    403#define BS_CTRL_EN		BIT(0)
    404#define BS_CTRL_VM		BIT(1)
    405#define BS_CTRL_BM		BIT(2)
    406#define BS_CTRL_HMASK		BIT(4)
    407#define BS_CTRL_VD		BIT(5)
    408#define BS_CTRL_TE		BIT(8)
    409#define BS_CTRL_TS		BIT(9)
    410#define BS_CTRL_TM		BIT(12)
    411#define BS_CTRL_DL		BIT(16)
    412#define BS_CTRL_SBS		BIT(17)
    413#define BS_CTRL_CRC		BIT(18)
    414#define BS_CTRL_PM		BIT(20)
    415
    416/* BS active size/intervals */
    417#define BS_H_INTVALS(hfp, hbp)	(((hfp) & 0xFFF) + (((hbp) & 0x3FF) << 16))
    418#define BS_V_INTVALS(vfp, vbp)  (((vfp) & 0x3FFF) + (((vbp) & 0xFF) << 16))
    419
    420/* BS_SYNC bits */
    421#define BS_SYNC_HSW(x)		((x) & 0x3FF)
    422#define BS_SYNC_HSP		BIT(12)
    423#define BS_SYNC_VSW(x)		(((x) & 0xFF) << 16)
    424#define BS_SYNC_VSP		BIT(28)
    425
    426#define BS_NUM_INPUT_IDS	0
    427#define BS_NUM_OUTPUT_IDS	0
    428
    429/* Image process registers */
    430#define IPS_DEPTH		0x0D8
    431#define IPS_RGB_RGB_COEFF0	0x130
    432#define IPS_RGB_YUV_COEFF0	0x170
    433
    434#define IPS_DEPTH_MARK		0xF
    435
    436/* IPS control register bits */
    437#define IPS_CTRL_RGB		BIT(0)
    438#define IPS_CTRL_FT		BIT(4)
    439#define IPS_CTRL_YUV		BIT(8)
    440#define IPS_CTRL_CHD422		BIT(9)
    441#define IPS_CTRL_CHD420		BIT(10)
    442#define IPS_CTRL_LPF		BIT(11)
    443#define IPS_CTRL_DITH		BIT(12)
    444#define IPS_CTRL_CLAMP		BIT(16)
    445#define IPS_CTRL_SBS		BIT(17)
    446
    447/* IPS info register bits */
    448#define IPS_INFO_CHD420		BIT(10)
    449
    450#define IPS_NUM_INPUT_IDS	2
    451#define IPS_NUM_OUTPUT_IDS	1
    452
    453/* FT_COEFF block registers */
    454#define FT_COEFF0		0x80
    455#define GLB_IT_COEFF		0x80
    456
    457/* GLB_SC_COEFF registers */
    458#define GLB_SC_COEFF_ADDR	0x0080
    459#define GLB_SC_COEFF_DATA	0x0084
    460#define GLB_LT_COEFF_DATA	0x0080
    461
    462#define GLB_SC_COEFF_MAX_NUM	1024
    463#define GLB_LT_COEFF_NUM	65
    464/* GLB_SC_ADDR */
    465#define SC_COEFF_R_ADDR		BIT(18)
    466#define SC_COEFF_G_ADDR		BIT(17)
    467#define SC_COEFF_B_ADDR		BIT(16)
    468
    469#define SC_COEFF_DATA(x, y)	(((y) & 0xFFFF) | (((x) & 0xFFFF) << 16))
    470
    471enum d71_blk_type {
    472	D71_BLK_TYPE_GCU		= 0x00,
    473	D71_BLK_TYPE_LPU		= 0x01,
    474	D71_BLK_TYPE_CU			= 0x02,
    475	D71_BLK_TYPE_DOU		= 0x03,
    476	D71_BLK_TYPE_AEU		= 0x04,
    477	D71_BLK_TYPE_GLB_LT_COEFF	= 0x05,
    478	D71_BLK_TYPE_GLB_SCL_COEFF	= 0x06, /* SH/SV scaler coeff */
    479	D71_BLK_TYPE_GLB_SC_COEFF	= 0x07,
    480	D71_BLK_TYPE_PERIPH		= 0x08,
    481	D71_BLK_TYPE_LPU_TRUSTED	= 0x09,
    482	D71_BLK_TYPE_AEU_TRUSTED	= 0x0A,
    483	D71_BLK_TYPE_LPU_LAYER		= 0x10,
    484	D71_BLK_TYPE_LPU_WB_LAYER	= 0x11,
    485	D71_BLK_TYPE_CU_SPLITTER	= 0x20,
    486	D71_BLK_TYPE_CU_SCALER		= 0x21,
    487	D71_BLK_TYPE_CU_MERGER		= 0x22,
    488	D71_BLK_TYPE_DOU_IPS		= 0x30,
    489	D71_BLK_TYPE_DOU_BS		= 0x31,
    490	D71_BLK_TYPE_DOU_FT_COEFF	= 0x32,
    491	D71_BLK_TYPE_AEU_DS		= 0x40,
    492	D71_BLK_TYPE_AEU_AES		= 0x41,
    493	D71_BLK_TYPE_RESERVED		= 0xFF
    494};
    495
    496/* Constant of components */
    497#define D71_MAX_PIPELINE		2
    498#define D71_PIPELINE_MAX_SCALERS	2
    499#define D71_PIPELINE_MAX_LAYERS		4
    500
    501#define D71_MAX_GLB_IT_COEFF		3
    502#define D71_MAX_GLB_SCL_COEFF		4
    503
    504#define D71_MAX_LAYERS_PER_LPU		4
    505#define D71_BLOCK_MAX_INPUT		9
    506#define D71_BLOCK_MAX_OUTPUT		5
    507#define D71_MAX_SC_PER_CU		2
    508
    509#define D71_BLOCK_OFFSET_PERIPH		0xFE00
    510#define D71_BLOCK_SIZE			0x0200
    511
    512#define D71_DEFAULT_PREPRETCH_LINE	5
    513#define D71_BUS_WIDTH_16_BYTES		16
    514
    515#define D71_SC_MAX_UPSCALING		64
    516#define D71_SC_MAX_DOWNSCALING		6
    517#define D71_SC_SPLIT_OVERLAP		8
    518#define D71_SC_ENH_SPLIT_OVERLAP	1
    519
    520#define D71_MG_MIN_MERGED_SIZE		4
    521#define D71_MG_MAX_MERGED_HSIZE		4032
    522#define D71_MG_MAX_MERGED_VSIZE		4096
    523
    524#define D71_PALPHA_DEF_MAP		0xFFAA5500
    525#define D71_LAYER_CONTROL_DEFAULT	0x30000000
    526#define D71_WB_LAYER_CONTROL_DEFAULT	0x3000FF00
    527#define D71_BS_CONTROL_DEFAULT		0x00000002
    528
    529struct block_header {
    530	u32 block_info;
    531	u32 pipeline_info;
    532	u32 input_ids[D71_BLOCK_MAX_INPUT];
    533	u32 output_ids[D71_BLOCK_MAX_OUTPUT];
    534};
    535
    536static inline u32 get_block_type(struct block_header *blk)
    537{
    538	return BLOCK_INFO_BLK_TYPE(blk->block_info);
    539}
    540
    541#endif /* !_D71_REG_H_ */