X-Git-Url: http://plrg.eecs.uci.edu/git/?p=cdsspec-compiler.git;a=blobdiff_plain;f=promise.h;h=84d5aa49b3af7b8156ef4744e270f128c6a0cabf;hp=e8c233c61d8240d4820fc39ad7d735d0ffeff355;hb=c1c75c2ccffa6d9e5a57336d8134c6060c3759f9;hpb=cb7d648c3c1c3d916c7fc60a7cb332eb2b52d510 diff --git a/promise.h b/promise.h index e8c233c..84d5aa4 100644 --- a/promise.h +++ b/promise.h @@ -14,6 +14,7 @@ #include "stl-model.h" class ModelAction; +class ModelExecution; struct future_value { uint64_t value; @@ -23,13 +24,14 @@ struct future_value { class Promise { public: - Promise(ModelAction *read, struct future_value fv); + Promise(const ModelExecution *execution, ModelAction *read, struct future_value fv); bool add_reader(ModelAction *reader); ModelAction * get_reader(unsigned int i) const; unsigned int get_num_readers() const { return readers.size(); } bool eliminate_thread(thread_id_t tid); void add_thread(thread_id_t tid); bool thread_is_available(thread_id_t tid) const; + unsigned int max_available_thread_idx() const; bool has_failed() const; void set_write(const ModelAction *act) { write = act; } const ModelAction * get_write() const { return write; } @@ -52,6 +54,9 @@ class Promise { SNAPSHOTALLOC private: + /** @brief The execution which created this Promise */ + const ModelExecution *execution; + /** @brief Thread ID(s) for thread(s) that potentially can satisfy this * promise */ SnapVector available_thread;