1*91f16700Schasinglulu /* 2*91f16700Schasinglulu * Copyright (c) 2022, MediaTek Inc. All rights reserved. 3*91f16700Schasinglulu * 4*91f16700Schasinglulu * SPDX-License-Identifier: BSD-3-Clause 5*91f16700Schasinglulu */ 6*91f16700Schasinglulu 7*91f16700Schasinglulu #include <assert.h> 8*91f16700Schasinglulu #include <arch_helpers.h> 9*91f16700Schasinglulu #include <common/debug.h> 10*91f16700Schasinglulu #include <drivers/gpio.h> 11*91f16700Schasinglulu #include <lib/mtk_init/mtk_init.h> 12*91f16700Schasinglulu #include <lib/pm/mtk_pm.h> 13*91f16700Schasinglulu #include <plat_params.h> 14*91f16700Schasinglulu #include <pmic.h> 15*91f16700Schasinglulu #include <rtc.h> 16*91f16700Schasinglulu 17*91f16700Schasinglulu static void __dead2 mtk_system_reset_cros(void) 18*91f16700Schasinglulu { 19*91f16700Schasinglulu struct bl_aux_gpio_info *gpio_reset = plat_get_mtk_gpio_reset(); 20*91f16700Schasinglulu 21*91f16700Schasinglulu INFO("MTK System Reset\n"); 22*91f16700Schasinglulu 23*91f16700Schasinglulu gpio_set_value(gpio_reset->index, gpio_reset->polarity); 24*91f16700Schasinglulu 25*91f16700Schasinglulu wfi(); 26*91f16700Schasinglulu ERROR("MTK System Reset: operation not handled.\n"); 27*91f16700Schasinglulu panic(); 28*91f16700Schasinglulu } 29*91f16700Schasinglulu 30*91f16700Schasinglulu static void __dead2 mtk_system_off_cros(void) 31*91f16700Schasinglulu { 32*91f16700Schasinglulu INFO("MTK System Off\n"); 33*91f16700Schasinglulu 34*91f16700Schasinglulu rtc_power_off_sequence(); 35*91f16700Schasinglulu pmic_power_off(); 36*91f16700Schasinglulu 37*91f16700Schasinglulu wfi(); 38*91f16700Schasinglulu ERROR("MTK System Off: operation not handled.\n"); 39*91f16700Schasinglulu panic(); 40*91f16700Schasinglulu } 41*91f16700Schasinglulu 42*91f16700Schasinglulu static struct plat_pm_reset_ctrl lib_reset_ctrl = { 43*91f16700Schasinglulu .system_off = mtk_system_off_cros, 44*91f16700Schasinglulu .system_reset = mtk_system_reset_cros, 45*91f16700Schasinglulu .system_reset2 = NULL, 46*91f16700Schasinglulu }; 47*91f16700Schasinglulu 48*91f16700Schasinglulu static int lib_reset_ctrl_init(void) 49*91f16700Schasinglulu { 50*91f16700Schasinglulu INFO("Reset init\n"); 51*91f16700Schasinglulu 52*91f16700Schasinglulu plat_pm_ops_setup_reset(&lib_reset_ctrl); 53*91f16700Schasinglulu 54*91f16700Schasinglulu return 0; 55*91f16700Schasinglulu } 56*91f16700Schasinglulu MTK_ARCH_INIT(lib_reset_ctrl_init); 57