blob: 6e5544dc9ccc745b2c8e7fdce15d07f18ac8d10c [file] [log] [blame]
Yann Gautiera42bad32019-01-17 14:51:25 +01001/*
Yann Gautier39b08bc2022-10-27 17:52:41 +02002 * Copyright (c) 2014-2024, STMicroelectronics - All Rights Reserved
Yann Gautiera42bad32019-01-17 14:51:25 +01003 *
4 * SPDX-License-Identifier: BSD-3-Clause
5 */
6
7#include <stdbool.h>
8#include <stdint.h>
9
10#include <common/debug.h>
11#include <common/runtime_svc.h>
Peng Fanb4734302021-01-20 11:04:08 +080012#include <drivers/scmi-msg.h>
Yann Gautiera42bad32019-01-17 14:51:25 +010013#include <lib/psci/psci.h>
14#include <tools_share/uuid.h>
15
16#include <stm32mp1_smc.h>
Yann Gautier39b08bc2022-10-27 17:52:41 +020017#include <stm32mp_svc_setup.h>
Yann Gautiera42bad32019-01-17 14:51:25 +010018
Yann Gautierc7ba52d2019-01-17 14:53:24 +010019#include "bsec_svc.h"
20
Yann Gautiera42bad32019-01-17 14:51:25 +010021/*
Yann Gautier39b08bc2022-10-27 17:52:41 +020022 * Platform Standard Service SMC handler. This handler will dispatch
23 * calls to features handlers.
Yann Gautiera42bad32019-01-17 14:51:25 +010024 */
Yann Gautier39b08bc2022-10-27 17:52:41 +020025void plat_svc_smc_handler(uint32_t smc_fid, u_register_t x1,
26 u_register_t x2, u_register_t x3,
27 u_register_t x4, uint32_t *ret1,
28 uint32_t *ret2, bool *ret2_enabled,
29 u_register_t flags)
Yann Gautiera42bad32019-01-17 14:51:25 +010030{
Yann Gautiera42bad32019-01-17 14:51:25 +010031 switch (smc_fid) {
32 case STM32_SIP_SVC_CALL_COUNT:
Yann Gautier39b08bc2022-10-27 17:52:41 +020033 *ret1 = STM32_COMMON_SIP_NUM_CALLS;
Yann Gautiera42bad32019-01-17 14:51:25 +010034 break;
Yann Gautierc7ba52d2019-01-17 14:53:24 +010035 case STM32_SMC_BSEC:
Yann Gautier39b08bc2022-10-27 17:52:41 +020036 *ret1 = bsec_main(x1, x2, x3, ret2);
37 *ret2_enabled = true;
Yann Gautierc7ba52d2019-01-17 14:53:24 +010038 break;
39
Etienne Carrierefdaaaeb2020-07-16 17:36:18 +020040 case STM32_SIP_SMC_SCMI_AGENT0:
41 scmi_smt_fastcall_smc_entry(0);
42 break;
43 case STM32_SIP_SMC_SCMI_AGENT1:
44 scmi_smt_fastcall_smc_entry(1);
45 break;
46
Yann Gautiera42bad32019-01-17 14:51:25 +010047 default:
48 WARN("Unimplemented STM32MP1 Service Call: 0x%x\n", smc_fid);
Yann Gautier39b08bc2022-10-27 17:52:41 +020049 *ret1 = STM32_SMC_NOT_SUPPORTED;
Yann Gautiera42bad32019-01-17 14:51:25 +010050 break;
51 }
Yann Gautiera42bad32019-01-17 14:51:25 +010052}