From: weiyu Date: Thu, 11 Jul 2019 23:38:06 +0000 (-0700) Subject: commit stuff before merge X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=080c029c02600d44ad7d797c8e373d4df899f9b0;p=c11tester.git commit stuff before merge --- diff --git a/funcinst.cc b/funcinst.cc index d3593fb7..61e3d922 100644 --- a/funcinst.cc +++ b/funcinst.cc @@ -17,7 +17,8 @@ FuncInst::FuncInst(ModelAction *act, FuncNode *func_node) : * @return false: other is already in predecessors * true : other is added to precedessors */ -bool FuncInst::add_pred(FuncInst * other) { +bool FuncInst::add_pred(FuncInst * other) +{ func_inst_list_mt::iterator it; for (it = predecessors.begin(); it != predecessors.end(); it++) { FuncInst * inst = *it; @@ -29,7 +30,8 @@ bool FuncInst::add_pred(FuncInst * other) { return true; } -bool FuncInst::add_succ(FuncInst * other) { +bool FuncInst::add_succ(FuncInst * other) +{ func_inst_list_mt::iterator it; for (it = successors.begin(); it != successors.end(); it++) { FuncInst * inst = *it; @@ -41,7 +43,8 @@ bool FuncInst::add_succ(FuncInst * other) { return true; } -FuncInst * FuncInst::search_in_collision(ModelAction *act) { +FuncInst * FuncInst::search_in_collision(ModelAction *act) +{ action_type type = act->get_type(); func_inst_list_mt::iterator it; @@ -52,3 +55,8 @@ FuncInst * FuncInst::search_in_collision(ModelAction *act) { } return NULL; } + +bool FuncInst::is_read() const +{ + return type == ATOMIC_READ || type == ATOMIC_RMWR || type == ATOMIC_RMWRCAS; +} diff --git a/funcinst.h b/funcinst.h index 6cb8c1a1..85b9c20e 100644 --- a/funcinst.h +++ b/funcinst.h @@ -25,6 +25,8 @@ public: func_inst_list_mt * get_preds() { return &predecessors; } func_inst_list_mt * get_succs() { return &successors; } + bool is_read() const; + MEMALLOC private: //ModelAction * const action; diff --git a/funcnode.cc b/funcnode.cc index 1f59a548..ce91815f 100644 --- a/funcnode.cc +++ b/funcnode.cc @@ -1,15 +1,19 @@ #include "funcnode.h" FuncNode::FuncNode() : - func_insts(), + func_inst_map(), inst_list(), entry_insts() {} +/* Check whether FuncInst with the same type, position, and location + * as act has been added to func_inst_map or not. If so, return it; + * if not, add it and return it. + * + * @return FuncInst with the same type, position, and location as act */ FuncInst * FuncNode::get_or_add_action(ModelAction *act) { ASSERT(act); - const char * position = act->get_position(); /* Actions THREAD_CREATE, THREAD_START, THREAD_YIELD, THREAD_JOIN, @@ -20,8 +24,8 @@ FuncInst * FuncNode::get_or_add_action(ModelAction *act) if (position == NULL) return NULL; - if ( func_insts.contains(position) ) { - FuncInst * inst = func_insts.get(position); + if ( func_inst_map.contains(position) ) { + FuncInst * inst = func_inst_map.get(position); if (inst->get_type() != act->get_type() ) { // model_print("action with a different type occurs at line number %s\n", position); @@ -35,8 +39,9 @@ FuncInst * FuncNode::get_or_add_action(ModelAction *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"); - + if (func_inst->is_read()) + group_reads_by_loc(func_inst); + return func_inst; } @@ -44,9 +49,12 @@ FuncInst * FuncNode::get_or_add_action(ModelAction *act) } FuncInst * func_inst = new FuncInst(act, this); - func_insts.put(position, func_inst); - + func_inst_map.put(position, func_inst); inst_list.push_back(func_inst); + + if (func_inst->is_read()) + group_reads_by_loc(func_inst); + return func_inst; } @@ -63,3 +71,30 @@ void FuncNode::add_entry_inst(FuncInst * inst) entry_insts.push_back(inst); } + +/* group atomic read actions by memory location */ +void FuncNode::group_reads_by_loc(FuncInst * inst) +{ + ASSERT(inst); + if ( !inst->is_read() ) + return; + + void * location = inst->get_location(); + + func_inst_list_mt * reads; + if ( !reads_by_loc.contains(location) ) { + reads = new func_inst_list_mt(); + reads->push_back(inst); + reads_by_loc.put(location, reads); + return; + } + + reads = reads_by_loc.get(location); + func_inst_list_mt::iterator it; + for (it = reads->begin(); it != reads->end(); it++) { + if (inst == *it) + return; + } + + reads->push_back(inst); +} diff --git a/funcnode.h b/funcnode.h index 3d3aaa4c..51f19f0c 100644 --- a/funcnode.h +++ b/funcnode.h @@ -18,11 +18,13 @@ public: FuncInst * get_or_add_action(ModelAction *act); - HashTable * getFuncInsts() { return &func_insts; } + HashTable * getFuncInstMap() { return &func_inst_map; } 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); + void group_reads_by_loc(FuncInst * inst); + MEMALLOC private: uint32_t func_id; @@ -34,11 +36,14 @@ private: * To do: cds_atomic_compare_exchange contains three atomic operations * that are feeded with the same source line number by llvm pass */ - HashTable func_insts; + HashTable func_inst_map; - /* list of all atomic instructions in this function */ + /* list of all atomic actions in this function */ func_inst_list_mt inst_list; - /* possible entry atomic instructions in this function */ + /* possible entry atomic actions in this function */ func_inst_list_mt entry_insts; + + /* group atomic read actions by memory location */ + HashTable reads_by_loc; };