redo model object initialization
[c11tester.git] / snapshot-interface.h
index ecc60ec6453a9ca4991c92e27d248622a201b7c5..3e3ad71e02388ff1130d3da357f8321c77543a01 100644 (file)
@@ -1,39 +1,20 @@
-/** @file snapshot-interface.h
- *  @brief C++ layer on top of snapshotting system.
+/**
+ * @file snapshot-interface.h
+ * @brief C interface layer on top of snapshotting system
  */
 
-
 #ifndef __SNAPINTERFACE_H
 #define __SNAPINTERFACE_H
-#include "mymemory.h"
 
 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:
-       SnapshotStack();
-       ~SnapshotStack();
-       int backTrackBeforeStep(int seq_index);
-       void snapshotStep(int seq_index);
-
-       MEMALLOC
- 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.*/
+void snapshot_system_init(unsigned int numbackingpages,
+                                                                                                       unsigned int numsnapshots, unsigned int nummemoryregions,
+                                                                                                       unsigned int numheappages);
+void startExecution(VoidFuncPtr entryPoint);
+void snapshot_stack_init();
+void snapshot_record(int seq_index);
+int snapshot_backtrack_before(int seq_index);
 
-extern SnapshotStack *snapshotObject;
 #endif