#define __ACTION_H__
#include <list>
+#include <cstddef>
+
#include "threads.h"
#include "libatomic.h"
#include "mymemory.h"
} action_type_t;
/* Forward declaration */
-class TreeNode;
class Node;
+class ClockVector;
class ModelAction {
public:
ModelAction(action_type_t type, memory_order order, void *loc, int value);
+ ~ModelAction();
void print(void);
thread_id_t get_tid() { return tid; }
void * get_location() { return location; }
int get_seq_number() const { return seq_number; }
- TreeNode * get_treenode() { return treenode; }
- void set_node(TreeNode *n) { treenode = n; }
Node * get_node() { return node; }
void set_node(Node *n) { node = n; }
bool same_thread(ModelAction *act);
bool is_dependent(ModelAction *act);
+ void create_cv(ModelAction *parent = NULL);
+ void read_from(ModelAction *act);
+
inline bool operator <(const ModelAction& act) const {
return get_seq_number() < act.get_seq_number();
}
inline bool operator >(const ModelAction& act) const {
return get_seq_number() > act.get_seq_number();
}
- MEMALLOC
+
+ MEMALLOC
private:
action_type type;
memory_order order;
void *location;
thread_id_t tid;
int value;
- TreeNode *treenode;
Node *node;
int seq_number;
+
+ ClockVector *cv;
};
-typedef std::list<class ModelAction *, MyAlloc< class ModelAction * > > action_list_t;
+typedef std::list<class ModelAction *> action_list_t;
#endif /* __ACTION_H__ */