xref: /rk3399_ARM-atf/include/services/trp/trp_helpers.h (revision 1d0ca40e9084903d21e570bb312646626aaf574b)
1*1d0ca40eSJavier Almansa Sobrino /*
2*1d0ca40eSJavier Almansa Sobrino  * Copyright (c) 2022, Arm Limited. All rights reserved.
3*1d0ca40eSJavier Almansa Sobrino  *
4*1d0ca40eSJavier Almansa Sobrino  * SPDX-License-Identifier: BSD-3-Clause
5*1d0ca40eSJavier Almansa Sobrino  */
6*1d0ca40eSJavier Almansa Sobrino 
7*1d0ca40eSJavier Almansa Sobrino #ifndef TRP_HELPERS_H
8*1d0ca40eSJavier Almansa Sobrino #define TRP_HELPERS_H
9*1d0ca40eSJavier Almansa Sobrino 
10*1d0ca40eSJavier Almansa Sobrino /* Definitions to help the assembler access the SMC/ERET args structure */
11*1d0ca40eSJavier Almansa Sobrino #define TRP_ARGS_SIZE		TRP_ARGS_END
12*1d0ca40eSJavier Almansa Sobrino #define TRP_ARG0		0x0
13*1d0ca40eSJavier Almansa Sobrino #define TRP_ARG1		0x8
14*1d0ca40eSJavier Almansa Sobrino #define TRP_ARG2		0x10
15*1d0ca40eSJavier Almansa Sobrino #define TRP_ARG3		0x18
16*1d0ca40eSJavier Almansa Sobrino #define TRP_ARG4		0x20
17*1d0ca40eSJavier Almansa Sobrino #define TRP_ARG5		0x28
18*1d0ca40eSJavier Almansa Sobrino #define TRP_ARG6		0x30
19*1d0ca40eSJavier Almansa Sobrino #define TRP_ARG7		0x38
20*1d0ca40eSJavier Almansa Sobrino #define TRP_ARGS_END		0x40
21*1d0ca40eSJavier Almansa Sobrino 
22*1d0ca40eSJavier Almansa Sobrino #ifndef __ASSEMBLER__
23*1d0ca40eSJavier Almansa Sobrino 
24*1d0ca40eSJavier Almansa Sobrino #include <platform_def.h>
25*1d0ca40eSJavier Almansa Sobrino 
26*1d0ca40eSJavier Almansa Sobrino /* Data structure to hold SMC arguments */
27*1d0ca40eSJavier Almansa Sobrino typedef struct trp_args {
28*1d0ca40eSJavier Almansa Sobrino 	uint64_t regs[TRP_ARGS_END >> 3];
29*1d0ca40eSJavier Almansa Sobrino } __aligned(CACHE_WRITEBACK_GRANULE) trp_args_t;
30*1d0ca40eSJavier Almansa Sobrino 
31*1d0ca40eSJavier Almansa Sobrino trp_args_t *set_smc_args(uint64_t arg0,
32*1d0ca40eSJavier Almansa Sobrino 			 uint64_t arg1,
33*1d0ca40eSJavier Almansa Sobrino 			 uint64_t arg2,
34*1d0ca40eSJavier Almansa Sobrino 			 uint64_t arg3,
35*1d0ca40eSJavier Almansa Sobrino 			 uint64_t arg4,
36*1d0ca40eSJavier Almansa Sobrino 			 uint64_t arg5,
37*1d0ca40eSJavier Almansa Sobrino 			 uint64_t arg6,
38*1d0ca40eSJavier Almansa Sobrino 			 uint64_t arg7);
39*1d0ca40eSJavier Almansa Sobrino 
40*1d0ca40eSJavier Almansa Sobrino __dead2 void trp_boot_abort(uint64_t err);
41*1d0ca40eSJavier Almansa Sobrino 
42*1d0ca40eSJavier Almansa Sobrino #endif /* __ASSEMBLER __ */
43*1d0ca40eSJavier Almansa Sobrino #endif /* TRP_HELPERS_H */
44