blob: ac7f53a81d93b5498431fc04f6921a54b7a5ae71 [file] [log] [blame]
Yatharth Kochar9518d022016-03-11 14:20:19 +00001/*
Govindraj Rajacd29ad52024-04-15 12:42:13 -05002 * Copyright (c) 2016-2024, Arm Limited and Contributors. All rights reserved.
Yatharth Kochar9518d022016-03-11 14:20:19 +00003 *
dp-armfa3cf0b2017-05-03 09:38:09 +01004 * SPDX-License-Identifier: BSD-3-Clause
Yatharth Kochar9518d022016-03-11 14:20:19 +00005 */
Antonio Nino Diaze0f90632018-12-14 00:18:21 +00006
Yatharth Kochar9518d022016-03-11 14:20:19 +00007#include <assert.h>
Antonio Nino Diaze0f90632018-12-14 00:18:21 +00008
9#include <common/debug.h>
10#include <lib/pmf/pmf.h>
11#include <plat/common/platform.h>
Antonio Nino Diaz3c817f42018-03-21 10:49:27 +000012#include <smccc_helpers.h>
Yatharth Kochar9518d022016-03-11 14:20:19 +000013
14/*
15 * This function is responsible for handling all PMF SMC calls.
16 */
17uintptr_t pmf_smc_handler(unsigned int smc_fid,
18 u_register_t x1,
19 u_register_t x2,
20 u_register_t x3,
21 u_register_t x4,
22 void *cookie,
23 void *handle,
24 u_register_t flags)
25{
26 int rc;
27 unsigned long long ts_value;
28
Manish Pandey0b1714f2023-10-27 11:45:44 +010029 /* Determine if the cpu exists of not */
30 if (!is_valid_mpidr(x2))
31 return PSCI_E_INVALID_PARAMS;
32
Yatharth Kochar9518d022016-03-11 14:20:19 +000033 if (((smc_fid >> FUNCID_CC_SHIFT) & FUNCID_CC_MASK) == SMC_32) {
34
35 x1 = (uint32_t)x1;
36 x2 = (uint32_t)x2;
37 x3 = (uint32_t)x3;
38
Govindraj Rajacd29ad52024-04-15 12:42:13 -050039 if (smc_fid == PMF_SMC_GET_TIMESTAMP_32 ||
40 smc_fid == PMF_SMC_GET_TIMESTAMP_32_DEP) {
Yatharth Kochar9518d022016-03-11 14:20:19 +000041 /*
42 * Return error code and the captured
43 * time-stamp to the caller.
44 * x0 --> error code.
45 * x1 - x2 --> time-stamp value.
46 */
Antonio Nino Diazbf170be2018-10-25 17:38:23 +010047 rc = pmf_get_timestamp_smc((unsigned int)x1, x2,
48 (unsigned int)x3, &ts_value);
Yatharth Kochar9518d022016-03-11 14:20:19 +000049 SMC_RET3(handle, rc, (uint32_t)ts_value,
50 (uint32_t)(ts_value >> 32));
Yatharth Kochar9518d022016-03-11 14:20:19 +000051 }
Govindraj Raja560537e2024-04-23 11:48:48 -050052
53 if (smc_fid == PMF_SMC_GET_VERSION_32) {
54 SMC_RET2(handle, SMC_OK, PMF_SMC_VERSION);
55 }
Yatharth Kochar9518d022016-03-11 14:20:19 +000056 } else {
Govindraj Rajacd29ad52024-04-15 12:42:13 -050057 if (smc_fid == PMF_SMC_GET_TIMESTAMP_64 ||
58 smc_fid == PMF_SMC_GET_TIMESTAMP_64_DEP) {
Yatharth Kochar9518d022016-03-11 14:20:19 +000059 /*
60 * Return error code and the captured
61 * time-stamp to the caller.
62 * x0 --> error code.
63 * x1 --> time-stamp value.
64 */
Antonio Nino Diazbf170be2018-10-25 17:38:23 +010065 rc = pmf_get_timestamp_smc((unsigned int)x1, x2,
66 (unsigned int)x3, &ts_value);
Yatharth Kochar9518d022016-03-11 14:20:19 +000067 SMC_RET2(handle, rc, ts_value);
Yatharth Kochar9518d022016-03-11 14:20:19 +000068 }
Govindraj Raja560537e2024-04-23 11:48:48 -050069
70 if (smc_fid == PMF_SMC_GET_VERSION_64) {
71 SMC_RET2(handle, SMC_OK, PMF_SMC_VERSION);
72 }
Yatharth Kochar9518d022016-03-11 14:20:19 +000073 }
74
75 WARN("Unimplemented PMF Call: 0x%x \n", smc_fid);
76 SMC_RET1(handle, SMC_UNK);
77}