From a500c9dbb1766a6bde312ad34929dad66f81cfb7 Mon Sep 17 00:00:00 2001 From: Gwilym Kuiper Date: Mon, 16 Aug 2021 21:02:03 +0100 Subject: [PATCH] Make mutex new constant and reduce unsafe block size --- agb/src/interrupt.rs | 18 +++++++++--------- 1 file changed, 9 insertions(+), 9 deletions(-) diff --git a/agb/src/interrupt.rs b/agb/src/interrupt.rs index 21e65016..05f58752 100644 --- a/agb/src/interrupt.rs +++ b/agb/src/interrupt.rs @@ -347,7 +347,7 @@ impl Mutex { } } - pub fn new(val: T) -> Self { + pub const fn new(val: T) -> Self { Mutex { internal: UnsafeCell::new(val), state: UnsafeCell::new(MutexState::Unlocked), @@ -362,14 +362,14 @@ pub struct MutexRef<'a, T> { impl<'a, T> Drop for MutexRef<'a, T> { fn drop(&mut self) { - unsafe { - let state = &mut *self.state.get(); - let prev_state = *state; - *state = MutexState::Unlocked; - match prev_state { - MutexState::Locked(b) => INTERRUPTS_ENABLED.set(b as u16), - MutexState::Unlocked => {} - } + let state = unsafe { &mut *self.state.get() }; + + let prev_state = *state; + *state = MutexState::Unlocked; + + match prev_state { + MutexState::Locked(b) => INTERRUPTS_ENABLED.set(b as u16), + MutexState::Unlocked => {} } } }