From 137b4993a4710a247d79cdc0194dfa107b080f98 Mon Sep 17 00:00:00 2001 From: Gabe Black Date: Mon, 8 Oct 2018 23:08:27 -0700 Subject: systemc: Don't re-schedule a process which is already scheduled. Change-Id: I8e12713c49aad03d0bfb779883adcbfa8fd4b42e Reviewed-on: https://gem5-review.googlesource.com/c/13334 Reviewed-by: Gabe Black Maintainer: Gabe Black --- src/systemc/core/process.cc | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) (limited to 'src/systemc/core/process.cc') diff --git a/src/systemc/core/process.cc b/src/systemc/core/process.cc index a0759d9cc..e29cee030 100644 --- a/src/systemc/core/process.cc +++ b/src/systemc/core/process.cc @@ -359,7 +359,7 @@ Process::ready() return; if (suspended()) _suspendedReady = true; - else + else if (!scheduled()) scheduler.ready(this); } @@ -381,9 +381,10 @@ Process::Process(const char *name, ProcessFuncWrapper *func, bool internal) : timeoutEvent([this]() { this->timeout(); }), func(func), _internal(internal), _timedOut(false), _dontInitialize(false), _needsStart(true), _isUnwinding(false), _terminated(false), - _suspended(false), _disabled(false), _syncReset(false), syncResetCount(0), - asyncResetCount(0), _waitCount(0), refCount(0), - stackSize(::Fiber::DefaultStackSize), dynamicSensitivity(nullptr) + _scheduled(false), _suspended(false), _disabled(false), + _syncReset(false), syncResetCount(0), asyncResetCount(0), _waitCount(0), + refCount(0), stackSize(::Fiber::DefaultStackSize), + dynamicSensitivity(nullptr) { _dynamic = (::sc_core::sc_get_status() > -- cgit v1.2.3