191e9d4abSLoGin use system_error::SystemError; 291e9d4abSLoGin 3aa0367d6SLoGin use crate::{ 41496ba7bSLoGin arch::interrupt::ipi::send_ipi, 5aa0367d6SLoGin exception::ipi::{IpiKind, IpiTarget}, 6aa0367d6SLoGin }; 7aa0367d6SLoGin 8*e2841179SLoGin use self::cpu::ProcessorId; 9*e2841179SLoGin 1040fe15e0SLoGin pub mod c_adapter; 1166f67c6aSlogin pub mod core; 1270a4e555SLoGin pub mod cpu; 13aa0367d6SLoGin 14*e2841179SLoGin pub fn kick_cpu(cpu_id: ProcessorId) -> Result<(), SystemError> { 15aa0367d6SLoGin // todo: 增加对cpu_id的有效性检查 16aa0367d6SLoGin 17*e2841179SLoGin send_ipi(IpiKind::KickCpu, IpiTarget::Specified(cpu_id)); 18aa0367d6SLoGin return Ok(()); 19aa0367d6SLoGin } 205b59005fSLoGin 215b59005fSLoGin pub trait SMPArch { 225b59005fSLoGin /// 准备SMP初始化所需的cpu拓扑数据。 235b59005fSLoGin /// 245b59005fSLoGin /// 该函数需要标记为 `#[inline(never)]` 255b59005fSLoGin fn prepare_cpus() -> Result<(), SystemError>; 265b59005fSLoGin 275b59005fSLoGin /// 初始化SMP 285b59005fSLoGin /// 295b59005fSLoGin /// 该函数需要标记为 `#[inline(never)]` 305b59005fSLoGin fn init() -> Result<(), SystemError>; 315b59005fSLoGin } 32