X-Git-Url: http://plrg.eecs.uci.edu/git/?p=c11tester.git;a=blobdiff_plain;f=history.h;h=431f978ea3f54e1053e682aadece744b9ed0ca44;hp=7a01d4027a150a1d8054f057e3c9854512d95ac4;hb=25d73096cfc14c655f94b01bb235cc5efd1d5696;hpb=4ba63eb5064000a0974833515006355d173bdcf9 diff --git a/history.h b/history.h index 7a01d402..431f978e 100644 --- a/history.h +++ b/history.h @@ -1,12 +1,13 @@ #ifndef __HISTORY_H__ #define __HISTORY_H__ -#include "stl-model.h" #include "common.h" +#include "classlist.h" #include "hashtable.h" -#include "hashset.h" #include "threads-model.h" +#define INIT_SEQ_NUMBER 0xffffffff + class ModelHistory { public: ModelHistory(); @@ -26,18 +27,34 @@ public: ModelVector * getFuncNodes() { return &func_nodes; } FuncNode * get_func_node(uint32_t func_id); + FuncNode * get_curr_func_node(thread_id_t tid); + + void update_write_history(void * location, uint64_t write_val); + 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); + SnapVector * getWrFuncNodes(void * location); - void add_to_write_history(void * location, uint64_t write_val); - HashTable * getWriteHistory() { return &write_history; } - void add_to_loc_func_nodes_map(void * location, FuncNode * node); + void add_waiting_write(ConcretePredicate * concrete); + void remove_waiting_write(thread_id_t tid); + void check_waiting_write(ModelAction * write_act); + SnapVector * getThrdWaitingWrite() { return thrd_waiting_write; } + + 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); void set_new_exec_flag(); - void print_write(); + void dump_func_node_graph(); void print_func_node(); + void print_waiting_threads(); MEMALLOC private: uint32_t func_counter; + modelclock_t last_seq_number; /* Map function names to integer ids */ HashTable func_map; @@ -47,12 +64,32 @@ private: ModelVector func_nodes; - HashTable write_history; + /* Map a location to a set of values that have been written to it */ + HashTable * write_history; /* Map a location to FuncNodes that may read from it */ - HashTable *, uintptr_t, 4> loc_func_nodes_map; + HashTable *, uintptr_t, 0> * loc_rd_func_nodes_map; + + /* Map a location to FuncNodes that may write to it */ + HashTable *, uintptr_t, 0> * loc_wr_func_nodes_map; + + HashTable *, uintptr_t, 0> * loc_waiting_writes_map; + + /* 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; + + bool skip_action(ModelAction * act); + void monitor_waiting_thread(uint32_t func_id, thread_id_t tid); + void monitor_waiting_thread_counter(thread_id_t tid); - void add_edges_between(FuncNode * prev_node, FuncNode * next_node); }; #endif /* __HISTORY_H__ */