[PATCH] D32205: X86RegisterInfo: eliminateFrameIndex: Force SP in AfterFPPop case; NFC

Phabricator via Phabricator via llvm-commits llvm-commits at lists.llvm.org
Thu Apr 20 16:47:39 PDT 2017


This revision was automatically updated to reflect the committed changes.
Closed by commit rL300922: X86RegisterInfo: eliminateFrameIndex: Force SP for AfterFPPop; NFC (authored by matze).

Changed prior to commit:
  https://reviews.llvm.org/D32205?vs=95862&id=96057#toc

Repository:
  rL LLVM

https://reviews.llvm.org/D32205

Files:
  llvm/trunk/lib/Target/X86/X86RegisterInfo.cpp


Index: llvm/trunk/lib/Target/X86/X86RegisterInfo.cpp
===================================================================
--- llvm/trunk/lib/Target/X86/X86RegisterInfo.cpp
+++ llvm/trunk/lib/Target/X86/X86RegisterInfo.cpp
@@ -675,12 +675,13 @@
   bool AfterFPPop = Opc == X86::TAILJMPm64 || Opc == X86::TAILJMPm ||
                     Opc == X86::TCRETURNmi || Opc == X86::TCRETURNmi64;
 
-  if (hasBasePointer(MF))
+  if (AfterFPPop) {
+    assert(FrameIndex < 0 && "Should only reference fixed stack objects here");
+    BasePtr = StackPtr;
+  } else if (hasBasePointer(MF))
     BasePtr = (FrameIndex < 0 ? FramePtr : getBaseRegister());
   else if (needsStackRealignment(MF))
     BasePtr = (FrameIndex < 0 ? FramePtr : StackPtr);
-  else if (AfterFPPop)
-    BasePtr = StackPtr;
   else
     BasePtr = (TFI->hasFP(MF) ? FramePtr : StackPtr);
 


-------------- next part --------------
A non-text attachment was scrubbed...
Name: D32205.96057.patch
Type: text/x-patch
Size: 849 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20170420/159d7100/attachment.bin>


More information about the llvm-commits mailing list