X-Git-Url: http://plrg.eecs.uci.edu/git/?p=c11tester.git;a=blobdiff_plain;f=history.h;h=f06c2e44e46cb189c34d06f870063a75a0dcd772;hp=2cf93f8a6480cc22b339a9fffbfb5b12019cd625;hb=54fe8f7be84c753df62188139cd59ab8207ea3e0;hpb=c635df842e0738f2478bdd21a103155ee5c58c97 diff --git a/history.h b/history.h index 2cf93f8a..f06c2e44 100644 --- a/history.h +++ b/history.h @@ -28,7 +28,7 @@ public: FuncNode * get_curr_func_node(thread_id_t tid); void update_write_history(void * location, uint64_t write_val); - HashTable * getWriteHistory() { return write_history; } + HashTable * getWriteHistory() { return write_history; } void update_loc_rd_func_nodes_map(void * location, FuncNode * node); void update_loc_wr_func_nodes_map(void * location, FuncNode * node); SnapVector * getRdFuncNodes(void * location); @@ -38,8 +38,11 @@ public: void remove_waiting_write(thread_id_t tid); void check_waiting_write(ModelAction * write_act); SnapVector * getThrdWaitingWrite() { return thrd_waiting_write; } - thrd_id_set_t * getWaitingFor(thread_id_t tid); + WaitObj * getWaitObj(thread_id_t tid); + void add_waiting_thread(thread_id_t self_id, thread_id_t waiting_for_id, FuncNode * target_node, int dist); + void remove_waiting_thread(thread_id_t tid); + void stop_waiting_for_node(thread_id_t self_id, thread_id_t waiting_for_id, FuncNode * target_node); SnapVector * getThrdInstActMap(uint32_t func_id); @@ -61,7 +64,7 @@ private: ModelVector func_nodes; /* Map a location to a set of values that have been written to it */ - HashTable * write_history; + HashTable * write_history; /* Map a location to FuncNodes that may read from it */ HashTable *, uintptr_t, 0> * loc_rd_func_nodes_map; @@ -70,15 +73,32 @@ private: HashTable *, uintptr_t, 0> * loc_wr_func_nodes_map; HashTable *, uintptr_t, 0> * loc_waiting_writes_map; + + /* Keeps track of atomic actions that thread i has performed in some + * function. Index of SnapVector is thread id. SnapList simulates + * the call stack. + */ + SnapVector< SnapList *> * thrd_func_act_lists; + + /* thrd_func_list stores a list of function ids for each thread. + * Each element in thrd_func_list stores the functions that + * thread i has entered and yet to exit from + */ + SnapVector * thrd_func_list; + SnapVector * thrd_last_entered_func; + /* The write values each paused thread is waiting for */ SnapVector * thrd_waiting_write; SnapVector * thrd_wait_obj; - /* A run-time map from FuncInst to ModelAction per each thread, per each FuncNode. + /* A run-time map from FuncInst to ModelAction per thread, per FuncNode. * Manipulated by FuncNode, and needed by NewFuzzer */ HashTable *, int, 0> * func_inst_act_maps; bool skip_action(ModelAction * act, SnapList * curr_act_list); + void monitor_waiting_thread(uint32_t func_id, thread_id_t tid); + void monitor_waiting_thread_counter(thread_id_t tid); + }; #endif /* __HISTORY_H__ */