/* * Copyright (c) 2022, MediaTek Inc. All rights reserved. * * SPDX-License-Identifier: BSD-3-Clause */ #include #include #include #include #include #include #include #include #include static void __dead2 mtk_system_reset_cros(void) { struct bl_aux_gpio_info *gpio_reset = plat_get_mtk_gpio_reset(); INFO("MTK System Reset\n"); gpio_set_value(gpio_reset->index, gpio_reset->polarity); wfi(); ERROR("MTK System Reset: operation not handled.\n"); panic(); } static void __dead2 mtk_system_off_cros(void) { INFO("MTK System Off\n"); rtc_power_off_sequence(); pmic_power_off(); wfi(); ERROR("MTK System Off: operation not handled.\n"); panic(); } static struct plat_pm_reset_ctrl lib_reset_ctrl = { .system_off = mtk_system_off_cros, .system_reset = mtk_system_reset_cros, .system_reset2 = NULL, }; static int lib_reset_ctrl_init(void) { INFO("Reset init\n"); plat_pm_ops_setup_reset(&lib_reset_ctrl); return 0; } MTK_ARCH_INIT(lib_reset_ctrl_init);