mirror of
https://github.com/ARM-software/arm-trusted-firmware.git
synced 2025-04-16 09:34:18 +00:00

Commit@f7679d437d5f27a3168f017db8d42bc561ac0c59 PMF is moved under vendor specific EL3 range, part of this we have introduced each sub-service have an version scheme[1]. - Current PMF is not handling correctly identifying all FID's under it so handle this correctly. - Minor refactor to use existing macro GET_SMC_NUM rather than manual parsing to find the SMC number. [1]: https://trustedfirmware-a.readthedocs.io/en/latest/components/ven-el3-service.html Change-Id: I7a4c8936e42d4a579f0243fa3d06015540caca37 Signed-off-by: Govindraj Raja <govindraj.raja@arm.com>
92 lines
2.4 KiB
C
92 lines
2.4 KiB
C
/*
|
|
* Copyright (c) 2016-2024, Arm Limited and Contributors. All rights reserved.
|
|
*
|
|
* SPDX-License-Identifier: BSD-3-Clause
|
|
*/
|
|
|
|
#ifndef PMF_H
|
|
#define PMF_H
|
|
|
|
#include <lib/cassert.h>
|
|
#include <lib/pmf/pmf_helpers.h>
|
|
#include <lib/utils_def.h>
|
|
|
|
/*
|
|
* Constants used for/by PMF services.
|
|
*/
|
|
#define PMF_ARM_TIF_IMPL_ID UL(0x41)
|
|
#define PMF_TID_SHIFT 0
|
|
#define PMF_TID_MASK (UL(0xFF) << PMF_TID_SHIFT)
|
|
#define PMF_SVC_ID_SHIFT 10
|
|
#define PMF_SVC_ID_MASK (UL(0x3F) << PMF_SVC_ID_SHIFT)
|
|
#define PMF_IMPL_ID_SHIFT 24
|
|
#define PMF_IMPL_ID_MASK (UL(0xFF) << PMF_IMPL_ID_SHIFT)
|
|
|
|
/*
|
|
* Flags passed to PMF_REGISTER_SERVICE
|
|
*/
|
|
#define PMF_STORE_ENABLE (1 << 0)
|
|
#define PMF_DUMP_ENABLE (1 << 1)
|
|
|
|
/*
|
|
* Flags passed to PMF_GET_TIMESTAMP_XXX
|
|
* and PMF_CAPTURE_TIMESTAMP
|
|
*/
|
|
#define PMF_CACHE_MAINT (U(1) << 0)
|
|
#define PMF_NO_CACHE_MAINT U(0)
|
|
|
|
/*
|
|
* Defines for PMF SMC function ids used with arm-sip
|
|
* range, this is now deprecated and will be removed.
|
|
*/
|
|
#define PMF_SMC_GET_TIMESTAMP_32_DEP U(0x82000010)
|
|
#define PMF_SMC_GET_TIMESTAMP_64_DEP U(0xC2000010)
|
|
|
|
#define PMF_FID_VALUE_DEPRECATED U(0x10)
|
|
#define is_pmf_fid_deprecated(_fid) \
|
|
(GET_SMC_NUM(_fid) == PMF_FID_VALUE_DEPRECATED)
|
|
|
|
/*
|
|
* Defines for PMF SMC function ids used with Vendor-Specific
|
|
* EL3 range.
|
|
*/
|
|
#define PMF_SMC_GET_TIMESTAMP_32 U(0x87000020)
|
|
#define PMF_SMC_GET_TIMESTAMP_64 U(0xC7000020)
|
|
#define PMF_NUM_SMC_CALLS 2
|
|
|
|
#define PMF_SMC_GET_VERSION_32 U(0x87000021)
|
|
#define PMF_SMC_GET_VERSION_64 U(0xC7000021)
|
|
|
|
#define PMF_SMC_VERSION U(0x00000001)
|
|
|
|
/*
|
|
* The macros below are used to identify
|
|
* PMF calls from the SMC function ID.
|
|
*/
|
|
#define PMF_FID_VALUE U(0x20)
|
|
#define PMF_ID_MASK (FUNCID_NUM_MASK & ~(0xf))
|
|
#define is_pmf_fid(_fid) ((GET_SMC_NUM(_fid) & PMF_ID_MASK) == PMF_FID_VALUE)
|
|
|
|
/* Following are the supported PMF service IDs */
|
|
#define PMF_PSCI_STAT_SVC_ID 0
|
|
#define PMF_RT_INSTR_SVC_ID 1
|
|
|
|
/*******************************************************************************
|
|
* Function & variable prototypes
|
|
******************************************************************************/
|
|
/* PMF common functions */
|
|
int pmf_get_timestamp_smc(unsigned int tid,
|
|
u_register_t mpidr,
|
|
unsigned int flags,
|
|
unsigned long long *ts_value);
|
|
int pmf_setup(void);
|
|
uintptr_t pmf_smc_handler(unsigned int smc_fid,
|
|
u_register_t x1,
|
|
u_register_t x2,
|
|
u_register_t x3,
|
|
u_register_t x4,
|
|
void *cookie,
|
|
void *handle,
|
|
u_register_t flags);
|
|
|
|
#endif /* PMF_H */
|