apusys.c 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116
  1. /*
  2. * Copyright (c) 2023, MediaTek Inc. All rights reserved.
  3. *
  4. * SPDX-License-Identifier: BSD-3-Clause
  5. */
  6. /* TF-A system header */
  7. #include <common/debug.h>
  8. /* Vendor header */
  9. #include "apusys.h"
  10. #include "apusys_devapc.h"
  11. #include "apusys_power.h"
  12. #include "apusys_rv.h"
  13. #include "apusys_security_ctrl_plat.h"
  14. #include <lib/mtk_init/mtk_init.h>
  15. #include <mtk_sip_svc.h>
  16. static u_register_t apusys_kernel_handler(u_register_t x1,
  17. u_register_t x2,
  18. u_register_t x3,
  19. u_register_t x4,
  20. void *handle,
  21. struct smccc_res *smccc_ret)
  22. {
  23. uint32_t request_ops;
  24. int32_t ret = -1;
  25. request_ops = (uint32_t)x1;
  26. switch (request_ops) {
  27. case MTK_APUSYS_KERNEL_OP_APUSYS_PWR_TOP_ON:
  28. ret = apusys_kernel_apusys_rv_pwr_ctrl(APU_PWR_ON);
  29. break;
  30. case MTK_APUSYS_KERNEL_OP_APUSYS_PWR_TOP_OFF:
  31. ret = apusys_kernel_apusys_rv_pwr_ctrl(APU_PWR_OFF);
  32. break;
  33. case MTK_APUSYS_KERNEL_OP_APUSYS_RV_SETUP_REVISER:
  34. ret = apusys_kernel_apusys_rv_setup_reviser();
  35. break;
  36. case MTK_APUSYS_KERNEL_OP_APUSYS_RV_RESET_MP:
  37. ret = apusys_kernel_apusys_rv_reset_mp();
  38. break;
  39. case MTK_APUSYS_KERNEL_OP_APUSYS_RV_SETUP_BOOT:
  40. ret = apusys_kernel_apusys_rv_setup_boot();
  41. break;
  42. case MTK_APUSYS_KERNEL_OP_APUSYS_RV_START_MP:
  43. ret = apusys_kernel_apusys_rv_start_mp();
  44. break;
  45. case MTK_APUSYS_KERNEL_OP_APUSYS_RV_STOP_MP:
  46. ret = apusys_kernel_apusys_rv_stop_mp();
  47. break;
  48. case MTK_APUSYS_KERNEL_OP_DEVAPC_INIT_RCX:
  49. ret = apusys_devapc_rcx_init();
  50. break;
  51. case MTK_APUSYS_KERNEL_OP_APUSYS_RV_SETUP_SEC_MEM:
  52. ret = apusys_kernel_apusys_rv_setup_sec_mem();
  53. break;
  54. case MTK_APUSYS_KERNEL_OP_APUSYS_RV_DISABLE_WDT_ISR:
  55. ret = apusys_kernel_apusys_rv_disable_wdt_isr();
  56. break;
  57. case MTK_APUSYS_KERNEL_OP_APUSYS_RV_CLEAR_WDT_ISR:
  58. ret = apusys_kernel_apusys_rv_clear_wdt_isr();
  59. break;
  60. case MTK_APUSYS_KERNEL_OP_APUSYS_RV_CG_GATING:
  61. ret = apusys_kernel_apusys_rv_cg_gating();
  62. break;
  63. case MTK_APUSYS_KERNEL_OP_APUSYS_RV_CG_UNGATING:
  64. ret = apusys_kernel_apusys_rv_cg_ungating();
  65. break;
  66. case MTK_APUSYS_KERNEL_OP_APUSYS_RV_SETUP_APUMMU:
  67. ret = apusys_kernel_apusys_rv_setup_apummu();
  68. break;
  69. #ifdef CONFIG_MTK_APUSYS_LOGTOP_SUPPORT
  70. case MTK_APUSYS_KERNEL_OP_APUSYS_LOGTOP_REG_DUMP:
  71. ret = apusys_kernel_apusys_logtop_reg_dump((uint32_t)x2, smccc_ret);
  72. break;
  73. case MTK_APUSYS_KERNEL_OP_APUSYS_LOGTOP_REG_WRITE:
  74. ret = apusys_kernel_apusys_logtop_reg_write((uint32_t)x2, (uint32_t)x3,
  75. smccc_ret);
  76. break;
  77. case MTK_APUSYS_KERNEL_OP_APUSYS_LOGTOP_REG_W1C:
  78. ret = apusys_kernel_apusys_logtop_reg_w1c((uint32_t)x2, smccc_ret);
  79. break;
  80. #endif
  81. case MTK_APUSYS_KERNEL_OP_APUSYS_COLD_BOOT_CLR_MBOX_DUMMY:
  82. ret = apusys_rv_cold_boot_clr_mbox_dummy();
  83. break;
  84. case MTK_APUSYS_KERNEL_OP_APUSYS_SETUP_CE_BIN:
  85. ret = apusys_rv_setup_ce_bin();
  86. break;
  87. default:
  88. ERROR(MODULE_TAG "%s unknown request_ops = %x\n", MODULE_TAG, request_ops);
  89. break;
  90. }
  91. return ret;
  92. }
  93. DECLARE_SMC_HANDLER(MTK_SIP_APUSYS_CONTROL, apusys_kernel_handler);
  94. int apusys_init(void)
  95. {
  96. if (apusys_power_init() != 0) {
  97. return -1;
  98. }
  99. if (apusys_devapc_ao_init() != 0) {
  100. return -1;
  101. }
  102. apusys_security_ctrl_init();
  103. apusys_rv_mbox_mpu_init();
  104. return 0;
  105. }
  106. MTK_PLAT_SETUP_1_INIT(apusys_init);