From 5afb7f87917a67712fe289470ee03de0864fee7d Mon Sep 17 00:00:00 2001 From: weiyu Date: Tue, 22 Jan 2019 13:58:14 -0800 Subject: [PATCH] pthread join seems to be working --- action.cc | 13 +++++-------- action.h | 9 +++++---- execution.cc | 4 +++- model.cc | 1 + threads.cc | 14 +++++++++----- 5 files changed, 23 insertions(+), 18 deletions(-) diff --git a/action.cc b/action.cc index ea492105..359316d1 100644 --- a/action.cc +++ b/action.cc @@ -88,7 +88,7 @@ bool ModelAction::is_thread_start() const bool ModelAction::is_thread_join() const { - return type == THREAD_JOIN; + return type == THREAD_JOIN || type == PTHREAD_JOIN; } bool ModelAction::is_relseq_fixup() const @@ -277,17 +277,14 @@ void ModelAction::copy_typeandorder(ModelAction * act) Thread * ModelAction::get_thread_operand() const { if (type == THREAD_CREATE) { - /* THREAD_CREATE stores its (Thread *) in a thrd_t::priv */ - thrd_t *thrd = (thrd_t *)get_location(); - return thrd->priv; + /* thread_operand is set in execution.cc */ + return thread_operand; } else if (type == PTHREAD_CREATE) { - // not implemented - return NULL; + return thread_operand; } else if (type == THREAD_JOIN) { /* THREAD_JOIN uses (Thread *) for location */ return (Thread *)get_location(); } else if (type == PTHREAD_JOIN) { - // WL: to be added (modified) return (Thread *)get_location(); } else return NULL; @@ -597,7 +594,7 @@ void ModelAction::print() const { const char *type_str = get_type_str(), *mo_str = get_mo_str(); - model_print("%-4d %-2d %-13s %7s %14p %-#18" PRIx64, + model_print("%-4d %-2d %-14s %7s %14p %-#18" PRIx64, seq_number, id_to_int(tid), type_str, mo_str, location, get_return_value()); if (is_read()) { if (reads_from) diff --git a/action.h b/action.h index f7b66a89..f54c9d2a 100644 --- a/action.h +++ b/action.h @@ -189,10 +189,11 @@ public: bool may_read_from(const Promise *promise) const; MEMALLOC -// Added by WL - void set_value(uint64_t val) { - value = val; - } + void set_value(uint64_t val) { value = val; } + + /* to accomodate pthread create and join */ + Thread * thread_operand; + void set_thread_operand(Thread *th) { thread_operand = th; } private: const char * get_type_str() const; diff --git a/execution.cc b/execution.cc index 87e54252..fb72e818 100644 --- a/execution.cc +++ b/execution.cc @@ -949,6 +949,7 @@ bool ModelExecution::process_thread_action(ModelAction *curr) thrd_t *thrd = (thrd_t *)curr->get_location(); struct thread_params *params = (struct thread_params *)curr->get_value(); Thread *th = new Thread(get_next_id(), thrd, params->func, params->arg, get_thread(curr)); + curr->set_thread_operand(th); add_thread(th); th->set_creation(curr); /* Promises can be satisfied by children */ @@ -963,6 +964,7 @@ bool ModelExecution::process_thread_action(ModelAction *curr) thrd_t *thrd = (thrd_t *)curr->get_location(); struct pthread_params *params = (struct pthread_params *)curr->get_value(); Thread *th = new Thread(get_next_id(), thrd, params->func, params->arg, get_thread(curr)); + curr->set_thread_operand(th); add_thread(th); th->set_creation(curr); /* Promises can be satisfied by children */ @@ -981,11 +983,11 @@ bool ModelExecution::process_thread_action(ModelAction *curr) break; } case PTHREAD_JOIN: { - break; // WL: to be add (modified) Thread *blocking = curr->get_thread_operand(); ModelAction *act = get_last_action(blocking->get_id()); synchronize(act, curr); updated = true; /* trigger rel-seq checks */ + break; // WL: to be add (modified) } case THREAD_FINISH: { diff --git a/model.cc b/model.cc index 64bef579..9d147dfc 100644 --- a/model.cc +++ b/model.cc @@ -542,6 +542,7 @@ void ModelChecker::run() } while (!should_terminate_execution()); has_next = next_execution(); + pthread_map.clear(); i++; } while (i<100); // while (has_next); diff --git a/threads.cc b/threads.cc index d7034e93..77b13c69 100644 --- a/threads.cc +++ b/threads.cc @@ -51,7 +51,11 @@ void thread_startup() model->switch_to_master(new ModelAction(THREAD_START, std::memory_order_seq_cst, curr_thread)); /* Call the actual thread function */ - curr_thread->start_routine(curr_thread->arg); + if (curr_thread->start_routine != NULL) { + curr_thread->start_routine(curr_thread->arg); + } else if (curr_thread->pstart_routine != NULL) { + curr_thread->pstart_routine(curr_thread->arg); + } /* Finish thread properly */ model->switch_to_master(new ModelAction(THREAD_FINISH, std::memory_order_seq_cst, curr_thread)); } @@ -155,6 +159,7 @@ Thread::Thread(thread_id_t tid, thrd_t *t, void (*func)(void *), void *a, Thread creation(NULL), pending(NULL), start_routine(func), + pstart_routine(NULL), arg(a), user_thread(t), id(tid), @@ -169,7 +174,7 @@ Thread::Thread(thread_id_t tid, thrd_t *t, void (*func)(void *), void *a, Thread if (ret) model_print("Error in create_context\n"); - // user_thread->priv = this; // WL + user_thread->priv = this; // WL } /** @@ -234,9 +239,8 @@ Thread * Thread::waiting_on() const if (pending->get_type() == THREAD_JOIN) return pending->get_thread_operand(); - else if (pending->get_type() == PTHREAD_JOIN) { - // WL: to be added - } + else if (pending->get_type() == PTHREAD_JOIN) + return pending->get_thread_operand(); else if (pending->is_lock()) return (Thread *)pending->get_mutex()->get_state()->locked; return NULL; -- 2.34.1