mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2024-11-23 08:00:20 +00:00
LibPthread: Okay I'm dumb, let's convert mutex locks into Atomic<u32>&
This commit is contained in:
parent
2e280417e2
commit
a12c2df43f
Notes:
sideshowbarker
2024-07-19 10:45:58 +09:00
Author: https://github.com/awesomekling Commit: https://github.com/SerenityOS/serenity/commit/a12c2df43f9
1 changed files with 4 additions and 4 deletions
|
@ -114,11 +114,11 @@ int pthread_mutex_destroy(pthread_mutex_t*)
|
|||
|
||||
int pthread_mutex_lock(pthread_mutex_t* mutex)
|
||||
{
|
||||
auto* atomic = reinterpret_cast<Atomic<u32>*>(mutex->lock);
|
||||
auto& atomic = reinterpret_cast<Atomic<u32>&>(mutex->lock);
|
||||
pthread_t this_thread = pthread_self();
|
||||
for (;;) {
|
||||
u32 expected = false;
|
||||
if (!atomic->compare_exchange_strong(expected, true, AK::memory_order_acq_rel)) {
|
||||
if (!atomic.compare_exchange_strong(expected, true, AK::memory_order_acq_rel)) {
|
||||
if (mutex->type == PTHREAD_MUTEX_RECURSIVE && mutex->owner == this_thread) {
|
||||
mutex->level++;
|
||||
return 0;
|
||||
|
@ -134,9 +134,9 @@ int pthread_mutex_lock(pthread_mutex_t* mutex)
|
|||
|
||||
int pthread_mutex_trylock(pthread_mutex_t* mutex)
|
||||
{
|
||||
auto* atomic = reinterpret_cast<Atomic<u32>*>(mutex->lock);
|
||||
auto& atomic = reinterpret_cast<Atomic<u32>&>(mutex->lock);
|
||||
u32 expected = false;
|
||||
if (!atomic->compare_exchange_strong(expected, true, AK::memory_order_acq_rel)) {
|
||||
if (!atomic.compare_exchange_strong(expected, true, AK::memory_order_acq_rel)) {
|
||||
if (mutex->type == PTHREAD_MUTEX_RECURSIVE && mutex->owner == pthread_self()) {
|
||||
mutex->level++;
|
||||
return 0;
|
||||
|
|
Loading…
Reference in a new issue