mirror of
https://github.com/projectacrn/acrn-hypervisor.git
synced 2025-11-14 10:31:59 +00:00
hv: multi-arch: abstract some pcpu related interfaces and macros
The following pcpu related interfaces are moved into common: - common/cpu.c::start_pcpus - include/common/cpu.h::get_pcpu_id - include/common/cpu.h::set_current_pcpu_id Their arch specific implementations are moved into arch/$(ARCH): - arch/$(ARCH)/cpu.c::arch_start_pcpu - include/arch/$(ARCH)/asm/cpu.h::arch_get_pcpu_id - include/arch/$(ARCH)/asm/cpu.h::arch_set_current_pcpu_id The following interface is moved into common: - pcpu_set_current_state (from arch/x86/cpu.c -> common/cpu.c) The following MACROs are moved into include/common/cpu.h: - CPU_UP_TIMEOUT - CPU_DOWN_TIMEOUT - BSP_CPU_ID - INVALID_CPU_ID Tracked-On: #8791 Signed-off-by: Jian Jun Chen <jian.jun.chen@intel.com> Acked-by: Wang, Yu1 <yu1.wang@intel.com>
This commit is contained in:
committed by
acrnsi-robot
parent
b4092965a4
commit
e5831fec1e
@@ -10,6 +10,17 @@
|
||||
#include <types.h>
|
||||
#include <asm/cpu.h>
|
||||
|
||||
#define CPU_UP_TIMEOUT 100U /* millisecond */
|
||||
#define CPU_DOWN_TIMEOUT 100U /* millisecond */
|
||||
|
||||
#define BSP_CPU_ID 0U /* Boot CPU ID */
|
||||
|
||||
/**
|
||||
* The invalid cpu_id (INVALID_CPU_ID) is error code for error handling,
|
||||
* this means that caller can't find a valid physical cpu or virtual cpu.
|
||||
*/
|
||||
#define INVALID_CPU_ID 0xffffU
|
||||
|
||||
/* CPU states defined */
|
||||
enum pcpu_boot_state {
|
||||
PCPU_STATE_RESET = 0U,
|
||||
@@ -18,6 +29,10 @@ enum pcpu_boot_state {
|
||||
PCPU_STATE_HALTED,
|
||||
PCPU_STATE_DEAD,
|
||||
};
|
||||
|
||||
static inline uint16_t arch_get_pcpu_id(void);
|
||||
static inline void arch_set_current_pcpu_id(uint16_t pcpu_id);
|
||||
void arch_start_pcpu(uint16_t pcpu_id);
|
||||
uint16_t arch_get_pcpu_num(void);
|
||||
uint16_t get_pcpu_nums(void);
|
||||
bool is_pcpu_active(uint16_t pcpu_id);
|
||||
@@ -26,8 +41,20 @@ void clear_pcpu_active(uint16_t pcpu_id);
|
||||
bool check_pcpus_active(uint64_t mask);
|
||||
bool check_pcpus_inactive(uint64_t mask);
|
||||
uint64_t get_active_pcpu_bitmap(void);
|
||||
void pcpu_set_current_state(uint16_t pcpu_id, enum pcpu_boot_state state);
|
||||
bool start_pcpus(uint64_t mask);
|
||||
|
||||
#define ALL_CPUS_MASK ((1UL << get_pcpu_nums()) - 1UL)
|
||||
#define AP_MASK (ALL_CPUS_MASK & ~(1UL << BSP_CPU_ID))
|
||||
|
||||
static inline uint16_t get_pcpu_id(void)
|
||||
{
|
||||
return arch_get_pcpu_id();
|
||||
}
|
||||
|
||||
static inline void set_current_pcpu_id(uint16_t pcpu_id)
|
||||
{
|
||||
arch_set_current_pcpu_id(pcpu_id);
|
||||
}
|
||||
|
||||
#endif /* COMMON_CPU_H */
|
||||
|
||||
Reference in New Issue
Block a user