1f91c3cb1SSiva Durga Prasad Paladugu /*
2619bc13eSMichal Simek * Copyright (c) 2018-2021, Arm Limited and Contributors. All rights reserved.
372eb16b7SDevanshi Chauhan Alpeshbhai * Copyright (c) 2022-2025, Advanced Micro Devices, Inc. All rights reserved.
4f91c3cb1SSiva Durga Prasad Paladugu *
5f91c3cb1SSiva Durga Prasad Paladugu * SPDX-License-Identifier: BSD-3-Clause
6f91c3cb1SSiva Durga Prasad Paladugu */
7f91c3cb1SSiva Durga Prasad Paladugu
8f91c3cb1SSiva Durga Prasad Paladugu /* Top level SMC handler for SiP calls. Dispatch PM calls to PM SMC handler. */
9f91c3cb1SSiva Durga Prasad Paladugu
104a50363aSMichal Simek #include <inttypes.h>
114a50363aSMichal Simek
1209d40e0eSAntonio Nino Diaz #include <common/debug.h>
1309d40e0eSAntonio Nino Diaz #include <common/runtime_svc.h>
1409d40e0eSAntonio Nino Diaz #include <tools_share/uuid.h>
156e2f0d10SWendy Liang
1672b9f52dSPrasad Kummari #include <custom_svc.h>
176e2f0d10SWendy Liang #include "ipi_mailbox_svc.h"
18c73a90e5STejas Patel #include "pm_svc_main.h"
19f91c3cb1SSiva Durga Prasad Paladugu
20f91c3cb1SSiva Durga Prasad Paladugu /* SMC function IDs for SiP Service queries */
211cbf6c4aSSaivardhan Thatikonda #define VERSAL_SIP_SVC_UID 0x8200ff01U
221cbf6c4aSSaivardhan Thatikonda #define VERSAL_SIP_SVC_VERSION 0x8200ff03U
23f91c3cb1SSiva Durga Prasad Paladugu
24f91c3cb1SSiva Durga Prasad Paladugu /* SiP Service Calls version numbers */
251cbf6c4aSSaivardhan Thatikonda #define SIP_SVC_VERSION_MAJOR 0U
261cbf6c4aSSaivardhan Thatikonda #define SIP_SVC_VERSION_MINOR 2U
27f91c3cb1SSiva Durga Prasad Paladugu
28f91c3cb1SSiva Durga Prasad Paladugu /* These macros are used to identify PM calls from the SMC function ID */
294a50363aSMichal Simek #define SIP_FID_MASK GENMASK(23, 16)
304a50363aSMichal Simek #define XLNX_FID_MASK GENMASK(23, 12)
311cbf6c4aSSaivardhan Thatikonda #define PM_FID_VALUE 0U
321cbf6c4aSSaivardhan Thatikonda #define IPI_FID_VALUE 0x1000U
334a50363aSMichal Simek #define is_pm_fid(_fid) (((_fid) & XLNX_FID_MASK) == PM_FID_VALUE)
344a50363aSMichal Simek #define is_ipi_fid(_fid) (((_fid) & XLNX_FID_MASK) == IPI_FID_VALUE)
35f91c3cb1SSiva Durga Prasad Paladugu
36f91c3cb1SSiva Durga Prasad Paladugu /* SiP Service UUID */
37f91c3cb1SSiva Durga Prasad Paladugu DEFINE_SVC_UUID2(versal_sip_uuid,
38b2bb3efbSAbhyuday Godhasara 0x2ab9e4ecU, 0x93b9U, 0x11e7U, 0xa0U, 0x19U,
39b2bb3efbSAbhyuday Godhasara 0xdfU, 0xe0U, 0xdbU, 0xadU, 0x0aU, 0xe0U);
40f91c3cb1SSiva Durga Prasad Paladugu
41f91c3cb1SSiva Durga Prasad Paladugu /**
42f91c3cb1SSiva Durga Prasad Paladugu * sip_svc_setup() - Setup SiP Service
43f91c3cb1SSiva Durga Prasad Paladugu *
44de7ed953SPrasad Kummari * Return: 0 on success,negative error code on failure.
45de7ed953SPrasad Kummari *
46de7ed953SPrasad Kummari * Invokes PM setup.
47f91c3cb1SSiva Durga Prasad Paladugu */
sip_svc_setup(void)48f91c3cb1SSiva Durga Prasad Paladugu static int32_t sip_svc_setup(void)
49f91c3cb1SSiva Durga Prasad Paladugu {
50c73a90e5STejas Patel /* PM implementation as SiP Service */
51526a1fd1SAbhyuday Godhasara (void)pm_setup();
52c73a90e5STejas Patel
53f91c3cb1SSiva Durga Prasad Paladugu return 0;
54f91c3cb1SSiva Durga Prasad Paladugu }
55f91c3cb1SSiva Durga Prasad Paladugu
56f91c3cb1SSiva Durga Prasad Paladugu /**
57de7ed953SPrasad Kummari * sip_svc_smc_handler() - Top-level SiP Service SMC handler.
58de7ed953SPrasad Kummari * @smc_fid: Function Identifier.
59de7ed953SPrasad Kummari * @x1: SMC64 Arguments 1 from kernel.
60de7ed953SPrasad Kummari * @x2: SMC64 Arguments 2 from kernel.
61de7ed953SPrasad Kummari * @x3: SMC64 Arguments 3 from kernel(upper 32-bits).
62de7ed953SPrasad Kummari * @x4: SMC64 Arguments 4 from kernel.
63de7ed953SPrasad Kummari * @cookie: Unused
64de7ed953SPrasad Kummari * @handle: Pointer to caller's context structure.
65*4fd510e0SRonak Jain * @flags: SECURE or NON_SECURE.
66f91c3cb1SSiva Durga Prasad Paladugu *
67f91c3cb1SSiva Durga Prasad Paladugu * Handler for all SiP SMC calls. Handles standard SIP requests
68f91c3cb1SSiva Durga Prasad Paladugu * and calls PM SMC handler if the call is for a PM-API function.
69de7ed953SPrasad Kummari *
70de7ed953SPrasad Kummari * Return: Unused.
71f91c3cb1SSiva Durga Prasad Paladugu */
sip_svc_smc_handler(uint32_t 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)7216c611f8SMaheedhar Bollapalli static uintptr_t sip_svc_smc_handler(uint32_t smc_fid,
73f91c3cb1SSiva Durga Prasad Paladugu u_register_t x1,
74f91c3cb1SSiva Durga Prasad Paladugu u_register_t x2,
75f91c3cb1SSiva Durga Prasad Paladugu u_register_t x3,
76f91c3cb1SSiva Durga Prasad Paladugu u_register_t x4,
77f91c3cb1SSiva Durga Prasad Paladugu void *cookie,
78f91c3cb1SSiva Durga Prasad Paladugu void *handle,
79f91c3cb1SSiva Durga Prasad Paladugu u_register_t flags)
80f91c3cb1SSiva Durga Prasad Paladugu {
814a50363aSMichal Simek VERBOSE("SMCID: 0x%08x, x1: 0x%016" PRIx64 ", x2: 0x%016" PRIx64 ", x3: 0x%016" PRIx64 ", x4: 0x%016" PRIx64 "\n",
824a50363aSMichal Simek smc_fid, x1, x2, x3, x4);
834a50363aSMichal Simek
8412475663SMaheedhar Bollapalli if ((smc_fid & SIP_FID_MASK) != 0U) {
854a50363aSMichal Simek WARN("SMC out of SiP assinged range: 0x%x\n", smc_fid);
864a50363aSMichal Simek SMC_RET1(handle, SMC_UNK);
874a50363aSMichal Simek }
884a50363aSMichal Simek
89f91c3cb1SSiva Durga Prasad Paladugu /* Let PM SMC handler deal with PM-related requests */
90ab43d15bSTejas Patel if (is_pm_fid(smc_fid)) {
91ab43d15bSTejas Patel return pm_smc_handler(smc_fid, x1, x2, x3, x4, cookie, handle,
92ab43d15bSTejas Patel flags);
93ab43d15bSTejas Patel }
94ab43d15bSTejas Patel
956e2f0d10SWendy Liang /* Let IPI SMC handler deal with IPI-related requests */
966e2f0d10SWendy Liang if (is_ipi_fid(smc_fid)) {
976e2f0d10SWendy Liang return ipi_smc_handler(smc_fid, x1, x2, x3, x4, cookie, handle,
986e2f0d10SWendy Liang flags);
996e2f0d10SWendy Liang }
1006e2f0d10SWendy Liang
101ab43d15bSTejas Patel /* Let PM SMC handler deal with PM-related requests */
102f91c3cb1SSiva Durga Prasad Paladugu switch (smc_fid) {
103f91c3cb1SSiva Durga Prasad Paladugu case VERSAL_SIP_SVC_UID:
104f91c3cb1SSiva Durga Prasad Paladugu SMC_UUID_RET(handle, versal_sip_uuid);
105f91c3cb1SSiva Durga Prasad Paladugu
106f91c3cb1SSiva Durga Prasad Paladugu case VERSAL_SIP_SVC_VERSION:
107f91c3cb1SSiva Durga Prasad Paladugu SMC_RET2(handle, SIP_SVC_VERSION_MAJOR, SIP_SVC_VERSION_MINOR);
108f91c3cb1SSiva Durga Prasad Paladugu
10972b9f52dSPrasad Kummari case SOC_SIP_SVC_CUSTOM:
11072b9f52dSPrasad Kummari case SOC_SIP_SVC64_CUSTOM:
11172b9f52dSPrasad Kummari return custom_smc_handler(smc_fid, x1, x2, x3, x4, cookie,
11272b9f52dSPrasad Kummari handle, flags);
11372b9f52dSPrasad Kummari
114f91c3cb1SSiva Durga Prasad Paladugu default:
115f91c3cb1SSiva Durga Prasad Paladugu WARN("Unimplemented SiP Service Call: 0x%x\n", smc_fid);
116f91c3cb1SSiva Durga Prasad Paladugu SMC_RET1(handle, SMC_UNK);
117f91c3cb1SSiva Durga Prasad Paladugu }
118f91c3cb1SSiva Durga Prasad Paladugu }
119f91c3cb1SSiva Durga Prasad Paladugu
120f91c3cb1SSiva Durga Prasad Paladugu /* Register PM Service Calls as runtime service */
121f91c3cb1SSiva Durga Prasad Paladugu DECLARE_RT_SVC(
122f91c3cb1SSiva Durga Prasad Paladugu sip_svc,
123f91c3cb1SSiva Durga Prasad Paladugu OEN_SIP_START,
124f91c3cb1SSiva Durga Prasad Paladugu OEN_SIP_END,
12572eb16b7SDevanshi Chauhan Alpeshbhai (uint8_t)SMC_TYPE_FAST,
126f91c3cb1SSiva Durga Prasad Paladugu sip_svc_setup,
127f91c3cb1SSiva Durga Prasad Paladugu sip_svc_smc_handler);
128