From: weiyu Date: Tue, 9 Jul 2019 22:49:48 +0000 (-0700) Subject: add entry atomic instructions to FuncNode X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=6ded70495d74d65f8c6261b11685156b2325e709;p=c11tester.git add entry atomic instructions to FuncNode --- diff --git a/funcinst.cc b/funcinst.cc index 28754891..d3593fb7 100644 --- a/funcinst.cc +++ b/funcinst.cc @@ -1,14 +1,22 @@ #include "funcinst.h" -FuncInst::FuncInst(ModelAction *act) : +FuncInst::FuncInst(ModelAction *act, FuncNode *func_node) : collisions() { ASSERT(act); + ASSERT(func_node); this->position = act->get_position(); this->location = act->get_location(); this->type = act->get_type(); + this->func_node = func_node; } +/* @param other Preceding FuncInst in the same execution trace + * Add other to predecessors if it has been added + * + * @return false: other is already in predecessors + * true : other is added to precedessors + */ bool FuncInst::add_pred(FuncInst * other) { func_inst_list_mt::iterator it; for (it = predecessors.begin(); it != predecessors.end(); it++) { diff --git a/funcinst.h b/funcinst.h index 3f2307e1..6cb8c1a1 100644 --- a/funcinst.h +++ b/funcinst.h @@ -7,13 +7,14 @@ typedef ModelList func_inst_list_mt; class FuncInst { public: - FuncInst(ModelAction *act); + FuncInst(ModelAction *act, FuncNode *func_node); ~FuncInst(); //ModelAction * get_action() const { return action; } const char * get_position() const { return position; } void * get_location() const { return location; } action_type get_type() const { return type; } + FuncNode * get_func_node() const { return func_node; } bool add_pred(FuncInst * other); bool add_succ(FuncInst * other); @@ -28,10 +29,15 @@ public: private: //ModelAction * const action; const char * position; - void *location; + void * location; action_type type; + FuncNode * func_node; + /* collisions store a list of FuncInsts with the same position + * but different action types. For example, CAS is broken down + * as three different atomic operations in cmodelint.cc */ func_inst_list_mt collisions; + func_inst_list_mt predecessors; func_inst_list_mt successors; }; diff --git a/funcnode.cc b/funcnode.cc index 1fadc3b4..1f59a548 100644 --- a/funcnode.cc +++ b/funcnode.cc @@ -17,9 +17,8 @@ FuncInst * FuncNode::get_or_add_action(ModelAction *act) * ATOMIC_LOCK, ATOMIC_TRYLOCK, and ATOMIC_UNLOCK are not tagged with their * source line numbers */ - if (position == NULL) { + if (position == NULL) return NULL; - } if ( func_insts.contains(position) ) { FuncInst * inst = func_insts.get(position); @@ -33,7 +32,7 @@ FuncInst * FuncNode::get_or_add_action(ModelAction *act) return func_inst; } - func_inst = new FuncInst(act); + func_inst = new FuncInst(act, this); inst->get_collisions()->push_back(func_inst); inst_list.push_back(func_inst); // delete? // model_print("collision added\n"); @@ -44,9 +43,23 @@ FuncInst * FuncNode::get_or_add_action(ModelAction *act) return inst; } - FuncInst * func_inst = new FuncInst(act); + FuncInst * func_inst = new FuncInst(act, this); func_insts.put(position, func_inst); inst_list.push_back(func_inst); return func_inst; } + +void FuncNode::add_entry_inst(FuncInst * inst) +{ + if (inst == NULL) + return; + + func_inst_list_mt::iterator it; + for (it = entry_insts.begin(); it != entry_insts.end(); it++) { + if (inst == *it) + return; + } + + entry_insts.push_back(inst); +} diff --git a/funcnode.h b/funcnode.h index eb7bc794..3d3aaa4c 100644 --- a/funcnode.h +++ b/funcnode.h @@ -11,16 +11,18 @@ public: FuncNode(); ~FuncNode(); - FuncInst * get_or_add_action(ModelAction *act); - - HashTable * getFuncInsts() { return &func_insts; } - func_inst_list_mt * get_inst_list() { return &inst_list; } - uint32_t get_func_id() { return func_id; } const char * get_func_name() { return func_name; } void set_func_id(uint32_t id) { func_id = id; } void set_func_name(const char * name) { func_name = name; } + FuncInst * get_or_add_action(ModelAction *act); + + HashTable * getFuncInsts() { return &func_insts; } + func_inst_list_mt * get_inst_list() { return &inst_list; } + func_inst_list_mt * get_entry_insts() { return &entry_insts; } + void add_entry_inst(FuncInst * inst); + MEMALLOC private: uint32_t func_id; @@ -37,6 +39,6 @@ private: /* list of all atomic instructions in this function */ func_inst_list_mt inst_list; - /* possible entry (atomic) instructions in this function */ + /* possible entry atomic instructions in this function */ func_inst_list_mt entry_insts; }; diff --git a/history.cc b/history.cc index 7452c5c1..d81c50fb 100644 --- a/history.cc +++ b/history.cc @@ -121,9 +121,14 @@ void ModelHistory::link_insts(func_inst_list_t * inst_list) return; func_inst_list_t::iterator it = inst_list->begin(); - func_inst_list_t::iterator prev = inst_list->end(); - it++; + func_inst_list_t::iterator prev; + + /* add the first instruction to the list of entry insts */ + FuncInst * entry_inst = *it; + FuncNode * func_node = entry_inst->get_func_node(); + func_node->add_entry_inst(entry_inst); + it++; while (it != inst_list->end()) { prev = it; prev--; @@ -142,16 +147,27 @@ void ModelHistory::print() { for (uint32_t i = 0; i < func_atomics.size(); i++ ) { FuncNode * funcNode = func_atomics[i]; - func_inst_list_mt * inst_list = funcNode->get_inst_list(); - if (funcNode == NULL) continue; + func_inst_list_mt * entry_insts = funcNode->get_entry_insts(); + + model_print("function %s has entry actions\n", funcNode->get_func_name()); + func_inst_list_mt::iterator it; + for (it = entry_insts->begin(); it != entry_insts->end(); it++) { + FuncInst *inst = *it; + model_print("type: %d, at: %s\n", inst->get_type(), inst->get_position()); + } + +/* + func_inst_list_mt * inst_list = funcNode->get_inst_list(); + model_print("function %s has following actions\n", funcNode->get_func_name()); func_inst_list_mt::iterator it; for (it = inst_list->begin(); it != inst_list->end(); it++) { FuncInst *inst = *it; model_print("type: %d, at: %s\n", inst->get_type(), inst->get_position()); } +*/ } }