use core::{
cell::UnsafeCell,
ptr::{self, NonNull},
sync::atomic::AtomicBool,
};
use crate::{AutoEnable, CpuId, CpuMask, IrqRequest, IrqScope, RawIrqHandler};
pub(crate) struct Action {
pub(crate) id: u64,
pub(crate) handler: RawIrqHandler,
pub(crate) data: NonNull<()>,
pub(crate) scope: IrqScope,
pub(crate) enabled: AtomicBool,
pub(crate) detached: AtomicBool,
pending_enable: UnsafeCell<CpuMask>,
pub(crate) next: *mut Action,
}
unsafe impl Send for Action {}
unsafe impl Sync for Action {}
impl Action {
pub(crate) fn new(id: u64, request: &IrqRequest) -> Self {
Self {
id,
handler: request.handler,
data: request.data,
scope: request.scope,
enabled: AtomicBool::new(request.auto_enable == AutoEnable::Yes),
detached: AtomicBool::new(false),
pending_enable: UnsafeCell::new(CpuMask::empty()),
next: ptr::null_mut(),
}
}
pub(crate) fn pending_enable_contains(&self, cpu: CpuId) -> bool {
unsafe { (&*self.pending_enable.get()).contains(cpu) }
}
pub(crate) fn insert_pending_enable(&self, cpu: CpuId) {
unsafe { (&mut *self.pending_enable.get()).insert(cpu) };
}
pub(crate) fn remove_pending_enable(&self, cpu: CpuId) {
unsafe { (&mut *self.pending_enable.get()).remove(cpu) };
}
pub(crate) fn clear_pending_enable_all(&self) {
unsafe { *self.pending_enable.get() = CpuMask::empty() };
}
}