projects
/
model-checker.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Fix snapshot code
[model-checker.git]
/
model.h
diff --git
a/model.h
b/model.h
index 89d089d1051aafbcd95ae6cd4961c23f764be739..94483536cf4e7468346417c7d7ad87887ecaac9e 100644
(file)
--- a/
model.h
+++ b/
model.h
@@
-47,20
+47,25
@@
public:
void run();
void run();
+ /** Restart the model checker, intended for pluggins. */
+ void restart();
+
+ /** Exit the model checker, intended for pluggins. */
+ void exit_model_checker();
+
+ /** Check the exit_flag. */
+ bool get_exit_flag() const { return exit_flag; }
+
/** @returns the context for the main model-checking system thread */
ucontext_t * get_system_context() { return &system_context; }
/** @returns the context for the main model-checking system thread */
ucontext_t * get_system_context() { return &system_context; }
-
const
ModelExecution * get_execution() const { return execution; }
+ ModelExecution * get_execution() const { return execution; }
int get_execution_number() const { return execution_number; }
Thread * get_thread(thread_id_t tid) const;
Thread * get_thread(const ModelAction *act) const;
int get_execution_number() const { return execution_number; }
Thread * get_thread(thread_id_t tid) const;
Thread * get_thread(const ModelAction *act) const;
- bool is_enabled(Thread *t) const;
- bool is_enabled(thread_id_t tid) const;
-
- unsigned int get_num_threads() const;
Thread * get_current_thread() const;
void switch_from_master(Thread *thread);
Thread * get_current_thread() const;
void switch_from_master(Thread *thread);
@@
-70,15
+75,15
@@
public:
void assert_user_bug(const char *msg);
const model_params params;
void assert_user_bug(const char *msg);
const model_params params;
- void add_trace_analysis(TraceAnalysis *a) {
- trace_analyses.push_back(a);
- }
-
- action_list_t * get_actions_on_obj(void * obj, thread_id_t tid);
- ModelAction * get_last_action(thread_id_t tid) const;
-
+ void add_trace_analysis(TraceAnalysis *a) { trace_analyses.push_back(a); }
+ void set_inspect_plugin(TraceAnalysis *a) { inspect_plugin=a; }
MEMALLOC
private:
MEMALLOC
private:
+ /** Flag indicates whether to restart the model checker. */
+ bool restart_flag;
+ /** Flag indicates whether to exit the model checker. */
+ bool exit_flag;
+
/** The scheduler to use: tracks the running/ready Threads */
Scheduler * const scheduler;
NodeStack * const node_stack;
/** The scheduler to use: tracks the running/ready Threads */
Scheduler * const scheduler;
NodeStack * const node_stack;
@@
-86,6
+91,8
@@
private:
int execution_number;
int execution_number;
+ unsigned int get_num_threads() const;
+
void execute_sleep_set();
bool next_execution();
void execute_sleep_set();
bool next_execution();
@@
-102,6
+109,10
@@
private:
ModelVector<TraceAnalysis *> trace_analyses;
ModelVector<TraceAnalysis *> trace_analyses;
+ /** @bref Implement restart. */
+ void do_restart();
+ /** @bref Plugin that can inspect new actions. */
+ TraceAnalysis *inspect_plugin;
/** @brief The cumulative execution stats */
struct execution_stats stats;
void record_stats();
/** @brief The cumulative execution stats */
struct execution_stats stats;
void record_stats();