From: Gabe Black Date: Fri, 27 Oct 2006 11:09:14 +0000 (-0400) Subject: A more complete attempt to fix the clock skew. X-Git-Tag: m5_2.0_beta2~70^2~19 X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=a46e19f7384eb3e6a03136ddab5ba74716e43eb6;p=gem5.git A more complete attempt to fix the clock skew. --HG-- extra : convert_revision : b2d505de51fc5fcae5177b2a13140729474e249e --- diff --git a/src/cpu/simple/atomic.cc b/src/cpu/simple/atomic.cc index b4ea4b216..a72f6361a 100644 --- a/src/cpu/simple/atomic.cc +++ b/src/cpu/simple/atomic.cc @@ -188,8 +188,11 @@ AtomicSimpleCPU::resume() changeState(SimObject::Running); if (thread->status() == ThreadContext::Active) { - if (!tickEvent.scheduled()) - tickEvent.schedule(curTick); + if (!tickEvent.scheduled()) { + Tick nextTick = curTick + cycles(1) - 1; + nextTick -= (nextTick % (cycles(1))); + tickEvent.schedule(nextTick); + } } } } @@ -217,7 +220,9 @@ AtomicSimpleCPU::takeOverFrom(BaseCPU *oldCPU) ThreadContext *tc = threadContexts[i]; if (tc->status() == ThreadContext::Active && _status != Running) { _status = Running; - tickEvent.schedule(curTick); + Tick nextTick = curTick + cycles(1) - 1; + nextTick -= (nextTick % (cycles(1))); + tickEvent.schedule(nextTick); break; } } @@ -237,7 +242,7 @@ AtomicSimpleCPU::activateContext(int thread_num, int delay) //Make sure ticks are still on multiples of cycles Tick nextTick = curTick + cycles(1) - 1; nextTick -= (nextTick % (cycles(1))); - tickEvent.schedule(curTick + cycles(delay)); + tickEvent.schedule(nextTick); _status = Running; }