summaryrefslogtreecommitdiff
path: root/src/arch/arm/insts/macromem.cc
diff options
context:
space:
mode:
Diffstat (limited to 'src/arch/arm/insts/macromem.cc')
-rw-r--r--src/arch/arm/insts/macromem.cc10
1 files changed, 10 insertions, 0 deletions
diff --git a/src/arch/arm/insts/macromem.cc b/src/arch/arm/insts/macromem.cc
index cd77d6d5f..2ada29539 100644
--- a/src/arch/arm/insts/macromem.cc
+++ b/src/arch/arm/insts/macromem.cc
@@ -171,6 +171,16 @@ MacroMemOp::MacroMemOp(const char *mnem, ExtMachInst machInst,
(*uop)->setLastMicroop();
+ /* Take the control flags from the last microop for the macroop */
+ if ((*uop)->isControl())
+ setFlag(StaticInst::IsControl);
+ if ((*uop)->isCondCtrl())
+ setFlag(StaticInst::IsCondControl);
+ if ((*uop)->isIndirectCtrl())
+ setFlag(StaticInst::IsIndirectControl);
+ if ((*uop)->isReturn())
+ setFlag(StaticInst::IsReturn);
+
for (StaticInstPtr *curUop = microOps;
!(*curUop)->isLastMicroop(); curUop++) {
MicroOp * uopPtr = dynamic_cast<MicroOp *>(curUop->get());