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 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 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