From 1371ca80e0012e533ad450f955cb95d3d9dcc862 Mon Sep 17 00:00:00 2001 From: weiyu Date: Wed, 8 Jan 2020 14:42:16 -0800 Subject: [PATCH] Bug fix --- execution.cc | 26 +++++++++++++++----------- 1 file changed, 15 insertions(+), 11 deletions(-) diff --git a/execution.cc b/execution.cc index cd3ef4b0..8057aa99 100644 --- a/execution.cc +++ b/execution.cc @@ -1880,6 +1880,11 @@ void ModelExecution::collectActions() { modelclock_t tid_clock = cvmin->getClock(act_tid); if (actseq <= tid_clock) { removeAction(act); + // Remove reference to act from thrd_last_fence_release + int thread_id = id_to_int( act->get_tid() ); + if (thrd_last_fence_release[thread_id] == act) { + thrd_last_fence_release[thread_id] = NULL; + } delete act; continue; } @@ -1905,18 +1910,17 @@ void ModelExecution::collectActions() { delete act; continue; } + } - //If we don't delete the action, we should remove references to release fences - const ModelAction *rel_fence =act->get_last_fence_release(); - if (rel_fence != NULL) { - modelclock_t relfenceseq = rel_fence->get_seq_number(); - thread_id_t relfence_tid = rel_fence->get_tid(); - modelclock_t tid_clock = cvmin->getClock(relfence_tid); - //Remove references to irrelevant release fences - if (relfenceseq <= tid_clock) - act->set_last_fence_release(NULL); - } - + //If we don't delete the action, we should remove references to release fences + const ModelAction *rel_fence =act->get_last_fence_release(); + if (rel_fence != NULL) { + modelclock_t relfenceseq = rel_fence->get_seq_number(); + thread_id_t relfence_tid = rel_fence->get_tid(); + modelclock_t tid_clock = cvmin->getClock(relfence_tid); + //Remove references to irrelevant release fences + if (relfenceseq <= tid_clock) + act->set_last_fence_release(NULL); } } -- 2.34.1