rlsrpc->start();
}
+lock_client::~lock_client() {
+ release_fifo.enq(nothing<lock_protocol::lockid_t>());
+ releaser_thread.join();
+}
+
void lock_client::releaser() {
while (1) {
- lock_protocol::lockid_t lid;
- release_fifo.deq(&lid);
+ maybe<lock_protocol::lockid_t> mlid;
+ release_fifo.deq(&mlid);
+
+ if (!mlid) {
+ LOG << "Releaser stopping";
+ break;
+ }
+
+ lock_protocol::lockid_t lid = mlid;
LOG << "Releaser: " << lid;
lock_state & st = get_lock_state(lid);
st.state = lock_state::locked;
st.held_by = releaser_thread.get_id();
LOG << "Queuing " << lid << " for release";
- release_fifo.enq(lid);
+ release_fifo.enq(just(lid));
} else if (front == self) {
st.wanted_by.pop_front();
st.state = lock_state::locked;
st.held_by = releaser_thread.get_id();
st.wanted_by.pop_front();
LOG << "Queuing " << lid << " for release";
- release_fifo.enq(lid);
+ release_fifo.enq(just(lid));
} else
st.signal(front);
}
st.held_by = releaser_thread.get_id();
if (st.wanted_by.size())
st.wanted_by.pop_front();
- release_fifo.enq(lid);
+ release_fifo.enq(just(lid));
} else {
// get in line
st.wanted_by.push_back(releaser_thread.get_id());