run.sh: provide gdb option
[c11tester.git] / model.h
1 #ifndef __MODEL_H__
2 #define __MODEL_H__
3
4 #include <list>
5 #include <map>
6 #include <vector>
7 #include <cstddef>
8 #include <ucontext.h>
9
10 #include "schedule.h"
11 #include "mymemory.h"
12 #include <utility>
13 #include "libthreads.h"
14 #include "libatomic.h"
15 #include "threads.h"
16 #include "action.h"
17
18 /* Forward declaration */
19 class TreeNode;
20 class Backtrack;
21
22 class ModelChecker {
23 public:
24         ModelChecker();
25         ~ModelChecker();
26         class Scheduler *scheduler;
27
28         void set_system_context(ucontext_t *ctxt) { system_context = ctxt; }
29         ucontext_t * get_system_context(void) { return system_context; }
30
31         void set_current_action(ModelAction *act) { current_action = act; }
32         void check_current_action(void);
33         void print_summary(void);
34         Thread * schedule_next_thread();
35
36         int add_thread(Thread *t);
37         void remove_thread(Thread *t);
38         Thread * get_thread(thread_id_t tid) { return thread_map[id_to_int(tid)]; }
39
40         thread_id_t get_next_id();
41         int get_next_seq_num();
42
43         int switch_to_master(ModelAction *act);
44
45         bool next_execution();
46   MEMALLOC
47 private:
48         int next_thread_id;
49         int used_sequence_numbers;
50         int num_executions;
51
52         ModelAction * get_last_conflict(ModelAction *act);
53         void set_backtracking(ModelAction *act);
54         thread_id_t get_next_replay_thread();
55         Backtrack * get_next_backtrack();
56         void reset_to_initial_state();
57
58         void print_list(action_list_t *list);
59
60         class ModelAction *current_action;
61         Backtrack *exploring;
62         thread_id_t nextThread;
63
64         ucontext_t *system_context;
65         action_list_t *action_trace;
66         std::map<int, class Thread *, std::less< int >, MyAlloc< std::pair< const int, class Thread * > > > thread_map;
67         class TreeNode *rootNode, *currentNode;
68         std::list<class Backtrack *, MyAlloc< class Backtrack * > > backtrack_list;
69 };
70
71 extern ModelChecker *model;
72
73 #endif /* __MODEL_H__ */