Change initialize a bit
[c11tester.git] / mutex.cc
index b31b20a8ed2f02446fd1c4fbea5965c65b2b6979..fa751783dcc4418ddc8087e7ee5b24d566c412a5 100644 (file)
--- a/mutex.cc
+++ b/mutex.cc
@@ -1,25 +1,39 @@
 #include "mutex.h"
+
 #include "model.h"
+#include "execution.h"
+#include "threads-model.h"
+#include "clockvector.h"
+#include "action.h"
 
+namespace cdsc {
 
-namespace std {
-mutex::mutex() :
-       owner(0), islocked(false)
+mutex::mutex(int type)
 {
+       state.locked = NULL;
+       thread_id_t tid = thread_current_id();
+       state.alloc_tid = tid;
+       ClockVector *cv = model->get_execution()->get_cv(tid);
+       state.alloc_clock = cv  == NULL ? 0 : cv->getClock(tid);
 
+       // For recursive mutex
+       state.type = type;
+       state.lock_count = 0;
 }
-       
-void mutex::lock() {
-  model->switch_to_master(new ModelAction(ATOMIC_LOCK, std::memory_order_seq_cst, this));
+
+void mutex::lock()
+{
+       model->switch_thread(new ModelAction(ATOMIC_LOCK, std::memory_order_seq_cst, this));
 }
-       
-bool mutex::try_lock() {
-  model->switch_to_master(new ModelAction(ATOMIC_TRYLOCK, std::memory_order_seq_cst, this));
-  return thread_current()->get_return_value();
+
+bool mutex::try_lock()
+{
+       return model->switch_thread(new ModelAction(ATOMIC_TRYLOCK, std::memory_order_seq_cst, this));
 }
 
-void mutex::unlock() {
-  model->switch_to_master(new ModelAction(ATOMIC_UNLOCK, std::memory_order_seq_cst, this));
+void mutex::unlock()
+{
+       model->switch_thread(new ModelAction(ATOMIC_UNLOCK, std::memory_order_seq_cst, this));
 }
 
 }