Apply the same logic as in r23731 to all other places in the semaphore code
where threads are enqueued into the run queue. git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@23733 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
24e3a405c4
commit
d925650968
@ -320,8 +320,13 @@ sem_timeout(timer *data)
|
||||
GRAB_THREAD_LOCK();
|
||||
// put the threads in the run q here to make sure we dont deadlock in sem_interrupt_thread
|
||||
while ((thread = thread_dequeue(&wakeupQueue)) != NULL) {
|
||||
if (thread->state == B_THREAD_RUNNING)
|
||||
thread->next_state = B_THREAD_READY;
|
||||
else {
|
||||
thread->state = thread->next_state = B_THREAD_READY;
|
||||
scheduler_enqueue_in_run_queue(thread);
|
||||
}
|
||||
}
|
||||
RELEASE_THREAD_LOCK();
|
||||
|
||||
restore_interrupts(state);
|
||||
@ -610,8 +615,13 @@ sem_interrupt_thread(struct thread *thread)
|
||||
RELEASE_SEM_LOCK(sSems[slot]);
|
||||
|
||||
while ((thread = thread_dequeue(&wakeupQueue)) != NULL) {
|
||||
if (thread->state == B_THREAD_RUNNING)
|
||||
thread->next_state = B_THREAD_READY;
|
||||
else {
|
||||
thread->state = thread->next_state = B_THREAD_READY;
|
||||
scheduler_enqueue_in_run_queue(thread);
|
||||
}
|
||||
}
|
||||
|
||||
return B_NO_ERROR;
|
||||
}
|
||||
@ -643,7 +653,6 @@ remove_thread_from_sem(struct thread *thread, struct sem_entry *sem,
|
||||
thread->sem.count -= delta;
|
||||
if (thread->sem.count <= 0) {
|
||||
thread = thread_dequeue(&sem->u.used.queue);
|
||||
thread->state = thread->next_state = B_THREAD_READY;
|
||||
thread_enqueue(thread, queue);
|
||||
}
|
||||
sem->u.used.count -= delta;
|
||||
@ -763,7 +772,6 @@ delete_sem(sem_id id)
|
||||
|
||||
// free any threads waiting for this semaphore
|
||||
while ((thread = thread_dequeue(&sSems[slot].u.used.queue)) != NULL) {
|
||||
thread->state = B_THREAD_READY;
|
||||
thread->sem.acquire_status = B_BAD_SEM_ID;
|
||||
thread->sem.count = 0;
|
||||
thread_enqueue(thread, &releaseQueue);
|
||||
@ -785,8 +793,13 @@ delete_sem(sem_id id)
|
||||
if (releasedThreads > 0) {
|
||||
GRAB_THREAD_LOCK();
|
||||
while ((thread = thread_dequeue(&releaseQueue)) != NULL) {
|
||||
if (thread->state == B_THREAD_RUNNING)
|
||||
thread->next_state = B_THREAD_READY;
|
||||
else {
|
||||
thread->state = thread->next_state = B_THREAD_READY;
|
||||
scheduler_enqueue_in_run_queue(thread);
|
||||
}
|
||||
}
|
||||
scheduler_reschedule();
|
||||
RELEASE_THREAD_LOCK();
|
||||
}
|
||||
@ -943,8 +956,13 @@ switch_sem_etc(sem_id semToBeReleased, sem_id id, int32 count,
|
||||
}
|
||||
RELEASE_SEM_LOCK(sSems[slot]);
|
||||
while ((thread = thread_dequeue(&wakeupQueue)) != NULL) {
|
||||
if (thread->state == B_THREAD_RUNNING)
|
||||
thread->next_state = B_THREAD_READY;
|
||||
else {
|
||||
thread->state = thread->next_state = B_THREAD_READY;
|
||||
scheduler_enqueue_in_run_queue(thread);
|
||||
}
|
||||
}
|
||||
// fall through and reschedule since another thread with a higher priority may have been woken up
|
||||
}
|
||||
scheduler_reschedule();
|
||||
@ -1093,7 +1111,7 @@ release_sem_etc(sem_id id, int32 count, uint32 flags)
|
||||
if (thread->state == B_THREAD_RUNNING)
|
||||
thread->next_state = B_THREAD_READY;
|
||||
else {
|
||||
thread->state = B_THREAD_READY;
|
||||
thread->state = thread->next_state = B_THREAD_READY;
|
||||
scheduler_enqueue_in_run_queue(thread);
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user