projects
/
model-checker.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
changes to fix at least a bug
[model-checker.git]
/
action.h
diff --git
a/action.h
b/action.h
index 68db2c35899c479b5aa1b0b9329f049a14b84e45..f7e7e5ea0febd7251ff91e49654807ed9e437a95 100644
(file)
--- a/
action.h
+++ b/
action.h
@@
-26,7
+26,7
@@
using std::memory_order_seq_cst;
/** Note that this value can be legitimately used by a program, and
hence by iteself does not indicate no value. */
/** Note that this value can be legitimately used by a program, and
hence by iteself does not indicate no value. */
-#define VALUE_NONE
1234567890
+#define VALUE_NONE
0xdeadbeef
/** A special value to represent a successful trylock */
/** A special value to represent a successful trylock */
@@
-55,7
+55,10
@@
typedef enum action_type {
ATOMIC_FENCE, /**< A fence action */
ATOMIC_LOCK, /**< A lock action */
ATOMIC_TRYLOCK, /**< A trylock action */
ATOMIC_FENCE, /**< A fence action */
ATOMIC_LOCK, /**< A lock action */
ATOMIC_TRYLOCK, /**< A trylock action */
- ATOMIC_UNLOCK /**< An unlock action */
+ ATOMIC_UNLOCK, /**< An unlock action */
+ ATOMIC_NOTIFY_ONE, /**< A notify_one action */
+ ATOMIC_NOTIFY_ALL, /**< A notify all action */
+ ATOMIC_WAIT /**< A wait action */
} action_type_t;
/* Forward declaration */
} action_type_t;
/* Forward declaration */
@@
-90,10
+93,14
@@
public:
bool is_lock() const;
bool is_trylock() const;
bool is_unlock() const;
bool is_lock() const;
bool is_trylock() const;
bool is_unlock() const;
+ bool is_wait() const;
+ bool is_notify() const;
+ bool is_notify_one() const;
bool is_success_lock() const;
bool is_failed_trylock() const;
bool is_read() const;
bool is_write() const;
bool is_success_lock() const;
bool is_failed_trylock() const;
bool is_read() const;
bool is_write() const;
+ bool could_be_write() const;
bool is_rmwr() const;
bool is_rmwc() const;
bool is_rmw() const;
bool is_rmwr() const;
bool is_rmwc() const;
bool is_rmw() const;
@@
-127,6
+134,7
@@
public:
void set_sleep_flag() { sleep_flag=true; }
bool get_sleep_flag() { return sleep_flag; }
void set_sleep_flag() { sleep_flag=true; }
bool get_sleep_flag() { return sleep_flag; }
+ unsigned int hash() const;
MEMALLOC
private:
MEMALLOC
private: