X-Git-Url: http://demsky.eecs.uci.edu/git/?a=blobdiff_plain;f=snapshot-interface.h;h=c0db0d0c0990595beaea3f1af70933a0f97779a8;hb=c204d45f6621818bf1db92bf470baa531f0a3980;hp=0c2478ee67abb38b817106a876899803fa458771;hpb=700898cdd309acb86dcd275d8b1c34e02d67922e;p=model-checker.git diff --git a/snapshot-interface.h b/snapshot-interface.h index 0c2478e..c0db0d0 100644 --- a/snapshot-interface.h +++ b/snapshot-interface.h @@ -1,12 +1,39 @@ +/** @file snapshot-interface.h + * @brief C++ layer on top of snapshotting system. + */ + + #ifndef __SNAPINTERFACE_H #define __SNAPINTERFACE_H -#include "snapshot.h" #include "mymemory.h" -#include -#include -#include -typedef std::basic_string< char, std::char_traits< char >, MyAlloc< char > > MyString; -namespace snapshot_utils{ - std::vector< std::pair< void *, size_t >, MyAlloc< std::pair< void *, size_t > > > ReturnGlobalSegmentsToSnapshot(); + +typedef unsigned int snapshot_id; + +typedef void (*VoidFuncPtr)(); +void initSnapshotLibrary(unsigned int numbackingpages, + unsigned int numsnapshots, unsigned int nummemoryregions, + unsigned int numheappages, VoidFuncPtr entryPoint); + +struct stackEntry { + struct stackEntry *next; + snapshot_id snapshotid; + int index; }; + +class SnapshotStack { + public: + MEMALLOC + SnapshotStack( ); + ~SnapshotStack(); + int backTrackBeforeStep(int seq_index); + void snapshotStep(int seq_index); + + private: + struct stackEntry * stack; +}; + +/* Not sure what it even means to have more than one snapshot object, + so let's just make a global reference to it.*/ + +extern SnapshotStack * snapshotObject; #endif