diff options
author | Giacomo Gabrielli <Giacomo.Gabrielli@arm.com> | 2011-08-19 15:08:05 -0500 |
---|---|---|
committer | Giacomo Gabrielli <Giacomo.Gabrielli@arm.com> | 2011-08-19 15:08:05 -0500 |
commit | 676a530b776ca3468a4c318bbe5bbf8b473bc5f2 (patch) | |
tree | 4cf315d62e27d14a3ef4b7e81b7a2264cc2baa21 | |
parent | f778c46b5ec37c2050b51c1e1610b2e33c018031 (diff) | |
download | gem5-676a530b776ca3468a4c318bbe5bbf8b473bc5f2.tar.xz |
O3: Squash the violator and younger instructions instead not all insts.
Change the way instructions are squashed on memory ordering violations
to squash the violator and younger instructions, not all instructions
that are younger than the instruction they violated (no reason to throw
away valid work).
-rw-r--r-- | src/cpu/o3/iew_impl.hh | 31 |
1 files changed, 14 insertions, 17 deletions
diff --git a/src/cpu/o3/iew_impl.hh b/src/cpu/o3/iew_impl.hh index aceca3c93..9c4b1068d 100644 --- a/src/cpu/o3/iew_impl.hh +++ b/src/cpu/o3/iew_impl.hh @@ -478,27 +478,24 @@ template<class Impl> void DefaultIEW<Impl>::squashDueToMemOrder(DynInstPtr &inst, ThreadID tid) { - DPRINTF(IEW, "[tid:%i]: Squashing from a specific instruction, " - "PC: %s [sn:%i].\n", tid, inst->pcState(), inst->seqNum); - + DPRINTF(IEW, "[tid:%i]: Memory violation, squashing violator and younger " + "insts, PC: %s [sn:%i].\n", tid, inst->pcState(), inst->seqNum); + // Need to include inst->seqNum in the following comparison to cover the + // corner case when a branch misprediction and a memory violation for the + // same instruction (e.g. load PC) are detected in the same cycle. In this + // case the memory violator should take precedence over the branch + // misprediction because it requires the violator itself to be included in + // the squash. if (toCommit->squash[tid] == false || - inst->seqNum < toCommit->squashedSeqNum[tid]) { + inst->seqNum <= toCommit->squashedSeqNum[tid]) { toCommit->squash[tid] = true; + toCommit->squashedSeqNum[tid] = inst->seqNum; - TheISA::PCState pc; - if (inst->isMemRef() && inst->isIndirectCtrl()) { - // If an operation is a control operation as well as a memory - // reference we need to use the predicted PC, not the PC+N - // This instruction will verify misprediction based on predPC - pc = inst->readPredTarg(); - } else { - pc = inst->pcState(); - TheISA::advancePC(pc, inst->staticInst); - } - toCommit->pc[tid] = pc; + toCommit->pc[tid] = inst->pcState(); toCommit->mispredictInst[tid] = NULL; - toCommit->includeSquashInst[tid] = false; + // Must include the memory violator in the squash. + toCommit->includeSquashInst[tid] = true; wroteToTimeBuffer = true; } @@ -1374,7 +1371,7 @@ DefaultIEW<Impl>::executeInsts() instQueue.violation(inst, violator); // Squash. - squashDueToMemOrder(inst,tid); + squashDueToMemOrder(violator, tid); ++memOrderViolationEvents; } else if (ldstQueue.loadBlocked(tid) && |