4 #include "threads-model.h"
5 #include "clockvector.h"
10 thread_id_t tid=thread_current()->get_id();
12 state.alloc_clock=model->get_cv(tid)->getClock(tid);
16 model->switch_to_master(new ModelAction(ATOMIC_LOCK, std::memory_order_seq_cst, this));
19 bool mutex::try_lock() {
20 model->switch_to_master(new ModelAction(ATOMIC_TRYLOCK, std::memory_order_seq_cst, this));
21 return thread_current()->get_return_value();
24 void mutex::unlock() {
25 model->switch_to_master(new ModelAction(ATOMIC_UNLOCK, std::memory_order_seq_cst, this));