1*85f199b7SChia-Wei Wang /* 2*85f199b7SChia-Wei Wang * Copyright (c) 2023, Aspeed Technology Inc. 3*85f199b7SChia-Wei Wang * 4*85f199b7SChia-Wei Wang * SPDX-License-Identifier: BSD-3-Clause 5*85f199b7SChia-Wei Wang */ 6*85f199b7SChia-Wei Wang 7*85f199b7SChia-Wei Wang #include <arch.h> 8*85f199b7SChia-Wei Wang #include <lib/psci/psci.h> 9*85f199b7SChia-Wei Wang #include <platform_def.h> 10*85f199b7SChia-Wei Wang 11*85f199b7SChia-Wei Wang static const unsigned char ast2700_power_domain_tree_desc[] = { 12*85f199b7SChia-Wei Wang PLATFORM_SYSTEM_COUNT, 13*85f199b7SChia-Wei Wang PLATFORM_CORE_COUNT_PER_CLUSTER, 14*85f199b7SChia-Wei Wang }; 15*85f199b7SChia-Wei Wang plat_get_power_domain_tree_desc(void)16*85f199b7SChia-Wei Wangconst unsigned char *plat_get_power_domain_tree_desc(void) 17*85f199b7SChia-Wei Wang { 18*85f199b7SChia-Wei Wang return ast2700_power_domain_tree_desc; 19*85f199b7SChia-Wei Wang } 20*85f199b7SChia-Wei Wang plat_core_pos_by_mpidr(u_register_t mpidr)21*85f199b7SChia-Wei Wangunsigned int plat_core_pos_by_mpidr(u_register_t mpidr) 22*85f199b7SChia-Wei Wang { 23*85f199b7SChia-Wei Wang unsigned int cluster_id, cpu_id; 24*85f199b7SChia-Wei Wang 25*85f199b7SChia-Wei Wang mpidr &= MPIDR_AFFINITY_MASK; 26*85f199b7SChia-Wei Wang 27*85f199b7SChia-Wei Wang if (mpidr & ~(MPIDR_CLUSTER_MASK | MPIDR_CPU_MASK)) { 28*85f199b7SChia-Wei Wang return -1; 29*85f199b7SChia-Wei Wang } 30*85f199b7SChia-Wei Wang 31*85f199b7SChia-Wei Wang cluster_id = (mpidr >> MPIDR_AFF1_SHIFT) & MPIDR_AFFLVL_MASK; 32*85f199b7SChia-Wei Wang cpu_id = (mpidr >> MPIDR_AFF0_SHIFT) & MPIDR_AFFLVL_MASK; 33*85f199b7SChia-Wei Wang 34*85f199b7SChia-Wei Wang if (cluster_id >= PLATFORM_CLUSTER_COUNT) { 35*85f199b7SChia-Wei Wang return -1; 36*85f199b7SChia-Wei Wang } 37*85f199b7SChia-Wei Wang 38*85f199b7SChia-Wei Wang if (cpu_id >= PLATFORM_CORE_COUNT_PER_CLUSTER) { 39*85f199b7SChia-Wei Wang return -1; 40*85f199b7SChia-Wei Wang } 41*85f199b7SChia-Wei Wang 42*85f199b7SChia-Wei Wang return (cluster_id * PLATFORM_CORE_COUNT_PER_CLUSTER) + cpu_id; 43*85f199b7SChia-Wei Wang } 44