}
case THREAD_FINISH: {
Thread *th = get_thread(curr);
- while (!th->wait_list_empty()) {
- ModelAction *act = th->pop_wait_list();
- scheduler->wake(get_thread(act));
+ /* Wake up any joining threads */
+ for (unsigned int i = 0; i < get_num_threads(); i++) {
+ Thread *waiting = get_thread(int_to_id(i));
+ if (waiting->waiting_on() == th &&
+ waiting->get_pending()->is_thread_join())
+ scheduler->wake(waiting);
}
th->complete();
/* Completed thread can't satisfy promises */
} else if (curr->is_thread_join()) {
Thread *blocking = curr->get_thread_operand();
if (!blocking->is_complete()) {
- blocking->push_wait_list(curr);
thread_blocking_check_promises(blocking, get_thread(curr));
return false;
}
/** @return True if this thread is blocked */
bool is_blocked() const { return state == THREAD_BLOCKED; }
- /** @return True if no threads are waiting on this Thread */
- bool wait_list_empty() const { return wait_list.empty(); }
-
- /**
- * Add a ModelAction to the waiting list for this thread.
- * @param t The ModelAction to add. Must be a JOIN.
- */
- void push_wait_list(ModelAction *act) { wait_list.push_back(act); }
-
- unsigned int num_wait_list() const {
- return wait_list.size();
- }
-
- ModelAction * get_waiter(unsigned int i) const {
- return wait_list[i];
- }
-
/** @return The pending (next) ModelAction for this Thread
* @see Thread::pending */
ModelAction * get_pending() const { return pending; }
Thread * waiting_on() const;
bool is_waiting_on(const Thread *t) const;
- /**
- * Remove one ModelAction from the waiting list
- * @return The ModelAction that was removed from the waiting list
- */
- ModelAction * pop_wait_list() {
- ModelAction *ret = wait_list.front();
- wait_list.pop_back();
- return ret;
- }
-
bool is_model_thread() const { return model_thread; }
friend void thread_startup();
thread_id_t id;
thread_state state;
- /**
- * A list of ModelActions waiting on this Thread. Particularly, this
- * list is used for thread joins, where another Thread waits for this
- * Thread to complete
- */
- SnapVector<ModelAction *> wait_list;
-
/**
* The value returned by the last action in this thread
* @see Thread::set_return_value()