X-Git-Url: http://plrg.eecs.uci.edu/git/?p=c11tester.git;a=blobdiff_plain;f=promise.h;h=c131d743aa185d2972cd2d1922fb7ac43d6c3c8d;hp=2ce3e297305125baa0a057da571cf266965b916e;hb=963f325c5b5df37487e17c3a05f4d15efabb8870;hpb=c832cb55af09e735821ae3463bc37c29d3fa27c8 diff --git a/promise.h b/promise.h index 2ce3e297..c131d743 100644 --- a/promise.h +++ b/promise.h @@ -8,40 +8,56 @@ #define __PROMISE_H__ #include -#include "threads.h" +#include -#include "model.h" +#include "modeltypes.h" +#include "mymemory.h" + +class ModelAction; + +struct future_value { + uint64_t value; + modelclock_t expiration; + thread_id_t tid; +}; class Promise { public: - Promise(ModelAction *act, uint64_t value, modelclock_t expiration) : - value(value), expiration(expiration), read(act), write(NULL) - { - increment_threads(act->get_tid()); - } - modelclock_t get_expiration() const {return expiration;} + Promise(ModelAction *read, struct future_value fv); ModelAction * get_action() const { return read; } - bool increment_threads(thread_id_t tid); + bool eliminate_thread(thread_id_t tid); + void add_thread(thread_id_t tid); + bool thread_is_available(thread_id_t tid) const; + bool has_failed() const; + void set_write(const ModelAction *act) { write = act; } + const ModelAction * get_write() const { return write; } + int get_num_available_threads() const { return num_available_threads; } + bool is_compatible(const ModelAction *act) const; + bool is_compatible_exclusive(const ModelAction *act) const; - bool has_sync_thread(thread_id_t tid) { - unsigned int id=id_to_int(tid); - if (id>=synced_thread.size()) { - return false; - } - return synced_thread[id]; - } + modelclock_t get_expiration() const { return fv.expiration; } + uint64_t get_value() const { return fv.value; } + struct future_value get_fv() const { return fv; } - uint64_t get_value() const { return value; } - void set_write(const ModelAction *act) { write = act; } - const ModelAction * get_write() { return write; } + void print() const; + + bool equals(const Promise *x) const { return this == x; } + bool equals(const ModelAction *x) const { return false; } SNAPSHOTALLOC private: - std::vector synced_thread; - const uint64_t value; - const modelclock_t expiration; + /** @brief Thread ID(s) for thread(s) that potentially can satisfy this + * promise */ + std::vector< bool, SnapshotAlloc > available_thread; + + int num_available_threads; + + const future_value fv; + + /** @brief The action which reads a promised value */ ModelAction * const read; - const ModelAction * write; + + const ModelAction *write; }; #endif