Skip to content
Snippets Groups Projects
Verified Commit ec7abebc authored by jD91mZM2's avatar jD91mZM2
Browse files

Fix a very slight error in the mutex

This was just my attempt at being smart, I didn't realize
`compare_exchange` returned the old value (I'm dumb!), so I thought
that if the value was 1 then it must have become 2. Normally with
small errors like these you should leave a comment explaining why, but
really, compare and *exchange* is pretty obvious. My bad.
parent d704a35b
No related branches found
No related tags found
No related merge requests found
...@@ -70,7 +70,7 @@ impl<T> Mutex<T> { ...@@ -70,7 +70,7 @@ impl<T> Mutex<T> {
// //
// - Skip the atomic operation if the last value was 2, since it most likely hasn't changed. // - Skip the atomic operation if the last value was 2, since it most likely hasn't changed.
// - Skip the futex wait if the atomic operation says the mutex is unlocked. // - Skip the futex wait if the atomic operation says the mutex is unlocked.
if last == 2 || self.atomic().compare_exchange(1, 2, SeqCst, SeqCst).unwrap_or_else(|err| err) == 2 { if last == 2 || self.atomic().compare_exchange(1, 2, SeqCst, SeqCst).unwrap_or_else(|err| err) != 0 {
Sys::futex(self.atomic().get_mut(), FUTEX_WAIT, 2); Sys::futex(self.atomic().get_mut(), FUTEX_WAIT, 2);
} }
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment