fix bug...this is another evil one...
[model-checker.git] / threads.h
index 57319067b4adb74255435cb721d723650900153c..7d2189b49d9f098a775b1cc158390cf76f49cbf4 100644 (file)
--- a/threads.h
+++ b/threads.h
@@ -16,6 +16,8 @@ typedef enum thread_state {
        THREAD_COMPLETED
 } thread_state;
 
+class ModelAction;
+
 class Thread {
 public:
        Thread(thrd_t *t, void (*func)(void *), void *a);
@@ -30,11 +32,17 @@ public:
        thread_id_t get_id();
        thrd_t get_thrd_t() { return *user_thread; }
        Thread * get_parent() { return parent; }
-  friend void thread_startup();
-  MEMALLOC
+
+       void set_creation(ModelAction *act) { creation = act; }
+       ModelAction * get_creation() { return creation; }
+
+       friend void thread_startup();
+
+       SNAPSHOTALLOC
 private:
        int create_context();
        Thread *parent;
+       ModelAction *creation;
 
        void (*start_routine)(void *);
        void *arg;