From: Brian Norris Date: Fri, 1 Mar 2013 20:32:13 +0000 (-0800) Subject: action: add get_write_value() X-Git-Tag: oopsla2013~195 X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=a0db445e3ecfedce6a85b7b381416b5c363a0614;p=model-checker.git action: add get_write_value() --- diff --git a/action.cc b/action.cc index e6a621b..5f83c3f 100644 --- a/action.cc +++ b/action.cc @@ -397,6 +397,23 @@ uint64_t ModelAction::get_reads_from_value() const return reads_from_promise->get_value(); } +/** + * @brief Get the value written by this store + * + * We differentiate this function from ModelAction::get_reads_from_value and + * ModelAction::get_value for the purpose of RMW's, which may have both a + * 'read' and a 'write' value. + * + * Note: 'this' must be a store. + * + * @return The value written by this store + */ +uint64_t ModelAction::get_write_value() const +{ + ASSERT(is_write()); + return value; +} + /** @return The Node associated with this ModelAction */ Node * ModelAction::get_node() const { @@ -532,6 +549,8 @@ void ModelAction::print() const uint64_t valuetoprint; if (is_read()) valuetoprint = get_reads_from_value(); + else if (is_write()) + valuetoprint = get_write_value(); else valuetoprint = value; diff --git a/action.h b/action.h index 8a3650b..c546f57 100644 --- a/action.h +++ b/action.h @@ -81,6 +81,7 @@ public: modelclock_t get_seq_number() const { return seq_number; } uint64_t get_value() const { return value; } uint64_t get_reads_from_value() const; + uint64_t get_write_value() const; const ModelAction * get_reads_from() const { return reads_from; } Promise * get_reads_from_promise() const { return reads_from_promise; } diff --git a/model.cc b/model.cc index b10a841..a66648b 100644 --- a/model.cc +++ b/model.cc @@ -1022,7 +1022,7 @@ void ModelChecker::add_future_value(const ModelAction *writer, ModelAction *read write_thread = write_thread->get_parent(); struct future_value fv = { - writer->get_value(), + writer->get_write_value(), writer->get_seq_number() + params.maxfuturedelay, write_thread->get_id(), };