diff options
author | Erik Hallnor <ehallnor@umich.edu> | 2004-10-17 00:07:21 -0400 |
---|---|---|
committer | Erik Hallnor <ehallnor@umich.edu> | 2004-10-17 00:07:21 -0400 |
commit | 867a9b84d9d633bed17a8880f84864840b923dfd (patch) | |
tree | 028cd85e7094c7e3fe8707d01e314e6957600f9b /cpu/trace/trace_cpu.cc | |
parent | 800d970c2675a6609c29f4ddbc7a308e80a2caa9 (diff) | |
download | gem5-867a9b84d9d633bed17a8880f84864840b923dfd.tar.xz |
Bunch of little changes for tracking copies and getting OPT right.
cpu/simple_cpu/simple_cpu.cc:
Send Copy
cpu/trace/opt_cpu.cc:
Calculate the block size correctly. Set lookupTable value directly, since the old way only worked for FA caches.
cpu/trace/trace_cpu.cc:
Don't start events if the hierarchy is in non-event mode.
--HG--
extra : convert_revision : daf2db5ed7428c2fb08652cf76f6fe99d8357db5
Diffstat (limited to 'cpu/trace/trace_cpu.cc')
-rw-r--r-- | cpu/trace/trace_cpu.cc | 23 |
1 files changed, 17 insertions, 6 deletions
diff --git a/cpu/trace/trace_cpu.cc b/cpu/trace/trace_cpu.cc index e19509fec..b69793a4b 100644 --- a/cpu/trace/trace_cpu.cc +++ b/cpu/trace/trace_cpu.cc @@ -75,9 +75,14 @@ TraceCPU::tick() icacheInterface->squash(nextReq->asid); } else { ++instReqs; - nextReq->completionEvent = - new TraceCompleteEvent(nextReq, this); - icacheInterface->access(nextReq); + if (icacheInterface->doEvents()) { + nextReq->completionEvent = + new TraceCompleteEvent(nextReq, this); + icacheInterface->access(nextReq); + } else { + icacheInterface->access(nextReq); + completeRequest(nextReq); + } } } else { if (dcacheInterface->isBlocked()) @@ -85,9 +90,15 @@ TraceCPU::tick() ++dataReqs; nextReq->time = curTick; - nextReq->completionEvent = - new TraceCompleteEvent(nextReq, this); - dcacheInterface->access(nextReq); + if (dcacheInterface->doEvents()) { + nextReq->completionEvent = + new TraceCompleteEvent(nextReq, this); + dcacheInterface->access(nextReq); + } else { + dcacheInterface->access(nextReq); + completeRequest(nextReq); + } + } nextCycle = dataTrace->getNextReq(nextReq); } |