From 4bbdd6ceb2639fe21408ab211b7c4c7e53adb249 Mon Sep 17 00:00:00 2001 From: Min Kyu Jeong Date: Tue, 7 Dec 2010 16:19:57 -0800 Subject: O3: Support SWAP and predicated loads/store in ARM. --- src/cpu/o3/iew_impl.hh | 15 ++++----------- 1 file changed, 4 insertions(+), 11 deletions(-) (limited to 'src/cpu/o3/iew_impl.hh') diff --git a/src/cpu/o3/iew_impl.hh b/src/cpu/o3/iew_impl.hh index 608e70cde..521f07089 100644 --- a/src/cpu/o3/iew_impl.hh +++ b/src/cpu/o3/iew_impl.hh @@ -1236,20 +1236,13 @@ DefaultIEW::executeInsts() fault = ldstQueue.executeStore(inst); // If the store had a fault then it may not have a mem req - if (!inst->isStoreConditional() && fault == NoFault) { - inst->setExecuted(); - - instToCommit(inst); - } else if (fault != NoFault) { - // If the instruction faulted, then we need to send it along to commit - // without the instruction completing. - DPRINTF(IEW, "Store has fault %s! [sn:%lli]\n", - fault->name(), inst->seqNum); - + if (fault != NoFault || inst->readPredicate() == false || + !inst->isStoreConditional()) { + // If the instruction faulted, then we need to send it along + // to commit without the instruction completing. // Send this instruction to commit, also make sure iew stage // realizes there is activity. inst->setExecuted(); - instToCommit(inst); activityThisCycle(); } -- cgit v1.2.3