#include "classlist.h"
#include "mymemory.h"
#include "stl-model.h"
+#include "predicate.h"
+
+struct node_dist_info {
+ node_dist_info(thread_id_t tid, FuncNode * node, int distance) :
+ tid(tid),
+ target(node),
+ dist(distance)
+ {}
+
+ thread_id_t tid;
+ FuncNode * target;
+ int dist;
+
+ SNAPSHOTALLOC
+};
class NewFuzzer : public Fuzzer {
public:
NewFuzzer();
int selectWrite(ModelAction *read, SnapVector<ModelAction *>* rf_set);
- Predicate * get_selected_child_branch(thread_id_t tid);
bool has_paused_threads();
void notify_paused_thread(Thread * thread);
bool shouldWake(const ModelAction * sleep);
bool shouldWait(const ModelAction * wait);
- void register_engine(ModelHistory * history, ModelExecution * execution);
+ void register_engine(ModelChecker * model, ModelExecution * execution);
+ Predicate * get_selected_child_branch(thread_id_t tid);
SNAPSHOTALLOC
private:
ModelExecution * execution;
SnapVector<ModelAction *> thrd_last_read_act;
- SnapVector<Predicate *> thrd_curr_pred;
+ SnapVector<FuncInst *> thrd_last_func_inst;
+
+ SnapVector<Predicate *> available_branches_tmp_storage;
SnapVector<Predicate *> thrd_selected_child_branch;
SnapVector< SnapVector<ModelAction *> *> thrd_pruned_writes;
- bool prune_writes(thread_id_t tid, Predicate * pred, SnapVector<ModelAction *> * rf_set, inst_act_map_t * inst_act_map);
+ bool check_branch_inst(Predicate * curr_pred, FuncInst * read_inst, SnapVector<ModelAction *> * rf_set);
Predicate * selectBranch(thread_id_t tid, Predicate * curr_pred, FuncInst * read_inst);
+ bool prune_writes(thread_id_t tid, Predicate * pred, SnapVector<ModelAction *> * rf_set);
+ int choose_branch_index(SnapVector<Predicate *> * branches);
/* The set of Threads put to sleep by NewFuzzer because no writes in rf_set satisfies the selected predicate. Only used by selectWrite.
*/
- SnapVector<Thread *> paused_thread_list;
- HashTable<Thread *, int, uintptr_t, 0> paused_thread_table;
+ SnapVector<Thread *> paused_thread_list; //-- (not in use)
+ HashTable<Thread *, int, uintptr_t, 0> paused_thread_table; //--
+
+ SnapVector<struct node_dist_info> dist_info_vec; //--
- void conditional_sleep(Thread * thread);
- void wake_up_paused_threads(int * threadlist, int * numthreads);
+ void conditional_sleep(Thread * thread); //--
+ void wake_up_paused_threads(int * threadlist, int * numthreads); //--
- void find_threads(ModelAction * pending_read);
+ bool find_threads(ModelAction * pending_read); //--
};
-#endif /* end of __NEWFUZZER_H__ */
+#endif /* end of __NEWFUZZER_H__ */