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