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