uint64_t get_reads_from_value() const;
uint64_t get_write_value() const;
uint64_t get_return_value() const;
- const ModelAction * get_reads_from() const { return reads_from; }
+ ModelAction * get_reads_from() const { return reads_from; }
cdsc::mutex * get_mutex() const;
Node * get_node() const;
void set_node(Node *n) { node = n; }
- void set_read_from(const ModelAction *act);
+ void set_read_from(ModelAction *act);
/** Store the most recent fence-release from the same thread
* @param fence The fence-release that occured prior to this */
Thread * get_thread_operand() const;
void create_cv(const ModelAction *parent = NULL);
ClockVector * get_cv() const { return cv; }
+ ClockVector * get_rfcv() const { return rf_cv; }
+ void set_rfcv(ClockVector * rfcv) { rf_cv = rfcv; }
bool synchronize_with(const ModelAction *act);
bool has_synchronized_with(const ModelAction *act) const;
*
* Only valid for reads
*/
- const ModelAction *reads_from;
+ ModelAction *reads_from;
int size;
};
* vectors for all operations.
*/
ClockVector *cv;
+ ClockVector *rf_cv;
/** @brief The value written (for write or RMW; undefined for read) */
uint64_t value;