#[percpu::def_percpu]
static CPU_ID: usize = 0;
#[percpu::def_percpu]
static IS_BSP: bool = false;
#[percpu::def_percpu]
static CURRENT_TASK_PTR: usize = 0;
#[inline]
pub fn this_cpu_id() -> usize {
CPU_ID.read_current()
}
#[inline]
pub fn this_cpu_is_bsp() -> bool {
IS_BSP.read_current()
}
#[cfg(target_arch = "aarch64")]
pub(crate) unsafe fn cache_current_task_ptr() {
use tock_registers::interfaces::Writeable;
aarch64_cpu::registers::SP_EL0.set(CURRENT_TASK_PTR.read_current_raw() as u64);
}
#[inline]
pub fn current_task_ptr<T>() -> *const T {
#[cfg(target_arch = "x86_64")]
unsafe {
CURRENT_TASK_PTR.read_current_raw() as _
}
#[cfg(any(target_arch = "riscv32", target_arch = "riscv64"))]
unsafe {
let _guard = kernel_guard::IrqSave::new();
CURRENT_TASK_PTR.read_current_raw() as _
}
#[cfg(target_arch = "aarch64")]
{
use tock_registers::interfaces::Readable;
aarch64_cpu::registers::SP_EL0.get() as _
}
}
#[inline]
pub unsafe fn set_current_task_ptr<T>(ptr: *const T) {
#[cfg(target_arch = "x86_64")]
{
CURRENT_TASK_PTR.write_current_raw(ptr as usize)
}
#[cfg(any(target_arch = "riscv32", target_arch = "riscv64"))]
{
let _guard = kernel_guard::IrqSave::new();
CURRENT_TASK_PTR.write_current_raw(ptr as usize)
}
#[cfg(target_arch = "aarch64")]
{
let _guard = kernel_guard::IrqSave::new();
CURRENT_TASK_PTR.write_current_raw(ptr as usize);
cache_current_task_ptr();
}
}
#[allow(dead_code)]
pub(crate) fn init_primary(cpu_id: usize) {
percpu::init(axconfig::SMP);
percpu::set_local_thread_pointer(cpu_id);
unsafe {
CPU_ID.write_current_raw(cpu_id);
IS_BSP.write_current_raw(true);
}
crate::arch::cpu_init();
}
#[allow(dead_code)]
pub(crate) fn init_secondary(cpu_id: usize) {
percpu::set_local_thread_pointer(cpu_id);
unsafe {
CPU_ID.write_current_raw(cpu_id);
IS_BSP.write_current_raw(false);
}
crate::arch::cpu_init();
}