diff options
| author | Ian Moffett <ian@osmora.org> | 2025-11-21 14:20:15 -0500 |
|---|---|---|
| committer | Ian Moffett <ian@osmora.org> | 2025-11-21 14:20:15 -0500 |
| commit | e105fa42d5ddb6ff7bfbbb964c4b93415b22b05a (patch) | |
| tree | 66ee5d020e7cc682ebe365fd2e2aeb6850e4a246 /sys/arch/amd64/cpu/spinlock.c | |
| parent | 9600d3df3e1b75cff0e3ecd20ae3ca2fe393eb8b (diff) | |
kern: Improve IRQ mask modification on spinlocks
Signed-off-by: Ian Moffett <ian@osmora.org>
Diffstat (limited to 'sys/arch/amd64/cpu/spinlock.c')
| -rw-r--r-- | sys/arch/amd64/cpu/spinlock.c | 16 |
1 files changed, 10 insertions, 6 deletions
diff --git a/sys/arch/amd64/cpu/spinlock.c b/sys/arch/amd64/cpu/spinlock.c index 1cfa088..6857aa6 100644 --- a/sys/arch/amd64/cpu/spinlock.c +++ b/sys/arch/amd64/cpu/spinlock.c @@ -29,12 +29,15 @@ #include <sys/cdefs.h> #include <mu/spinlock.h> +#include <mu/irq.h> void mu_spinlock_acq(volatile size_t *lock, int flags) { - if (ISSET(flags, SPINLOCK_INTTOG)) { - asm volatile("cli"); + bool irq_en = mu_irq_state(); + + if (ISSET(flags, SPINLOCK_INTTOG) && irq_en) { + __asmv("cli"); } __asmv( @@ -48,6 +51,11 @@ mu_spinlock_acq(volatile size_t *lock, int flags) : "r" (lock) : "memory", "rax" ); + + if (ISSET(flags, SPINLOCK_INTTOG)) { + if (irq_en && !mu_irq_state()) + __asmv("sti"); + } } void @@ -60,8 +68,4 @@ mu_spinlock_rel(volatile size_t *lock, int flags) : : "memory", "rax" ); - - if (ISSET(flags, SPINLOCK_INTTOG)) { - asm volatile("sti"); - } } |
