#[cfg(not(portable_atomic_no_asm))]
use core::arch::asm;
#[cfg(not(portable_atomic_no_asm))]
#[cfg_attr(
portable_atomic_no_cfg_target_has_atomic,
cfg(any(test, portable_atomic_no_atomic_cas))
)]
#[cfg_attr(
not(portable_atomic_no_cfg_target_has_atomic),
cfg(any(test, not(target_has_atomic = "ptr")))
)]
pub(super) use super::super::avr as atomic;
pub(crate) type State = u8;
#[inline(always)]
pub(crate) fn disable() -> State {
let sreg: State;
unsafe {
#[cfg(not(portable_atomic_no_asm))]
asm!(
"in {sreg}, 0x3F", "cli", sreg = out(reg) sreg,
options(nostack),
);
#[cfg(portable_atomic_no_asm)]
{
llvm_asm!("in $0, 0x3F" : "=r"(sreg) ::: "volatile");
llvm_asm!("cli" ::: "memory" : "volatile");
}
}
sreg
}
#[inline(always)]
pub(crate) unsafe fn restore(prev_sreg: State) {
unsafe {
#[cfg(not(portable_atomic_no_asm))]
asm!(
"out 0x3F, {prev_sreg}", prev_sreg = in(reg) prev_sreg,
options(nostack),
);
#[cfg(portable_atomic_no_asm)]
llvm_asm!("out 0x3F, $0" :: "r"(prev_sreg) : "memory" : "volatile");
}
}