xref: /rk3399_ARM-atf/plat/xilinx/versal/sip_svc_setup.c (revision 4a50363aaeaa16edafcff17486006049b30e1e2f)
1f91c3cb1SSiva Durga Prasad Paladugu /*
20623dceaSAbhyuday Godhasara  * Copyright (c) 2018-2021, ARM Limited and Contributors. All rights reserved.
3f91c3cb1SSiva Durga Prasad Paladugu  *
4f91c3cb1SSiva Durga Prasad Paladugu  * SPDX-License-Identifier: BSD-3-Clause
5f91c3cb1SSiva Durga Prasad Paladugu  */
6f91c3cb1SSiva Durga Prasad Paladugu 
7f91c3cb1SSiva Durga Prasad Paladugu /* Top level SMC handler for SiP calls. Dispatch PM calls to PM SMC handler. */
8f91c3cb1SSiva Durga Prasad Paladugu 
9*4a50363aSMichal Simek #include <inttypes.h>
10*4a50363aSMichal Simek 
1109d40e0eSAntonio Nino Diaz #include <common/debug.h>
1209d40e0eSAntonio Nino Diaz #include <common/runtime_svc.h>
1309d40e0eSAntonio Nino Diaz #include <tools_share/uuid.h>
146e2f0d10SWendy Liang 
156e2f0d10SWendy Liang #include "ipi_mailbox_svc.h"
16c73a90e5STejas Patel #include "pm_svc_main.h"
17f91c3cb1SSiva Durga Prasad Paladugu 
18f91c3cb1SSiva Durga Prasad Paladugu /* SMC function IDs for SiP Service queries */
190623dceaSAbhyuday Godhasara #define VERSAL_SIP_SVC_CALL_COUNT	U(0x8200ff00)
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)
25b2bb3efbSAbhyuday Godhasara #define SIP_SVC_VERSION_MINOR	U(1)
26f91c3cb1SSiva Durga Prasad Paladugu 
27f91c3cb1SSiva Durga Prasad Paladugu /* These macros are used to identify PM calls from the SMC function ID */
28*4a50363aSMichal Simek #define SIP_FID_MASK	GENMASK(23, 16)
29*4a50363aSMichal Simek #define XLNX_FID_MASK	GENMASK(23, 12)
30f91c3cb1SSiva Durga Prasad Paladugu #define PM_FID_VALUE	0u
316e2f0d10SWendy Liang #define IPI_FID_VALUE	0x1000u
32*4a50363aSMichal Simek #define is_pm_fid(_fid) (((_fid) & XLNX_FID_MASK) == PM_FID_VALUE)
33*4a50363aSMichal 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  *
43f91c3cb1SSiva Durga Prasad Paladugu  * Invokes PM setup
44f91c3cb1SSiva Durga Prasad Paladugu  */
45f91c3cb1SSiva Durga Prasad Paladugu static int32_t sip_svc_setup(void)
46f91c3cb1SSiva Durga Prasad Paladugu {
47c73a90e5STejas Patel 	/* PM implementation as SiP Service */
48526a1fd1SAbhyuday Godhasara 	(void)pm_setup();
49c73a90e5STejas Patel 
50f91c3cb1SSiva Durga Prasad Paladugu 	return 0;
51f91c3cb1SSiva Durga Prasad Paladugu }
52f91c3cb1SSiva Durga Prasad Paladugu 
53f91c3cb1SSiva Durga Prasad Paladugu /**
54f91c3cb1SSiva Durga Prasad Paladugu  * sip_svc_smc_handler() - Top-level SiP Service SMC handler
55f91c3cb1SSiva Durga Prasad Paladugu  *
56f91c3cb1SSiva Durga Prasad Paladugu  * Handler for all SiP SMC calls. Handles standard SIP requests
57f91c3cb1SSiva Durga Prasad Paladugu  * and calls PM SMC handler if the call is for a PM-API function.
58f91c3cb1SSiva Durga Prasad Paladugu  */
59f91c3cb1SSiva Durga Prasad Paladugu uintptr_t sip_svc_smc_handler(uint32_t smc_fid,
60f91c3cb1SSiva Durga Prasad Paladugu 			     u_register_t x1,
61f91c3cb1SSiva Durga Prasad Paladugu 			     u_register_t x2,
62f91c3cb1SSiva Durga Prasad Paladugu 			     u_register_t x3,
63f91c3cb1SSiva Durga Prasad Paladugu 			     u_register_t x4,
64f91c3cb1SSiva Durga Prasad Paladugu 			     void *cookie,
65f91c3cb1SSiva Durga Prasad Paladugu 			     void *handle,
66f91c3cb1SSiva Durga Prasad Paladugu 			     u_register_t flags)
67f91c3cb1SSiva Durga Prasad Paladugu {
68*4a50363aSMichal Simek 	VERBOSE("SMCID: 0x%08x, x1: 0x%016" PRIx64 ", x2: 0x%016" PRIx64 ", x3: 0x%016" PRIx64 ", x4: 0x%016" PRIx64 "\n",
69*4a50363aSMichal Simek 		smc_fid, x1, x2, x3, x4);
70*4a50363aSMichal Simek 
71*4a50363aSMichal Simek 	if (smc_fid & SIP_FID_MASK) {
72*4a50363aSMichal Simek 		WARN("SMC out of SiP assinged range: 0x%x\n", smc_fid);
73*4a50363aSMichal Simek 		SMC_RET1(handle, SMC_UNK);
74*4a50363aSMichal Simek 	}
75*4a50363aSMichal Simek 
76f91c3cb1SSiva Durga Prasad Paladugu 	/* Let PM SMC handler deal with PM-related requests */
77ab43d15bSTejas Patel 	if (is_pm_fid(smc_fid)) {
78ab43d15bSTejas Patel 		return pm_smc_handler(smc_fid, x1, x2, x3, x4, cookie, handle,
79ab43d15bSTejas Patel 				      flags);
80ab43d15bSTejas Patel 	}
81ab43d15bSTejas Patel 
826e2f0d10SWendy Liang 	/* Let IPI SMC handler deal with IPI-related requests */
836e2f0d10SWendy Liang 	if (is_ipi_fid(smc_fid)) {
846e2f0d10SWendy Liang 		return ipi_smc_handler(smc_fid, x1, x2, x3, x4, cookie, handle,
856e2f0d10SWendy Liang 				      flags);
866e2f0d10SWendy Liang 	}
876e2f0d10SWendy Liang 
88ab43d15bSTejas Patel 	/* Let PM SMC handler deal with PM-related requests */
89f91c3cb1SSiva Durga Prasad Paladugu 	switch (smc_fid) {
90f91c3cb1SSiva Durga Prasad Paladugu 	case VERSAL_SIP_SVC_CALL_COUNT:
91f91c3cb1SSiva Durga Prasad Paladugu 		/* PM functions + default functions */
92f91c3cb1SSiva Durga Prasad Paladugu 		SMC_RET1(handle, 2);
93f91c3cb1SSiva Durga Prasad Paladugu 
94f91c3cb1SSiva Durga Prasad Paladugu 	case VERSAL_SIP_SVC_UID:
95f91c3cb1SSiva Durga Prasad Paladugu 		SMC_UUID_RET(handle, versal_sip_uuid);
96f91c3cb1SSiva Durga Prasad Paladugu 
97f91c3cb1SSiva Durga Prasad Paladugu 	case VERSAL_SIP_SVC_VERSION:
98f91c3cb1SSiva Durga Prasad Paladugu 		SMC_RET2(handle, SIP_SVC_VERSION_MAJOR, SIP_SVC_VERSION_MINOR);
99f91c3cb1SSiva Durga Prasad Paladugu 
100f91c3cb1SSiva Durga Prasad Paladugu 	default:
101f91c3cb1SSiva Durga Prasad Paladugu 		WARN("Unimplemented SiP Service Call: 0x%x\n", smc_fid);
102f91c3cb1SSiva Durga Prasad Paladugu 		SMC_RET1(handle, SMC_UNK);
103f91c3cb1SSiva Durga Prasad Paladugu 	}
104f91c3cb1SSiva Durga Prasad Paladugu }
105f91c3cb1SSiva Durga Prasad Paladugu 
106f91c3cb1SSiva Durga Prasad Paladugu /* Register PM Service Calls as runtime service */
107f91c3cb1SSiva Durga Prasad Paladugu DECLARE_RT_SVC(
108f91c3cb1SSiva Durga Prasad Paladugu 		sip_svc,
109f91c3cb1SSiva Durga Prasad Paladugu 		OEN_SIP_START,
110f91c3cb1SSiva Durga Prasad Paladugu 		OEN_SIP_END,
111f91c3cb1SSiva Durga Prasad Paladugu 		SMC_TYPE_FAST,
112f91c3cb1SSiva Durga Prasad Paladugu 		sip_svc_setup,
113f91c3cb1SSiva Durga Prasad Paladugu 		sip_svc_smc_handler);
114