X-Git-Url: http://demsky.eecs.uci.edu/git/?a=blobdiff_plain;f=scanalysis.h;h=988c8f75c13ad58f0fdfc44ebd3e936bb59601e1;hb=130a35155171503883aaf18e57f8957ce63d06e8;hp=a6420955be068d8077e03c8900c0663a5218a0e9;hpb=9508fe09d2eeaaf7fbe7193d9cb81b3bc66316b5;p=model-checker.git diff --git a/scanalysis.h b/scanalysis.h index a642095..988c8f7 100644 --- a/scanalysis.h +++ b/scanalysis.h @@ -3,18 +3,49 @@ #include "traceanalysis.h" #include "hashtable.h" -class SCAnalysis : public Trace_Analysis { +struct sc_statistics { + unsigned long long elapsedtime; + unsigned int sccount; + unsigned int nonsccount; +}; + +class SCAnalysis : public TraceAnalysis { public: 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 buildVectors(action_list_t *); + void update_stats(); + void print_list(action_list_t *list); + 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); + 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; + HashTable cvmap; + bool cyclic; + HashTable badrfset; + HashTable lastwrmap; + SnapVector threadlists; + ModelExecution *execution; + bool print_always; + bool print_buggy; + bool print_nonsc; + bool time; + struct sc_statistics *stats; }; #endif