axeld + bonefish:
Before starting to wait on a condition variable check for pending signals first, if the call is interruptable. git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@23980 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
7d2d758d46
commit
fe19cba8f0
@ -156,8 +156,16 @@ PrivateConditionVariableEntry::Wait(uint32 flags)
|
|||||||
entry = entry->fThreadNext;
|
entry = entry->fThreadNext;
|
||||||
}
|
}
|
||||||
|
|
||||||
// all entries are unnotified -- wait
|
// When interruptable, check pending signals first
|
||||||
struct thread* thread = thread_get_current_thread();
|
struct thread* thread = thread_get_current_thread();
|
||||||
|
if (((flags & B_CAN_INTERRUPT)
|
||||||
|
&& (thread->sig_pending & ~thread->sig_block_mask) != 0)
|
||||||
|
|| ((flags & B_KILL_CAN_INTERRUPT)
|
||||||
|
&& (thread->sig_pending & KILL_SIGNALS))) {
|
||||||
|
return B_INTERRUPTED;
|
||||||
|
}
|
||||||
|
|
||||||
|
// wait
|
||||||
thread->next_state = B_THREAD_WAITING;
|
thread->next_state = B_THREAD_WAITING;
|
||||||
thread->condition_variable_entry = firstEntry;
|
thread->condition_variable_entry = firstEntry;
|
||||||
thread->sem.blocking = -1;
|
thread->sem.blocking = -1;
|
||||||
|
Loading…
Reference in New Issue
Block a user