Fix a bug around truncating vector in const prop.
authorJiangning Liu <jiangning.liu@arm.com>
Thu, 21 Aug 2014 02:12:35 +0000 (02:12 +0000)
committerJiangning Liu <jiangning.liu@arm.com>
Thu, 21 Aug 2014 02:12:35 +0000 (02:12 +0000)
In constant folding stage, "TRUNC" can't handle vector data type.

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

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

index 9124c1119357979bc5f8a34ec5935525bcf0311e..b96d1540d715547e98d5ff89a32178e1cd620674 100644 (file)
@@ -674,6 +674,9 @@ Constant *llvm::ConstantFoldCastInstruction(unsigned opc, Constant *V,
     }
     return nullptr;
   case Instruction::Trunc: {
+    if (V->getType()->isVectorTy())
+      return nullptr;
+
     uint32_t DestBitWidth = cast<IntegerType>(DestTy)->getBitWidth();
     if (ConstantInt *CI = dyn_cast<ConstantInt>(V)) {
       return ConstantInt::get(V->getContext(),
diff --git a/test/Transforms/ConstProp/trunc_vec.ll b/test/Transforms/ConstProp/trunc_vec.ll
new file mode 100644 (file)
index 0000000..99db329
--- /dev/null
@@ -0,0 +1,9 @@
+; RUN: opt -constprop < %s
+
+; Make sure we don't crash on this one
+
+define <8 x i8> @test_truc_vec() {
+  %x = bitcast <2 x i64> <i64 1, i64 2> to <8 x i16>
+  %y = trunc <8 x i16> %x to <8 x i8>
+  ret <8 x i8> %y
+}