blob: 87e8960965edbc788a5e41ac9f7b22b81a6ae7f0 [file] [log] [blame]
Chungying Lua566cc92023-03-15 14:16:28 +08001/*
2 * Copyright (c) 2023, MediaTek Inc. All rights reserved.
3 *
4 * SPDX-License-Identifier: BSD-3-Clause
5 */
6
7/* TF-A system header */
8#include <common/debug.h>
9
10/* Vendor header */
11#include "apusys.h"
Karl Li130536e2023-04-21 11:43:24 +080012#include "apusys_devapc.h"
Chungying Lua566cc92023-03-15 14:16:28 +080013#include "apusys_power.h"
Karl Lieb629492023-04-27 14:00:10 +080014#include "apusys_rv.h"
Karl Lidece5f02023-04-27 10:38:28 +080015#include "apusys_security_ctrl_plat.h"
Chungying Lua566cc92023-03-15 14:16:28 +080016#include <lib/mtk_init/mtk_init.h>
Chungying Luf1f14b32023-03-15 15:31:56 +080017#include <mtk_sip_svc.h>
18
19static u_register_t apusys_kernel_handler(u_register_t x1,
20 u_register_t x2,
21 u_register_t x3,
22 u_register_t x4,
23 void *handle,
24 struct smccc_res *smccc_ret)
25{
26 uint32_t request_ops;
27 int32_t ret = -1;
28
29 request_ops = (uint32_t)x1;
30
31 switch (request_ops) {
32 case MTK_APUSYS_KERNEL_OP_APUSYS_PWR_TOP_ON:
developer4acfe9b2024-11-14 20:38:19 +080033 ret = apusys_kernel_apusys_rv_pwr_ctrl(APU_PWR_ON);
Chungying Luf1f14b32023-03-15 15:31:56 +080034 break;
35 case MTK_APUSYS_KERNEL_OP_APUSYS_PWR_TOP_OFF:
developer4acfe9b2024-11-14 20:38:19 +080036 ret = apusys_kernel_apusys_rv_pwr_ctrl(APU_PWR_OFF);
Chungying Luf1f14b32023-03-15 15:31:56 +080037 break;
Chungying Lu15ffb072023-04-19 17:17:23 +080038 case MTK_APUSYS_KERNEL_OP_APUSYS_RV_SETUP_REVISER:
39 ret = apusys_kernel_apusys_rv_setup_reviser();
40 break;
41 case MTK_APUSYS_KERNEL_OP_APUSYS_RV_RESET_MP:
42 ret = apusys_kernel_apusys_rv_reset_mp();
43 break;
44 case MTK_APUSYS_KERNEL_OP_APUSYS_RV_SETUP_BOOT:
45 ret = apusys_kernel_apusys_rv_setup_boot();
46 break;
47 case MTK_APUSYS_KERNEL_OP_APUSYS_RV_START_MP:
48 ret = apusys_kernel_apusys_rv_start_mp();
49 break;
50 case MTK_APUSYS_KERNEL_OP_APUSYS_RV_STOP_MP:
51 ret = apusys_kernel_apusys_rv_stop_mp();
52 break;
Karl Li03facb02023-04-24 16:45:49 +080053 case MTK_APUSYS_KERNEL_OP_DEVAPC_INIT_RCX:
54 ret = apusys_devapc_rcx_init();
55 break;
Chungying Lu59c1c2b2023-04-25 15:39:10 +080056 case MTK_APUSYS_KERNEL_OP_APUSYS_RV_SETUP_SEC_MEM:
57 ret = apusys_kernel_apusys_rv_setup_sec_mem();
58 break;
Chungying Lu4f3b5da2023-05-12 18:37:32 +080059 case MTK_APUSYS_KERNEL_OP_APUSYS_RV_DISABLE_WDT_ISR:
60 ret = apusys_kernel_apusys_rv_disable_wdt_isr();
61 break;
62 case MTK_APUSYS_KERNEL_OP_APUSYS_RV_CLEAR_WDT_ISR:
63 ret = apusys_kernel_apusys_rv_clear_wdt_isr();
64 break;
65 case MTK_APUSYS_KERNEL_OP_APUSYS_RV_CG_GATING:
66 ret = apusys_kernel_apusys_rv_cg_gating();
67 break;
68 case MTK_APUSYS_KERNEL_OP_APUSYS_RV_CG_UNGATING:
69 ret = apusys_kernel_apusys_rv_cg_ungating();
70 break;
developer2b9bda02024-11-15 11:01:03 +080071 case MTK_APUSYS_KERNEL_OP_APUSYS_RV_SETUP_APUMMU:
72 ret = apusys_kernel_apusys_rv_setup_apummu();
73 break;
developerf7dfb992024-11-14 20:21:31 +080074#ifdef CONFIG_MTK_APUSYS_LOGTOP_SUPPORT
75 case MTK_APUSYS_KERNEL_OP_APUSYS_LOGTOP_REG_DUMP:
76 ret = apusys_kernel_apusys_logtop_reg_dump((uint32_t)x2, smccc_ret);
77 break;
78 case MTK_APUSYS_KERNEL_OP_APUSYS_LOGTOP_REG_WRITE:
79 ret = apusys_kernel_apusys_logtop_reg_write((uint32_t)x2, (uint32_t)x3,
80 smccc_ret);
81 break;
82 case MTK_APUSYS_KERNEL_OP_APUSYS_LOGTOP_REG_W1C:
83 ret = apusys_kernel_apusys_logtop_reg_w1c((uint32_t)x2, smccc_ret);
84 break;
85#endif
86 case MTK_APUSYS_KERNEL_OP_APUSYS_COLD_BOOT_CLR_MBOX_DUMMY:
87 ret = apusys_rv_cold_boot_clr_mbox_dummy();
88 break;
89 case MTK_APUSYS_KERNEL_OP_APUSYS_SETUP_CE_BIN:
90 ret = apusys_rv_setup_ce_bin();
91 break;
Chungying Luf1f14b32023-03-15 15:31:56 +080092 default:
93 ERROR(MODULE_TAG "%s unknown request_ops = %x\n", MODULE_TAG, request_ops);
94 break;
95 }
96
97 return ret;
98}
99DECLARE_SMC_HANDLER(MTK_SIP_APUSYS_CONTROL, apusys_kernel_handler);
Chungying Lua566cc92023-03-15 14:16:28 +0800100
101int apusys_init(void)
102{
Karl Li130536e2023-04-21 11:43:24 +0800103 if (apusys_power_init() != 0) {
104 return -1;
105 }
106
107 if (apusys_devapc_ao_init() != 0) {
108 return -1;
109 }
110
Karl Lidece5f02023-04-27 10:38:28 +0800111 apusys_security_ctrl_init();
Karl Lieb629492023-04-27 14:00:10 +0800112 apusys_rv_mbox_mpu_init();
Karl Lidece5f02023-04-27 10:38:28 +0800113
Chungying Lua566cc92023-03-15 14:16:28 +0800114 return 0;
115}
116MTK_PLAT_SETUP_1_INIT(apusys_init);