2 * @brief Core model checker.
12 #include "hashtable.h"
14 #include "modeltypes.h"
15 #include "stl-model.h"
18 #include "classlist.h"
19 #include "snapshot-interface.h"
21 typedef SnapList<ModelAction *> action_list_t;
23 /** @brief Model checker execution stats */
24 struct execution_stats {
25 int num_total; /**< @brief Total number of executions */
26 int num_buggy_executions; /** @brief Number of buggy executions */
27 int num_complete; /**< @brief Number of feasible, non-buggy, complete executions */
30 /** @brief The central structure for model-checking */
35 model_params * getParams();
38 /** Exit the model checker, intended for pluggins. */
39 void exit_model_checker();
41 /** @returns the context for the main model-checking system thread */
42 ucontext_t * get_system_context() { return &system_context; }
44 ModelExecution * get_execution() const { return execution; }
45 ModelHistory * get_history() const { return history; }
47 int get_execution_number() const { return execution_number; }
49 Thread * get_thread(thread_id_t tid) const;
50 Thread * get_thread(const ModelAction *act) const;
52 Thread * get_current_thread() const;
54 void switch_from_master(Thread *thread);
55 uint64_t switch_to_master(ModelAction *act);
56 uint64_t switch_thread(ModelAction *act);
58 void assert_bug(const char *msg, ...);
60 void assert_user_bug(const char *msg);
63 void add_trace_analysis(TraceAnalysis *a) { trace_analyses.push_back(a); }
64 void set_inspect_plugin(TraceAnalysis *a) { inspect_plugin=a; }
66 Thread * getInitThread() {return init_thread;}
67 Scheduler * getScheduler() {return scheduler;}
70 /** Snapshot id we return to restart. */
73 /** The scheduler to use: tracks the running/ready Threads */
74 Scheduler * const scheduler;
75 ModelHistory * history;
76 ModelExecution *execution;
83 unsigned int get_num_threads() const;
85 void finish_execution(bool moreexecutions);
86 bool should_terminate_execution();
88 Thread * get_next_thread();
89 void reset_to_initial_state();
91 ucontext_t system_context;
93 ModelVector<TraceAnalysis *> trace_analyses;
95 /** @bref Plugin that can inspect new actions. */
96 TraceAnalysis *inspect_plugin;
97 /** @brief The cumulative execution stats */
98 struct execution_stats stats;
100 void run_trace_analyses();
101 void print_bugs() const;
102 void print_execution(bool printbugs) const;
103 void print_stats() const;
106 extern ModelChecker *model;
107 void parse_options(struct model_params *params);
108 void install_trace_analyses(ModelExecution *execution);
110 #endif /* __MODEL_H__ */