xref: /rk3399_ARM-atf/services/std_svc/rmmd/trp/trp_private.h (revision 8c980a4a468aeabb9e49875fec395c625a0c2b2b)
150a3056aSZelalem Aweke /*
2319fb084SSoby Mathew  * Copyright (c) 2021-2022, Arm Limited and Contributors. All rights reserved.
350a3056aSZelalem Aweke  *
450a3056aSZelalem Aweke  * SPDX-License-Identifier: BSD-3-Clause
550a3056aSZelalem Aweke  */
650a3056aSZelalem Aweke 
750a3056aSZelalem Aweke #ifndef TRP_PRIVATE_H
850a3056aSZelalem Aweke #define TRP_PRIVATE_H
950a3056aSZelalem Aweke 
10*8c980a4aSJavier Almansa Sobrino #include <services/rmmd_svc.h>
11*8c980a4aSJavier Almansa Sobrino 
1250a3056aSZelalem Aweke /* Definitions to help the assembler access the SMC/ERET args structure */
1350a3056aSZelalem Aweke #define TRP_ARGS_SIZE		TRP_ARGS_END
1450a3056aSZelalem Aweke #define TRP_ARG0		0x0
1550a3056aSZelalem Aweke #define TRP_ARG1		0x8
1650a3056aSZelalem Aweke #define TRP_ARG2		0x10
1750a3056aSZelalem Aweke #define TRP_ARG3		0x18
1850a3056aSZelalem Aweke #define TRP_ARG4		0x20
1950a3056aSZelalem Aweke #define TRP_ARG5		0x28
2050a3056aSZelalem Aweke #define TRP_ARG6		0x30
2150a3056aSZelalem Aweke #define TRP_ARG7		0x38
2250a3056aSZelalem Aweke #define TRP_ARGS_END		0x40
2350a3056aSZelalem Aweke 
24*8c980a4aSJavier Almansa Sobrino /* Definitions for RMM-EL3 Interface ABI VERSION */
25*8c980a4aSJavier Almansa Sobrino #define TRP_RMM_EL3_ABI_VERS_MAJOR	RMM_EL3_IFC_VERSION_MAJOR
26*8c980a4aSJavier Almansa Sobrino #define TRP_RMM_EL3_ABI_VERS_MINOR	RMM_EL3_IFC_VERSION_MINOR
27*8c980a4aSJavier Almansa Sobrino #define TRP_RMM_EL3_ABI_VERS	(((TRP_RMM_EL3_ABI_VERS_MAJOR & 0x7FFF) << 16) | \
28*8c980a4aSJavier Almansa Sobrino 				 (TRP_RMM_EL3_ABI_VERS_MINOR & 0xFFFF))
29*8c980a4aSJavier Almansa Sobrino 
30*8c980a4aSJavier Almansa Sobrino #define TRP_PLATFORM_CORE_COUNT		PLATFORM_CORE_COUNT
31*8c980a4aSJavier Almansa Sobrino 
3250a3056aSZelalem Aweke #ifndef __ASSEMBLER__
3350a3056aSZelalem Aweke 
3450a3056aSZelalem Aweke #include <stdint.h>
3550a3056aSZelalem Aweke 
3650a3056aSZelalem Aweke /* Data structure to hold SMC arguments */
3750a3056aSZelalem Aweke typedef struct trp_args {
3850a3056aSZelalem Aweke 	uint64_t regs[TRP_ARGS_END >> 3];
3950a3056aSZelalem Aweke } __aligned(CACHE_WRITEBACK_GRANULE) trp_args_t;
4050a3056aSZelalem Aweke 
4150a3056aSZelalem Aweke #define write_trp_arg(args, offset, val) (((args)->regs[offset >> 3])	\
4250a3056aSZelalem Aweke 					 = val)
43fb00dc4aSSubhasish Ghosh /* RMI SMC64 FIDs handled by the TRP */
44fb00dc4aSSubhasish Ghosh #define RMI_RMM_REQ_VERSION		SMC64_RMI_FID(U(0))
45fb00dc4aSSubhasish Ghosh #define RMI_RMM_GRANULE_DELEGATE	SMC64_RMI_FID(U(1))
46fb00dc4aSSubhasish Ghosh #define RMI_RMM_GRANULE_UNDELEGATE	SMC64_RMI_FID(U(2))
47319fb084SSoby Mathew 
4850a3056aSZelalem Aweke /* Definitions for RMI VERSION */
4950a3056aSZelalem Aweke #define RMI_ABI_VERSION_MAJOR		U(0x0)
5050a3056aSZelalem Aweke #define RMI_ABI_VERSION_MINOR		U(0x0)
51*8c980a4aSJavier Almansa Sobrino #define RMI_ABI_VERSION			(((RMI_ABI_VERSION_MAJOR & 0x7FFF) \
52*8c980a4aSJavier Almansa Sobrino 								  << 16) | \
53*8c980a4aSJavier Almansa Sobrino 					 (RMI_ABI_VERSION_MINOR & 0xFFFF))
54*8c980a4aSJavier Almansa Sobrino 
55*8c980a4aSJavier Almansa Sobrino #define TRP_RMM_EL3_VERSION_GET_MAJOR(x)		\
56*8c980a4aSJavier Almansa Sobrino 				RMM_EL3_IFC_VERSION_GET_MAJOR((x))
57*8c980a4aSJavier Almansa Sobrino #define TRP_RMM_EL3_VERSION_GET_MINOR(x)		\
58*8c980a4aSJavier Almansa Sobrino 				RMM_EL3_IFC_VERSION_GET_MAJOR_MINOR((x))
5950a3056aSZelalem Aweke 
6050a3056aSZelalem Aweke /* Helper to issue SMC calls to BL31 */
6150a3056aSZelalem Aweke uint64_t trp_smc(trp_args_t *);
6250a3056aSZelalem Aweke 
6350a3056aSZelalem Aweke /* The main function to executed only by Primary CPU */
6450a3056aSZelalem Aweke void trp_main(void);
6550a3056aSZelalem Aweke 
6650a3056aSZelalem Aweke /* Setup TRP. Executed only by Primary CPU */
67*8c980a4aSJavier Almansa Sobrino void trp_setup(uint64_t x0,
68*8c980a4aSJavier Almansa Sobrino 	       uint64_t x1,
69*8c980a4aSJavier Almansa Sobrino 	       uint64_t x2,
70*8c980a4aSJavier Almansa Sobrino 	       uint64_t x3);
7150a3056aSZelalem Aweke 
7250a3056aSZelalem Aweke #endif /* __ASSEMBLER__ */
7350a3056aSZelalem Aweke #endif /* TRP_PRIVATE_H */
74