xref: /rk3399_ARM-atf/plat/xilinx/versal/sip_svc_setup.c (revision 16c611f8a6f6a6669265fda95115a0ade56078e7)
1f91c3cb1SSiva Durga Prasad Paladugu /*
2619bc13eSMichal Simek  * Copyright (c) 2018-2021, Arm Limited and Contributors. All rights reserved.
3c26aa08bSJay Buddhabhatti  * Copyright (c) 2022-2024, 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 
166e2f0d10SWendy Liang #include "ipi_mailbox_svc.h"
17c73a90e5STejas Patel #include "pm_svc_main.h"
18f91c3cb1SSiva Durga Prasad Paladugu 
19f91c3cb1SSiva Durga Prasad Paladugu /* SMC function IDs for SiP Service queries */
200623dceaSAbhyuday Godhasara #define VERSAL_SIP_SVC_UID		U(0x8200ff01)
210623dceaSAbhyuday Godhasara #define VERSAL_SIP_SVC_VERSION		U(0x8200ff03)
22f91c3cb1SSiva Durga Prasad Paladugu 
23f91c3cb1SSiva Durga Prasad Paladugu /* SiP Service Calls version numbers */
24b2bb3efbSAbhyuday Godhasara #define SIP_SVC_VERSION_MAJOR	U(0)
25c26aa08bSJay Buddhabhatti #define SIP_SVC_VERSION_MINOR	U(2)
26f91c3cb1SSiva Durga Prasad Paladugu 
27f91c3cb1SSiva Durga Prasad Paladugu /* These macros are used to identify PM calls from the SMC function ID */
284a50363aSMichal Simek #define SIP_FID_MASK	GENMASK(23, 16)
294a50363aSMichal Simek #define XLNX_FID_MASK	GENMASK(23, 12)
30f91c3cb1SSiva Durga Prasad Paladugu #define PM_FID_VALUE	0u
316e2f0d10SWendy Liang #define IPI_FID_VALUE	0x1000u
324a50363aSMichal Simek #define is_pm_fid(_fid) (((_fid) & XLNX_FID_MASK) == PM_FID_VALUE)
334a50363aSMichal Simek #define is_ipi_fid(_fid) (((_fid) & XLNX_FID_MASK) == IPI_FID_VALUE)
34f91c3cb1SSiva Durga Prasad Paladugu 
35f91c3cb1SSiva Durga Prasad Paladugu /* SiP Service UUID */
36f91c3cb1SSiva Durga Prasad Paladugu DEFINE_SVC_UUID2(versal_sip_uuid,
37b2bb3efbSAbhyuday Godhasara 		0x2ab9e4ecU, 0x93b9U, 0x11e7U, 0xa0U, 0x19U,
38b2bb3efbSAbhyuday Godhasara 		0xdfU, 0xe0U, 0xdbU, 0xadU, 0x0aU, 0xe0U);
39f91c3cb1SSiva Durga Prasad Paladugu 
40f91c3cb1SSiva Durga Prasad Paladugu /**
41f91c3cb1SSiva Durga Prasad Paladugu  * sip_svc_setup() - Setup SiP Service
42f91c3cb1SSiva Durga Prasad Paladugu  *
43de7ed953SPrasad Kummari  * Return: 0 on success,negative error code on failure.
44de7ed953SPrasad Kummari  *
45de7ed953SPrasad Kummari  * Invokes PM setup.
46f91c3cb1SSiva Durga Prasad Paladugu  */
47f91c3cb1SSiva Durga Prasad Paladugu static int32_t sip_svc_setup(void)
48f91c3cb1SSiva Durga Prasad Paladugu {
49c73a90e5STejas Patel 	/* PM implementation as SiP Service */
50526a1fd1SAbhyuday Godhasara 	(void)pm_setup();
51c73a90e5STejas Patel 
52f91c3cb1SSiva Durga Prasad Paladugu 	return 0;
53f91c3cb1SSiva Durga Prasad Paladugu }
54f91c3cb1SSiva Durga Prasad Paladugu 
55f91c3cb1SSiva Durga Prasad Paladugu /**
56de7ed953SPrasad Kummari  * sip_svc_smc_handler() - Top-level SiP Service SMC handler.
57de7ed953SPrasad Kummari  * @smc_fid: Function Identifier.
58de7ed953SPrasad Kummari  * @x1: SMC64 Arguments 1 from kernel.
59de7ed953SPrasad Kummari  * @x2: SMC64 Arguments 2 from kernel.
60de7ed953SPrasad Kummari  * @x3: SMC64 Arguments 3 from kernel(upper 32-bits).
61de7ed953SPrasad Kummari  * @x4: SMC64 Arguments 4 from kernel.
62de7ed953SPrasad Kummari  * @cookie: Unused
63de7ed953SPrasad Kummari  * @handle: Pointer to caller's context structure.
64de7ed953SPrasad Kummari  * @flags: SECURE_FLAG or NON_SECURE_FLAG.
65f91c3cb1SSiva Durga Prasad Paladugu  *
66f91c3cb1SSiva Durga Prasad Paladugu  * Handler for all SiP SMC calls. Handles standard SIP requests
67f91c3cb1SSiva Durga Prasad Paladugu  * and calls PM SMC handler if the call is for a PM-API function.
68de7ed953SPrasad Kummari  *
69de7ed953SPrasad Kummari  * Return: Unused.
70f91c3cb1SSiva Durga Prasad Paladugu  */
71*16c611f8SMaheedhar Bollapalli static uintptr_t sip_svc_smc_handler(uint32_t smc_fid,
72f91c3cb1SSiva Durga Prasad Paladugu 				u_register_t x1,
73f91c3cb1SSiva Durga Prasad Paladugu 				u_register_t x2,
74f91c3cb1SSiva Durga Prasad Paladugu 				u_register_t x3,
75f91c3cb1SSiva Durga Prasad Paladugu 				u_register_t x4,
76f91c3cb1SSiva Durga Prasad Paladugu 				void *cookie,
77f91c3cb1SSiva Durga Prasad Paladugu 				void *handle,
78f91c3cb1SSiva Durga Prasad Paladugu 				u_register_t flags)
79f91c3cb1SSiva Durga Prasad Paladugu {
804a50363aSMichal Simek 	VERBOSE("SMCID: 0x%08x, x1: 0x%016" PRIx64 ", x2: 0x%016" PRIx64 ", x3: 0x%016" PRIx64 ", x4: 0x%016" PRIx64 "\n",
814a50363aSMichal Simek 		smc_fid, x1, x2, x3, x4);
824a50363aSMichal Simek 
8312475663SMaheedhar Bollapalli 	if ((smc_fid & SIP_FID_MASK) != 0U) {
844a50363aSMichal Simek 		WARN("SMC out of SiP assinged range: 0x%x\n", smc_fid);
854a50363aSMichal Simek 		SMC_RET1(handle, SMC_UNK);
864a50363aSMichal Simek 	}
874a50363aSMichal Simek 
88f91c3cb1SSiva Durga Prasad Paladugu 	/* Let PM SMC handler deal with PM-related requests */
89ab43d15bSTejas Patel 	if (is_pm_fid(smc_fid)) {
90ab43d15bSTejas Patel 		return pm_smc_handler(smc_fid, x1, x2, x3, x4, cookie, handle,
91ab43d15bSTejas Patel 				      flags);
92ab43d15bSTejas Patel 	}
93ab43d15bSTejas Patel 
946e2f0d10SWendy Liang 	/* Let IPI SMC handler deal with IPI-related requests */
956e2f0d10SWendy Liang 	if (is_ipi_fid(smc_fid)) {
966e2f0d10SWendy Liang 		return ipi_smc_handler(smc_fid, x1, x2, x3, x4, cookie, handle,
976e2f0d10SWendy Liang 				      flags);
986e2f0d10SWendy Liang 	}
996e2f0d10SWendy Liang 
100ab43d15bSTejas Patel 	/* Let PM SMC handler deal with PM-related requests */
101f91c3cb1SSiva Durga Prasad Paladugu 	switch (smc_fid) {
102f91c3cb1SSiva Durga Prasad Paladugu 	case VERSAL_SIP_SVC_UID:
103f91c3cb1SSiva Durga Prasad Paladugu 		SMC_UUID_RET(handle, versal_sip_uuid);
104f91c3cb1SSiva Durga Prasad Paladugu 
105f91c3cb1SSiva Durga Prasad Paladugu 	case VERSAL_SIP_SVC_VERSION:
106f91c3cb1SSiva Durga Prasad Paladugu 		SMC_RET2(handle, SIP_SVC_VERSION_MAJOR, SIP_SVC_VERSION_MINOR);
107f91c3cb1SSiva Durga Prasad Paladugu 
108f91c3cb1SSiva Durga Prasad Paladugu 	default:
109f91c3cb1SSiva Durga Prasad Paladugu 		WARN("Unimplemented SiP Service Call: 0x%x\n", smc_fid);
110f91c3cb1SSiva Durga Prasad Paladugu 		SMC_RET1(handle, SMC_UNK);
111f91c3cb1SSiva Durga Prasad Paladugu 	}
112f91c3cb1SSiva Durga Prasad Paladugu }
113f91c3cb1SSiva Durga Prasad Paladugu 
114f91c3cb1SSiva Durga Prasad Paladugu /* Register PM Service Calls as runtime service */
115f91c3cb1SSiva Durga Prasad Paladugu DECLARE_RT_SVC(
116f91c3cb1SSiva Durga Prasad Paladugu 		sip_svc,
117f91c3cb1SSiva Durga Prasad Paladugu 		OEN_SIP_START,
118f91c3cb1SSiva Durga Prasad Paladugu 		OEN_SIP_END,
119f91c3cb1SSiva Durga Prasad Paladugu 		SMC_TYPE_FAST,
120f91c3cb1SSiva Durga Prasad Paladugu 		sip_svc_setup,
121f91c3cb1SSiva Durga Prasad Paladugu 		sip_svc_smc_handler);
122