kernel/posix: Do not use thread_block_locked()
This commit is contained in:
parent
d3e5752b11
commit
20ded5c2eb
@ -126,12 +126,11 @@ public:
|
|||||||
// Unlock the queue before blocking
|
// Unlock the queue before blocking
|
||||||
queueLocker->Unlock();
|
queueLocker->Unlock();
|
||||||
|
|
||||||
InterruptsSpinLocker schedulerLocker(gSchedulerLock);
|
|
||||||
// TODO: We've got a serious race condition: If BlockAndUnlock() returned due to
|
// TODO: We've got a serious race condition: If BlockAndUnlock() returned due to
|
||||||
// interruption, we will still be queued. A WakeUpThread() at this point will
|
// interruption, we will still be queued. A WakeUpThread() at this point will
|
||||||
// call thread_unblock() and might thus screw with our trying to re-lock the
|
// call thread_unblock() and might thus screw with our trying to re-lock the
|
||||||
// mutex.
|
// mutex.
|
||||||
return thread_block_locked(thread);
|
return thread_block();
|
||||||
}
|
}
|
||||||
|
|
||||||
void DoIpcSet(struct msqid_ds *result)
|
void DoIpcSet(struct msqid_ds *result)
|
||||||
|
@ -142,12 +142,11 @@ public:
|
|||||||
// Unlock the set before blocking
|
// Unlock the set before blocking
|
||||||
setLocker->Unlock();
|
setLocker->Unlock();
|
||||||
|
|
||||||
InterruptsSpinLocker schedulerLocker(gSchedulerLock);
|
|
||||||
// TODO: We've got a serious race condition: If BlockAndUnlock() returned due to
|
// TODO: We've got a serious race condition: If BlockAndUnlock() returned due to
|
||||||
// interruption, we will still be queued. A WakeUpThread() at this point will
|
// interruption, we will still be queued. A WakeUpThread() at this point will
|
||||||
// call thread_unblock() and might thus screw with our trying to re-lock the
|
// call thread_unblock() and might thus screw with our trying to re-lock the
|
||||||
// mutex.
|
// mutex.
|
||||||
return thread_block_locked(thread);
|
return thread_block();
|
||||||
}
|
}
|
||||||
|
|
||||||
void Deque(queued_thread *queueEntry, bool waitForZero)
|
void Deque(queued_thread *queueEntry, bool waitForZero)
|
||||||
|
Loading…
Reference in New Issue
Block a user