Make sure not to break eh_return.
authorEvan Cheng <evan.cheng@apple.com>
Tue, 17 Jul 2007 18:40:47 +0000 (18:40 +0000)
committerEvan Cheng <evan.cheng@apple.com>
Tue, 17 Jul 2007 18:40:47 +0000 (18:40 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@39978 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Target/X86/X86RegisterInfo.cpp

index fce7172ae3fbf41f4b8ee088f8e2fea44f246531..9278516d05e8381aafa286f328c022b75c130584 100644 (file)
@@ -1332,14 +1332,6 @@ void X86RegisterInfo::emitEpilogue(MachineFunction &MF,
     NumBytes -= SlotSize;
   }
 
-  // We're returning from function via eh_return.
-  if (RetOpcode == X86::EH_RETURN) {
-    MachineOperand &DestAddr  = MBBI->getOperand(0);
-    assert(DestAddr.isReg() && "Offset should be in register!");
-    BuildMI(MBB, MBBI, TII.get(Is64Bit ? X86::MOV64rr : X86::MOV32rr),StackPtr).
-      addReg(DestAddr.getReg());
-  }
-
   // Skip the callee-saved pop instructions.
   while (MBBI != MBB.begin()) {
     MachineBasicBlock::iterator PI = prior(MBBI);      
@@ -1355,7 +1347,7 @@ void X86RegisterInfo::emitEpilogue(MachineFunction &MF,
     MachineInstr *MI = addRegOffset(BuildMI(TII.get(Opc), StackPtr),
                                     FramePtr, -CSSize);
     MBB.insert(MBBI, MI);
-    return;
+    NumBytes = 0;
   }
 
   if (NumBytes) {    // adjust stack pointer back: ESP += numbytes
@@ -1380,6 +1372,15 @@ void X86RegisterInfo::emitEpilogue(MachineFunction &MF,
     if (NumBytes)
       emitSPUpdate(MBB, MBBI, StackPtr, NumBytes, Is64Bit, TII);
   }
+
+  // We're returning from function via eh_return.
+  if (RetOpcode == X86::EH_RETURN) {
+    MBBI = prior(MBB.end());
+    MachineOperand &DestAddr  = MBBI->getOperand(0);
+    assert(DestAddr.isReg() && "Offset should be in register!");
+    BuildMI(MBB, MBBI, TII.get(Is64Bit ? X86::MOV64rr : X86::MOV32rr),StackPtr).
+      addReg(DestAddr.getReg());
+  }
 }
 
 unsigned X86RegisterInfo::getRARegister() const {