Fix a compiler-abort on a testcase where the stack-pointer is added to
authorDan Gohman <gohman@apple.com>
Wed, 24 Dec 2008 00:27:51 +0000 (00:27 +0000)
committerDan Gohman <gohman@apple.com>
Wed, 24 Dec 2008 00:27:51 +0000 (00:27 +0000)
a symbolic constant. This is unlikely to be intentional, but it
shouldn't crash the compiler.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@61408 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Target/X86/X86RegisterInfo.cpp
test/CodeGen/X86/2008-12-23-crazy-address.ll [new file with mode: 0644]

index b650d220507ac5028706792b5d0d09002325056e..a0d8b58b789c944547feca66c6bd7306d86aa289 100644 (file)
@@ -454,12 +454,19 @@ void X86RegisterInfo::eliminateFrameIndex(MachineBasicBlock::iterator II,
   // FrameIndex with base register with EBP.  Add an offset to the offset.
   MI.getOperand(i).ChangeToRegister(BasePtr, false);
 
-  // Now add the frame object offset to the offset from EBP. Offset is a
-  // 32-bit integer.
-  int Offset = getFrameIndexOffset(MF, FrameIndex) +
-    (int)(MI.getOperand(i+3).getImm());
-
-  MI.getOperand(i+3).ChangeToImmediate(Offset);
+  // Now add the frame object offset to the offset from EBP.
+  if (MI.getOperand(i+3).isImm()) {
+    // Offset is a 32-bit integer.
+    int Offset = getFrameIndexOffset(MF, FrameIndex) +
+      (int)(MI.getOperand(i+3).getImm());
+  
+     MI.getOperand(i+3).ChangeToImmediate(Offset);
+  } else {
+    // Offset is symbolic. This is extremely rare.
+    uint64_t Offset = getFrameIndexOffset(MF, FrameIndex) +
+                      (uint64_t)MI.getOperand(i+3).getOffset();
+    MI.getOperand(i+3).setOffset(Offset);
+  }
 }
 
 void
diff --git a/test/CodeGen/X86/2008-12-23-crazy-address.ll b/test/CodeGen/X86/2008-12-23-crazy-address.ll
new file mode 100644 (file)
index 0000000..e53a91e
--- /dev/null
@@ -0,0 +1,33 @@
+; RUN: llvm-as < %s | llc -march=x86 -relocation-model=static | grep {lea.*X.*esp} | count 2
+
+@X = external global [0 x i32]
+
+define void @foo() nounwind {
+entry:
+       %Y = alloca i32
+       call void @frob(i32* %Y) nounwind
+       %Y3 = bitcast i32* %Y to i8*
+       %ctg2 = getelementptr i8* %Y3, i32 ptrtoint ([0 x i32]* @X to i32)
+       %0 = ptrtoint i8* %ctg2 to i32
+       call void @borf(i32 %0) nounwind
+       ret void
+}
+
+define void @bar(i32 %i) nounwind {
+entry:
+       %Y = alloca [10 x i32]
+       %0 = getelementptr [10 x i32]* %Y, i32 0, i32 0
+       call void @frob(i32* %0) nounwind
+       %1 = getelementptr [0 x i32]* @X, i32 0, i32 %i
+       %2 = getelementptr [10 x i32]* %Y, i32 0, i32 0
+       %3 = ptrtoint i32* %2 to i32
+       %4 = bitcast i32* %1 to i8*
+       %ctg2 = getelementptr i8* %4, i32 %3
+       %5 = ptrtoint i8* %ctg2 to i32
+       call void @borf(i32 %5) nounwind
+       ret void
+}
+
+declare void @frob(i32*)
+
+declare void @borf(i32)