apply Eli's patch for PR2165 and provide a testcase.
authorChris Lattner <sabre@nondot.org>
Thu, 16 Oct 2008 05:26:51 +0000 (05:26 +0000)
committerChris Lattner <sabre@nondot.org>
Thu, 16 Oct 2008 05:26:51 +0000 (05:26 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@57625 91177308-0d34-0410-b5e6-96231b3b80d8

lib/VMCore/ConstantFold.cpp
test/Transforms/ConstProp/bitcast2.ll [new file with mode: 0644]

index 93ee7fe59aeaa44c9330f3d4549d75f4a7276064..fcbda21451bef7b514cf51eb4ae179391dce3782 100644 (file)
@@ -133,6 +133,12 @@ static Constant *FoldBitCast(Constant *V, const Type *DestTy) {
       if (ConstantVector *CV = dyn_cast<ConstantVector>(V))
         return BitCastConstantVector(CV, DestPTy);
     }
+
+    // Canonicalize scalar-to-vector bitcasts into vector-to-vector bitcasts
+    // This allows for other simplifications (although some of them
+    // can only be handled by Analysis/ConstantFolding.cpp).
+    if (isa<ConstantInt>(V) || isa<ConstantFP>(V))
+      return ConstantExpr::getBitCast(ConstantVector::get(&V, 1), DestPTy);
   }
   
   // Finally, implement bitcast folding now.   The code below doesn't handle
diff --git a/test/Transforms/ConstProp/bitcast2.ll b/test/Transforms/ConstProp/bitcast2.ll
new file mode 100644 (file)
index 0000000..66def7f
--- /dev/null
@@ -0,0 +1,8 @@
+; RUN: llvm-as < %s | opt -instcombine | llvm-dis | not grep bitcast
+; PR2165
+
+define <1 x i64> @test() {
+  %A = bitcast i64 63 to <1 x i64>
+  ret <1 x i64> %A
+}
+