projects
/
model-checker.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
threads/model: allocate Thread from w/in ModelChecker
[model-checker.git]
/
mutex.cc
diff --git
a/mutex.cc
b/mutex.cc
index 2cf6828af0ac679811d0fe7cac42d57502fe60d9..7fa0b589c8a4535a276c7f8f95eda76782bff554 100644
(file)
--- a/
mutex.cc
+++ b/
mutex.cc
@@
-1,10
+1,15
@@
-#include "mutex.h"
-#include "model.h"
+#include <mutex>
+#include "model.h"
+#include "threads-model.h"
+#include "clockvector.h"
namespace std {
mutex::mutex() {
state.islocked=false;
namespace std {
mutex::mutex() {
state.islocked=false;
+ thread_id_t tid=thread_current()->get_id();
+ state.alloc_tid=tid;
+ state.alloc_clock=model->get_cv(tid)->getClock(tid);
}
void mutex::lock() {
}
void mutex::lock() {
@@
-12,8
+17,7
@@
void mutex::lock() {
}
bool mutex::try_lock() {
}
bool mutex::try_lock() {
- model->switch_to_master(new ModelAction(ATOMIC_TRYLOCK, std::memory_order_seq_cst, this));
- return thread_current()->get_return_value();
+ return model->switch_to_master(new ModelAction(ATOMIC_TRYLOCK, std::memory_order_seq_cst, this));
}
void mutex::unlock() {
}
void mutex::unlock() {