summaryrefslogtreecommitdiff
path: root/src/arch/arm/insts/macromem.cc
diff options
context:
space:
mode:
authorGabe Black <gblack@eecs.umich.edu>2010-06-02 12:58:12 -0500
committerGabe Black <gblack@eecs.umich.edu>2010-06-02 12:58:12 -0500
commit1fcd389fa327493d66767ee11698ccff8fccb7ac (patch)
treed7ebff3689093d76e1339b674ebf7d507d2e6de4 /src/arch/arm/insts/macromem.cc
parent67766cbf17451559207d072eaf4fc6fb589a2656 (diff)
downloadgem5-1fcd389fa327493d66767ee11698ccff8fccb7ac.tar.xz
ARM: Make sure macroops aren't interrupted midinstruction.
Do this by setting the delayed commit flag for all but the last microop.
Diffstat (limited to 'src/arch/arm/insts/macromem.cc')
-rw-r--r--src/arch/arm/insts/macromem.cc14
1 files changed, 14 insertions, 0 deletions
diff --git a/src/arch/arm/insts/macromem.cc b/src/arch/arm/insts/macromem.cc
index 8e9e60f30..01ec3e1d8 100644
--- a/src/arch/arm/insts/macromem.cc
+++ b/src/arch/arm/insts/macromem.cc
@@ -128,6 +128,13 @@ MacroMemOp::MacroMemOp(const char *mnem, ExtMachInst machInst,
}
(*uop)->setLastMicroop();
+
+ for (StaticInstPtr *curUop = microOps;
+ !(*curUop)->isLastMicroop(); curUop++) {
+ MicroOp * uopPtr = dynamic_cast<MicroOp *>(curUop->get());
+ assert(uopPtr);
+ uopPtr->setDelayedCommit();
+ }
}
MacroVFPMemOp::MacroVFPMemOp(const char *mnem, ExtMachInst machInst,
@@ -198,6 +205,13 @@ MacroVFPMemOp::MacroVFPMemOp(const char *mnem, ExtMachInst machInst,
assert(numMicroops == i);
microOps[numMicroops - 1]->setLastMicroop();
+
+ for (StaticInstPtr *curUop = microOps;
+ !(*curUop)->isLastMicroop(); curUop++) {
+ MicroOp * uopPtr = dynamic_cast<MicroOp *>(curUop->get());
+ assert(uopPtr);
+ uopPtr->setDelayedCommit();
+ }
}
}