152430916SChungying Lu /*
252430916SChungying Lu * Copyright (c) 2023, MediaTek Inc. All rights reserved.
352430916SChungying Lu *
452430916SChungying Lu * SPDX-License-Identifier: BSD-3-Clause
552430916SChungying Lu */
652430916SChungying Lu
752430916SChungying Lu /* TF-A system header */
852430916SChungying Lu #include <common/debug.h>
952430916SChungying Lu
1052430916SChungying Lu /* Vendor header */
1152430916SChungying Lu #include "apusys.h"
12777e3b71SKarl Li #include "apusys_devapc.h"
1352430916SChungying Lu #include "apusys_power.h"
14ad7673adSKarl Li #include "apusys_rv.h"
15b5900c92SKarl Li #include "apusys_security_ctrl_plat.h"
1652430916SChungying Lu #include <lib/mtk_init/mtk_init.h>
178e38b928SChungying Lu #include <mtk_sip_svc.h>
188e38b928SChungying Lu
apusys_kernel_handler(u_register_t x1,u_register_t x2,u_register_t x3,u_register_t x4,void * handle,struct smccc_res * smccc_ret)198e38b928SChungying Lu static u_register_t apusys_kernel_handler(u_register_t x1,
208e38b928SChungying Lu u_register_t x2,
218e38b928SChungying Lu u_register_t x3,
228e38b928SChungying Lu u_register_t x4,
238e38b928SChungying Lu void *handle,
248e38b928SChungying Lu struct smccc_res *smccc_ret)
258e38b928SChungying Lu {
268e38b928SChungying Lu uint32_t request_ops;
278e38b928SChungying Lu int32_t ret = -1;
288e38b928SChungying Lu
298e38b928SChungying Lu request_ops = (uint32_t)x1;
308e38b928SChungying Lu
318e38b928SChungying Lu switch (request_ops) {
328e38b928SChungying Lu case MTK_APUSYS_KERNEL_OP_APUSYS_PWR_TOP_ON:
333ee4b2deSKarl Li ret = apusys_kernel_apusys_rv_pwr_ctrl(APU_PWR_ON);
348e38b928SChungying Lu break;
358e38b928SChungying Lu case MTK_APUSYS_KERNEL_OP_APUSYS_PWR_TOP_OFF:
363ee4b2deSKarl Li ret = apusys_kernel_apusys_rv_pwr_ctrl(APU_PWR_OFF);
378e38b928SChungying Lu break;
3894a9e624SChungying Lu case MTK_APUSYS_KERNEL_OP_APUSYS_RV_SETUP_REVISER:
3994a9e624SChungying Lu ret = apusys_kernel_apusys_rv_setup_reviser();
4094a9e624SChungying Lu break;
4194a9e624SChungying Lu case MTK_APUSYS_KERNEL_OP_APUSYS_RV_RESET_MP:
4294a9e624SChungying Lu ret = apusys_kernel_apusys_rv_reset_mp();
4394a9e624SChungying Lu break;
4494a9e624SChungying Lu case MTK_APUSYS_KERNEL_OP_APUSYS_RV_SETUP_BOOT:
4594a9e624SChungying Lu ret = apusys_kernel_apusys_rv_setup_boot();
4694a9e624SChungying Lu break;
4794a9e624SChungying Lu case MTK_APUSYS_KERNEL_OP_APUSYS_RV_START_MP:
4894a9e624SChungying Lu ret = apusys_kernel_apusys_rv_start_mp();
4994a9e624SChungying Lu break;
5094a9e624SChungying Lu case MTK_APUSYS_KERNEL_OP_APUSYS_RV_STOP_MP:
5194a9e624SChungying Lu ret = apusys_kernel_apusys_rv_stop_mp();
5294a9e624SChungying Lu break;
535986ae57SKarl Li case MTK_APUSYS_KERNEL_OP_DEVAPC_INIT_RCX:
545986ae57SKarl Li ret = apusys_devapc_rcx_init();
555986ae57SKarl Li break;
56176846a5SChungying Lu case MTK_APUSYS_KERNEL_OP_APUSYS_RV_SETUP_SEC_MEM:
57176846a5SChungying Lu ret = apusys_kernel_apusys_rv_setup_sec_mem();
58176846a5SChungying Lu break;
59baa0d45cSChungying Lu case MTK_APUSYS_KERNEL_OP_APUSYS_RV_DISABLE_WDT_ISR:
60baa0d45cSChungying Lu ret = apusys_kernel_apusys_rv_disable_wdt_isr();
61baa0d45cSChungying Lu break;
62baa0d45cSChungying Lu case MTK_APUSYS_KERNEL_OP_APUSYS_RV_CLEAR_WDT_ISR:
63baa0d45cSChungying Lu ret = apusys_kernel_apusys_rv_clear_wdt_isr();
64baa0d45cSChungying Lu break;
65baa0d45cSChungying Lu case MTK_APUSYS_KERNEL_OP_APUSYS_RV_CG_GATING:
66baa0d45cSChungying Lu ret = apusys_kernel_apusys_rv_cg_gating();
67baa0d45cSChungying Lu break;
68baa0d45cSChungying Lu case MTK_APUSYS_KERNEL_OP_APUSYS_RV_CG_UNGATING:
69baa0d45cSChungying Lu ret = apusys_kernel_apusys_rv_cg_ungating();
70baa0d45cSChungying Lu break;
71e534d4f6SKarl Li case MTK_APUSYS_KERNEL_OP_APUSYS_RV_SETUP_APUMMU:
72e534d4f6SKarl Li ret = apusys_kernel_apusys_rv_setup_apummu();
73e534d4f6SKarl Li break;
74*5e5c57d5SKarl Li #ifdef CONFIG_MTK_APUSYS_LOGTOP_SUPPORT
75*5e5c57d5SKarl Li case MTK_APUSYS_KERNEL_OP_APUSYS_LOGTOP_REG_DUMP:
76*5e5c57d5SKarl Li ret = apusys_kernel_apusys_logtop_reg_dump((uint32_t)x2, smccc_ret);
77*5e5c57d5SKarl Li break;
78*5e5c57d5SKarl Li case MTK_APUSYS_KERNEL_OP_APUSYS_LOGTOP_REG_WRITE:
79*5e5c57d5SKarl Li ret = apusys_kernel_apusys_logtop_reg_write((uint32_t)x2, (uint32_t)x3,
80*5e5c57d5SKarl Li smccc_ret);
81*5e5c57d5SKarl Li break;
82*5e5c57d5SKarl Li case MTK_APUSYS_KERNEL_OP_APUSYS_LOGTOP_REG_W1C:
83*5e5c57d5SKarl Li ret = apusys_kernel_apusys_logtop_reg_w1c((uint32_t)x2, smccc_ret);
84*5e5c57d5SKarl Li break;
85*5e5c57d5SKarl Li #endif
86*5e5c57d5SKarl Li case MTK_APUSYS_KERNEL_OP_APUSYS_COLD_BOOT_CLR_MBOX_DUMMY:
87*5e5c57d5SKarl Li ret = apusys_rv_cold_boot_clr_mbox_dummy();
88*5e5c57d5SKarl Li break;
89*5e5c57d5SKarl Li case MTK_APUSYS_KERNEL_OP_APUSYS_SETUP_CE_BIN:
90*5e5c57d5SKarl Li ret = apusys_rv_setup_ce_bin();
91*5e5c57d5SKarl Li break;
928e38b928SChungying Lu default:
938e38b928SChungying Lu ERROR(MODULE_TAG "%s unknown request_ops = %x\n", MODULE_TAG, request_ops);
948e38b928SChungying Lu break;
958e38b928SChungying Lu }
968e38b928SChungying Lu
978e38b928SChungying Lu return ret;
988e38b928SChungying Lu }
998e38b928SChungying Lu DECLARE_SMC_HANDLER(MTK_SIP_APUSYS_CONTROL, apusys_kernel_handler);
10052430916SChungying Lu
apusys_init(void)10152430916SChungying Lu int apusys_init(void)
10252430916SChungying Lu {
103777e3b71SKarl Li if (apusys_power_init() != 0) {
104777e3b71SKarl Li return -1;
105777e3b71SKarl Li }
106777e3b71SKarl Li
107777e3b71SKarl Li if (apusys_devapc_ao_init() != 0) {
108777e3b71SKarl Li return -1;
109777e3b71SKarl Li }
110777e3b71SKarl Li
111b5900c92SKarl Li apusys_security_ctrl_init();
112ad7673adSKarl Li apusys_rv_mbox_mpu_init();
113b5900c92SKarl Li
11452430916SChungying Lu return 0;
11552430916SChungying Lu }
11652430916SChungying Lu MTK_PLAT_SETUP_1_INIT(apusys_init);
117