From 7064cf5c139946885b0d3df46f59da4946b34d4c Mon Sep 17 00:00:00 2001 From: Brian Norris Date: Wed, 20 Feb 2013 14:58:21 -0800 Subject: [PATCH] model: document get_last{,_fence}_conflict() --- model.cc | 23 +++++++++++++++++++++++ 1 file changed, 23 insertions(+) diff --git a/model.cc b/model.cc index fab1a59..e0edbec 100644 --- a/model.cc +++ b/model.cc @@ -545,6 +545,18 @@ bool ModelChecker::next_execution() return true; } +/** + * @brief Find the last fence-related backtracking conflict for a ModelAction + * + * This function performs the search for the most recent conflicting action + * against which we should perform backtracking, as affected by fence + * operations. This includes pairs of potentially-synchronizing actions which + * occur due to fence-acquire or fence-release, and hence should be explored in + * the opposite execution order. + * + * @param act The current action + * @return The most recent action which conflicts with act due to fences + */ ModelAction * ModelChecker::get_last_fence_conflict(ModelAction *act) const { /* Only perform release/acquire fence backtracking for stores */ @@ -600,6 +612,17 @@ ModelAction * ModelChecker::get_last_fence_conflict(ModelAction *act) const return latest_backtrack; } +/** + * @brief Find the last backtracking conflict for a ModelAction + * + * This function performs the search for the most recent conflicting action + * against which we should perform backtracking. This primary includes pairs of + * synchronizing actions which should be explored in the opposite execution + * order. + * + * @param act The current action + * @return The most recent action which conflicts with act + */ ModelAction * ModelChecker::get_last_conflict(ModelAction *act) const { switch (act->get_type()) { -- 2.34.1