When loading from a constant, fold inttoptr if the integer type and the resulting...
authorAnders Carlsson <andersca@mac.com>
Sun, 6 Feb 2011 20:11:56 +0000 (20:11 +0000)
committerAnders Carlsson <andersca@mac.com>
Sun, 6 Feb 2011 20:11:56 +0000 (20:11 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@124987 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Analysis/ConstantFolding.cpp
test/Transforms/ConstProp/loads.ll

index 243611053c2965e4dbe9dad38329d7f13579b1cf..6c99ad32bbe75b44daf15847aca4c3bf367846e8 100644 (file)
@@ -340,6 +340,17 @@ static bool ReadDataFromGlobal(Constant *C, uint64_t ByteOffset,
     return true;
   }
   
+  if (ConstantExpr *CE = dyn_cast<ConstantExpr>(C)) {
+    if (CE->getOpcode() == Instruction::IntToPtr) {
+      uint64_t PtrSize = TD.getTypeAllocSize(C->getType());
+      uint64_t IntSize = TD.getTypeAllocSize(C->getOperand(0)->getType());
+
+      if (PtrSize == IntSize)
+        return ReadDataFromGlobal(CE->getOperand(0), ByteOffset, CurPtr, 
+                                  BytesLeft, TD);
+    }
+  }
+
   // Otherwise, unknown initializer type.
   return false;
 }
index 9fbba2b355281e79f79d713b17a7d93c6e2eef95..74d80aa18729033fc30c14a4a1648b28288008a8 100644 (file)
@@ -120,3 +120,20 @@ define i1 @test13() {
 ; CHECK: @test13
 ; CHECK: ret i1 false
 }
+
+@g6 = constant [2 x i8*] [i8* inttoptr (i64 1 to i8*), i8* inttoptr (i64 2 to i8*)]
+define i64 @test14() nounwind {
+entry:
+  %tmp = load i64* bitcast ([2 x i8*]* @g6 to i64*)
+  ret i64 %tmp
+; CHECK: @test14
+; CHECK: ret i64 1
+}
+
+define i64 @test15() nounwind {
+entry:
+  %tmp = load i64* bitcast (i8** getelementptr inbounds ([2 x i8*]* @g6, i32 0, i64 1) to i64*)
+  ret i64 %tmp
+; CHECK: @test15
+; CHECK: ret i64 2
+}