X-Git-Url: http://demsky.eecs.uci.edu/git/?a=blobdiff_plain;f=scanalysis.h;h=988c8f75c13ad58f0fdfc44ebd3e936bb59601e1;hb=2d0d4ac38e05905a6633b3f2d5112ccadd45c27f;hp=047793045e63c954b03b775fd433738aaf8d08d7;hpb=473bdc841f3b03b722911a5fa0b4f21ba3a217ed;p=model-checker.git diff --git a/scanalysis.h b/scanalysis.h index 0477930..988c8f7 100644 --- a/scanalysis.h +++ b/scanalysis.h @@ -3,24 +3,37 @@ #include "traceanalysis.h" #include "hashtable.h" +struct sc_statistics { + unsigned long long elapsedtime; + unsigned int sccount; + unsigned int nonsccount; +}; + class SCAnalysis : public TraceAnalysis { public: - SCAnalysis(const ModelExecution *execution); + SCAnalysis(); ~SCAnalysis(); + virtual void setExecution(ModelExecution * execution); virtual void analyze(action_list_t *); + virtual const char * name(); + virtual bool option(char *); + virtual void finish(); + SNAPSHOTALLOC private: + void update_stats(); void print_list(action_list_t *list); - void buildVectors(action_list_t *); + int buildVectors(action_list_t *); bool updateConstraints(ModelAction *act); void computeCV(action_list_t *); action_list_t * generateSC(action_list_t *); bool processRead(ModelAction *read, ClockVector *cv); - ModelAction * getNextAction(); + int getNextActions(ModelAction **array); bool merge(ClockVector *cv, const ModelAction *act, const ModelAction *act2); void check_rf(action_list_t *list); - + void reset(action_list_t *list); + ModelAction* pruneArray(ModelAction**, int); int maxthreads; HashTable cvmap; @@ -28,6 +41,11 @@ class SCAnalysis : public TraceAnalysis { HashTable badrfset; HashTable lastwrmap; SnapVector threadlists; - const ModelExecution *execution; + ModelExecution *execution; + bool print_always; + bool print_buggy; + bool print_nonsc; + bool time; + struct sc_statistics *stats; }; #endif