class Scheduler;
class Thread;
class ClockVector;
+class Trace_Analysis;
struct model_snapshot_members;
/** @brief Shorthand for a list of release sequence heads */
int maxreads;
int maxfuturedelay;
bool yieldon;
+ bool sc_trace_analysis;
unsigned int fairwindow;
unsigned int enabledcount;
unsigned int bound;
void check_promises(thread_id_t tid, ClockVector *old_cv, ClockVector *merge_cv);
bool isfeasibleprefix() const;
- bool assert_bug(const char *msg);
+ bool assert_bug(const char *msg, ...);
void assert_user_bug(const char *msg);
const model_params params;
Node * get_curr_node() const;
+ void add_trace_analysis(Trace_Analysis * a) {
+ trace_analyses->push_back(a);
+ }
MEMALLOC
private:
SnapVector<ModelAction *> * const thrd_last_action;
SnapVector<ModelAction *> * const thrd_last_fence_release;
NodeStack * const node_stack;
+ ModelVector<Trace_Analysis *> * trace_analyses;
+
/** Private data members that should be snapshotted. They are grouped
* together for efficiency and maintainability. */
/** @brief The cumulative execution stats */
struct execution_stats stats;
void record_stats();
-
+ void run_trace_analyses();
void print_infeasibility(const char *prefix) const;
bool is_feasible_prefix_ignore_relseq() const;
bool is_infeasible() const;