xref: /rk3399_ARM-atf/include/drivers/arm/cci.h (revision 82cb2c1ad9897473743f08437d0a3995bed561b9)
123e47edeSVikram Kanigiri /*
223e47edeSVikram Kanigiri  * Copyright (c) 2015, ARM Limited and Contributors. All rights reserved.
323e47edeSVikram Kanigiri  *
4*82cb2c1aSdp-arm  * SPDX-License-Identifier: BSD-3-Clause
523e47edeSVikram Kanigiri  */
623e47edeSVikram Kanigiri 
723e47edeSVikram Kanigiri #ifndef __CCI_H__
823e47edeSVikram Kanigiri #define __CCI_H__
923e47edeSVikram Kanigiri 
1023e47edeSVikram Kanigiri /* Slave interface offsets from PERIPHBASE */
1123e47edeSVikram Kanigiri #define SLAVE_IFACE6_OFFSET		0x7000
1223e47edeSVikram Kanigiri #define SLAVE_IFACE5_OFFSET		0x6000
1323e47edeSVikram Kanigiri #define SLAVE_IFACE4_OFFSET		0x5000
1423e47edeSVikram Kanigiri #define SLAVE_IFACE3_OFFSET		0x4000
1523e47edeSVikram Kanigiri #define SLAVE_IFACE2_OFFSET		0x3000
1623e47edeSVikram Kanigiri #define SLAVE_IFACE1_OFFSET		0x2000
1723e47edeSVikram Kanigiri #define SLAVE_IFACE0_OFFSET		0x1000
1823e47edeSVikram Kanigiri #define SLAVE_IFACE_OFFSET(index)	(SLAVE_IFACE0_OFFSET +	\
1923e47edeSVikram Kanigiri 					(0x1000 * (index)))
2023e47edeSVikram Kanigiri 
2123e47edeSVikram Kanigiri /* Slave interface event and count register offsets from PERIPHBASE */
2223e47edeSVikram Kanigiri #define EVENT_SELECT7_OFFSET		0x80000
2323e47edeSVikram Kanigiri #define EVENT_SELECT6_OFFSET		0x70000
2423e47edeSVikram Kanigiri #define EVENT_SELECT5_OFFSET		0x60000
2523e47edeSVikram Kanigiri #define EVENT_SELECT4_OFFSET		0x50000
2623e47edeSVikram Kanigiri #define EVENT_SELECT3_OFFSET		0x40000
2723e47edeSVikram Kanigiri #define EVENT_SELECT2_OFFSET		0x30000
2823e47edeSVikram Kanigiri #define EVENT_SELECT1_OFFSET		0x20000
2923e47edeSVikram Kanigiri #define EVENT_SELECT0_OFFSET		0x10000
3023e47edeSVikram Kanigiri #define EVENT_OFFSET(index)		(EVENT_SELECT0_OFFSET +	\
3123e47edeSVikram Kanigiri 					(0x10000 * (index)))
3223e47edeSVikram Kanigiri 
3323e47edeSVikram Kanigiri /* Control and ID register offsets */
3423e47edeSVikram Kanigiri #define CTRL_OVERRIDE_REG		0x0
3523e47edeSVikram Kanigiri #define SECURE_ACCESS_REG		0x8
3623e47edeSVikram Kanigiri #define STATUS_REG			0xc
3723e47edeSVikram Kanigiri #define IMPRECISE_ERR_REG		0x10
3823e47edeSVikram Kanigiri #define PERFMON_CTRL_REG		0x100
3923e47edeSVikram Kanigiri #define IFACE_MON_CTRL_REG		0x104
4023e47edeSVikram Kanigiri 
4123e47edeSVikram Kanigiri /* Component and peripheral ID registers */
4223e47edeSVikram Kanigiri #define PERIPHERAL_ID0			0xFE0
4323e47edeSVikram Kanigiri #define PERIPHERAL_ID1			0xFE4
4423e47edeSVikram Kanigiri #define PERIPHERAL_ID2			0xFE8
4523e47edeSVikram Kanigiri #define PERIPHERAL_ID3			0xFEC
4623e47edeSVikram Kanigiri #define PERIPHERAL_ID4			0xFD0
4723e47edeSVikram Kanigiri #define PERIPHERAL_ID5			0xFD4
4823e47edeSVikram Kanigiri #define PERIPHERAL_ID6			0xFD8
4923e47edeSVikram Kanigiri #define PERIPHERAL_ID7			0xFDC
5023e47edeSVikram Kanigiri 
5123e47edeSVikram Kanigiri #define COMPONENT_ID0			0xFF0
5223e47edeSVikram Kanigiri #define COMPONENT_ID1			0xFF4
5323e47edeSVikram Kanigiri #define COMPONENT_ID2			0xFF8
5423e47edeSVikram Kanigiri #define COMPONENT_ID3			0xFFC
5523e47edeSVikram Kanigiri #define COMPONENT_ID4			0x1000
5623e47edeSVikram Kanigiri #define COMPONENT_ID5			0x1004
5723e47edeSVikram Kanigiri #define COMPONENT_ID6			0x1008
5823e47edeSVikram Kanigiri #define COMPONENT_ID7			0x100C
5923e47edeSVikram Kanigiri 
6023e47edeSVikram Kanigiri /* Slave interface register offsets */
6123e47edeSVikram Kanigiri #define SNOOP_CTRL_REG			0x0
6223e47edeSVikram Kanigiri #define SH_OVERRIDE_REG			0x4
6323e47edeSVikram Kanigiri #define READ_CHNL_QOS_VAL_OVERRIDE_REG	0x100
6423e47edeSVikram Kanigiri #define WRITE_CHNL_QOS_VAL_OVERRIDE_REG	0x104
6523e47edeSVikram Kanigiri #define MAX_OT_REG			0x110
6623e47edeSVikram Kanigiri 
6723e47edeSVikram Kanigiri /* Snoop Control register bit definitions */
6823e47edeSVikram Kanigiri #define DVM_EN_BIT			(1 << 1)
6923e47edeSVikram Kanigiri #define SNOOP_EN_BIT			(1 << 0)
7023e47edeSVikram Kanigiri #define SUPPORT_SNOOPS			(1 << 30)
7123e47edeSVikram Kanigiri #define SUPPORT_DVM			(1 << 31)
7223e47edeSVikram Kanigiri 
7323e47edeSVikram Kanigiri /* Status register bit definitions */
7423e47edeSVikram Kanigiri #define CHANGE_PENDING_BIT		(1 << 0)
7523e47edeSVikram Kanigiri 
7623e47edeSVikram Kanigiri /* Event and count register offsets */
7723e47edeSVikram Kanigiri #define EVENT_SELECT_REG		0x0
7823e47edeSVikram Kanigiri #define EVENT_COUNT_REG			0x4
7923e47edeSVikram Kanigiri #define COUNT_CNTRL_REG			0x8
8023e47edeSVikram Kanigiri #define COUNT_OVERFLOW_REG		0xC
8123e47edeSVikram Kanigiri 
8223e47edeSVikram Kanigiri /* Slave interface monitor registers */
8323e47edeSVikram Kanigiri #define INT_MON_REG_SI0			0x90000
8423e47edeSVikram Kanigiri #define INT_MON_REG_SI1			0x90004
8523e47edeSVikram Kanigiri #define INT_MON_REG_SI2			0x90008
8623e47edeSVikram Kanigiri #define INT_MON_REG_SI3			0x9000C
8723e47edeSVikram Kanigiri #define INT_MON_REG_SI4			0x90010
8823e47edeSVikram Kanigiri #define INT_MON_REG_SI5			0x90014
8923e47edeSVikram Kanigiri #define INT_MON_REG_SI6			0x90018
9023e47edeSVikram Kanigiri 
9123e47edeSVikram Kanigiri /* Master interface monitor registers */
9223e47edeSVikram Kanigiri #define INT_MON_REG_MI0			0x90100
9323e47edeSVikram Kanigiri #define INT_MON_REG_MI1			0x90104
9423e47edeSVikram Kanigiri #define INT_MON_REG_MI2			0x90108
9523e47edeSVikram Kanigiri #define INT_MON_REG_MI3			0x9010c
9623e47edeSVikram Kanigiri #define INT_MON_REG_MI4			0x90110
9723e47edeSVikram Kanigiri #define INT_MON_REG_MI5			0x90114
9823e47edeSVikram Kanigiri 
9923e47edeSVikram Kanigiri #define SLAVE_IF_UNUSED			-1
10023e47edeSVikram Kanigiri 
10123e47edeSVikram Kanigiri #if ARM_CCI_PRODUCT_ID == 400
10223e47edeSVikram Kanigiri 	#define CCI_SLAVE_INTERFACE_COUNT	5
10323e47edeSVikram Kanigiri #elif ARM_CCI_PRODUCT_ID == 500
10423e47edeSVikram Kanigiri 	#define CCI_SLAVE_INTERFACE_COUNT	7
10523e47edeSVikram Kanigiri #else
10623e47edeSVikram Kanigiri 	#error "Invalid CCI product or CCI not supported"
10723e47edeSVikram Kanigiri #endif
10823e47edeSVikram Kanigiri 
10923e47edeSVikram Kanigiri #ifndef __ASSEMBLY__
11023e47edeSVikram Kanigiri 
11123e47edeSVikram Kanigiri #include <stdint.h>
11223e47edeSVikram Kanigiri 
11323e47edeSVikram Kanigiri /* Function declarations */
11423e47edeSVikram Kanigiri 
11523e47edeSVikram Kanigiri /*
11623e47edeSVikram Kanigiri  * The ARM CCI driver needs the following:
11723e47edeSVikram Kanigiri  * 1. Base address of the CCI-500/CCI-400
11823e47edeSVikram Kanigiri  * 2. An array  of map between AMBA 4 master ids and ACE/ACE lite slave
11923e47edeSVikram Kanigiri  *    interfaces.
12023e47edeSVikram Kanigiri  * 3. Size of the array.
12123e47edeSVikram Kanigiri  *
12223e47edeSVikram Kanigiri  * SLAVE_IF_UNUSED should be used in the map to represent no AMBA 4 master exists
12323e47edeSVikram Kanigiri  * for that interface.
12423e47edeSVikram Kanigiri  */
12502462972SJuan Castillo void cci_init(uintptr_t cci_base,
12623e47edeSVikram Kanigiri 	const int *map,
12723e47edeSVikram Kanigiri 	unsigned int num_cci_masters);
12823e47edeSVikram Kanigiri 
12923e47edeSVikram Kanigiri void cci_enable_snoop_dvm_reqs(unsigned int master_id);
13023e47edeSVikram Kanigiri void cci_disable_snoop_dvm_reqs(unsigned int master_id);
13123e47edeSVikram Kanigiri 
13223e47edeSVikram Kanigiri #endif /* __ASSEMBLY__ */
13323e47edeSVikram Kanigiri #endif /* __CCI_H__ */
134