xref: /rk3399_ARM-atf/plat/xilinx/versal/sip_svc_setup.c (revision 0c0b19f42de25bb75760d6cca02c325c08a33882)
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