xref: /rk3399_ARM-atf/services/std_svc/rmmd/trp/trp_private.h (revision 6e5951c70a1b887e751151a3a49d9a48afad13e9)
1 /*
2  * Copyright (c) 2021-2022, Arm Limited and Contributors. All rights reserved.
3  *
4  * SPDX-License-Identifier: BSD-3-Clause
5  */
6 
7 #ifndef TRP_PRIVATE_H
8 #define TRP_PRIVATE_H
9 
10 #include <services/rmmd_svc.h>
11 #include <trp_helpers.h>
12 
13 /* Definitions for RMM-EL3 Interface ABI VERSION */
14 #define TRP_RMM_EL3_ABI_VERS_MAJOR	RMM_EL3_IFC_VERSION_MAJOR
15 #define TRP_RMM_EL3_ABI_VERS_MINOR	RMM_EL3_IFC_VERSION_MINOR
16 #define TRP_RMM_EL3_ABI_VERS	(((TRP_RMM_EL3_ABI_VERS_MAJOR & 0x7FFF) << 16) | \
17 				 (TRP_RMM_EL3_ABI_VERS_MINOR & 0xFFFF))
18 
19 #define TRP_PLATFORM_CORE_COUNT		PLATFORM_CORE_COUNT
20 
21 #ifndef __ASSEMBLER__
22 
23 #include <stdint.h>
24 
25 #define write_trp_arg(args, offset, val) (((args)->regs[offset >> 3])	\
26 					 = val)
27 /* RMI SMC64 FIDs handled by the TRP */
28 #define RMI_RMM_ACTIVATE			SMC64_RMI_FID(U(0xB2))
29 #define RMI_RMM_REQ_VERSION			SMC64_RMI_FID(U(0))
30 #define RMI_RMM_GRANULE_DELEGATE		SMC64_RMI_FID(U(1))
31 #define RMI_RMM_GRANULE_UNDELEGATE		SMC64_RMI_FID(U(2))
32 #define RMI_RMM_CONFIG_SET			SMC64_RMI_FID(U(0x1E))
33 #define RMI_RMM_CONFIG_GET			SMC64_RMI_FID(U(0x9C))
34 #define RMI_RMM_GRANULE_RANGE_DELEGATE		SMC64_RMI_FID(U(0xA1))
35 #define RMI_RMM_GRANULE_RANGE_UNDELEGATE	SMC64_RMI_FID(U(0xA2))
36 #define RMI_RMM_PDEV_CREATE			SMC64_RMI_FID(U(0x26))
37 
38 /* Definitions for RMI VERSION */
39 #define RMI_ABI_VERSION_MAJOR			U(0x0)
40 #define RMI_ABI_VERSION_MINOR			U(0x0)
41 #define RMI_ABI_VERSION				(((RMI_ABI_VERSION_MAJOR & 0x7FFF) \
42 								  << 16) | \
43 								  (RMI_ABI_VERSION_MINOR & 0xFFFF))
44 
45 #define TRP_RMM_EL3_VERSION_GET_MAJOR(x)		\
46 				RMM_EL3_IFC_VERSION_GET_MAJOR((x))
47 #define TRP_RMM_EL3_VERSION_GET_MINOR(x)		\
48 				RMM_EL3_IFC_VERSION_GET_MAJOR_MINOR((x))
49 
50 /* Helper to issue SMC calls to BL31 */
51 uint64_t trp_smc(trp_args_t *);
52 
53 /* The main function to executed only by Primary CPU */
54 void trp_main(void);
55 
56 /* Setup TRP. Executed only by Primary CPU */
57 void trp_setup(uint64_t x0,
58 	       uint64_t x1,
59 	       uint64_t x2,
60 	       uint64_t x3);
61 
62 /* Validate arguments for warm boot only */
63 int trp_validate_warmboot_args(uint64_t x0, uint64_t x1,
64 			       uint64_t x2, uint64_t x3);
65 
66 #endif /* __ASSEMBLER__ */
67 #endif /* TRP_PRIVATE_H */
68