1*91f16700Schasinglulu /* 2*91f16700Schasinglulu * Copyright (c) 2020, MediaTek Inc. All rights reserved. 3*91f16700Schasinglulu * 4*91f16700Schasinglulu * SPDX-License-Identifier: BSD-3-Clause 5*91f16700Schasinglulu */ 6*91f16700Schasinglulu 7*91f16700Schasinglulu #ifndef MTSPMC_H 8*91f16700Schasinglulu #define MTSPMC_H 9*91f16700Schasinglulu 10*91f16700Schasinglulu #include <stdint.h> 11*91f16700Schasinglulu 12*91f16700Schasinglulu int spmc_init(void); 13*91f16700Schasinglulu 14*91f16700Schasinglulu void spm_poweron_cpu(unsigned int cluster, unsigned int cpu); 15*91f16700Schasinglulu void spm_poweroff_cpu(unsigned int cluster, unsigned int cpu); 16*91f16700Schasinglulu 17*91f16700Schasinglulu void spm_poweroff_cluster(unsigned int cluster); 18*91f16700Schasinglulu void spm_poweron_cluster(unsigned int cluster); 19*91f16700Schasinglulu 20*91f16700Schasinglulu bool spm_get_cpu_powerstate(unsigned int cluster, unsigned int cpu); 21*91f16700Schasinglulu bool spm_get_cluster_powerstate(unsigned int cluster); 22*91f16700Schasinglulu bool spm_get_powerstate(uint32_t mask); 23*91f16700Schasinglulu 24*91f16700Schasinglulu void mcucfg_init_archstate(unsigned int cluster, unsigned int cpu, bool arm64); 25*91f16700Schasinglulu void mcucfg_set_bootaddr(unsigned int cluster, unsigned int cpu, uintptr_t bootaddr); 26*91f16700Schasinglulu uintptr_t mcucfg_get_bootaddr(unsigned int cluster, unsigned int cpu); 27*91f16700Schasinglulu 28*91f16700Schasinglulu void mcucfg_disable_gic_wakeup(unsigned int cluster, unsigned int cpu); 29*91f16700Schasinglulu void mcucfg_enable_gic_wakeup(unsigned int cluster, unsigned int cpu); 30*91f16700Schasinglulu 31*91f16700Schasinglulu #endif /* MTSPMC_H */ 32