From: Nick Lewycky Date: Fri, 23 May 2008 04:54:45 +0000 (+0000) Subject: Constant integer vectors may also be negated. X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=18b3da6c34679cefc9a792f124c16b60097f2740;p=oota-llvm.git Constant integer vectors may also be negated. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@51476 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Transforms/Scalar/InstructionCombining.cpp b/lib/Transforms/Scalar/InstructionCombining.cpp index ce5f2397d22..d7f5ccf7884 100644 --- a/lib/Transforms/Scalar/InstructionCombining.cpp +++ b/lib/Transforms/Scalar/InstructionCombining.cpp @@ -550,6 +550,11 @@ static inline Value *dyn_castNegVal(Value *V) { // Constants can be considered to be negated values if they can be folded. if (ConstantInt *C = dyn_cast(V)) return ConstantExpr::getNeg(C); + + if (ConstantVector *C = dyn_cast(V)) + if (C->getType()->getElementType()->isInteger()) + return ConstantExpr::getNeg(C); + return 0; } diff --git a/test/Transforms/InstCombine/2008-05-22-NegValVector.ll b/test/Transforms/InstCombine/2008-05-22-NegValVector.ll new file mode 100644 index 00000000000..f2511b38325 --- /dev/null +++ b/test/Transforms/InstCombine/2008-05-22-NegValVector.ll @@ -0,0 +1,8 @@ +; RUN: llvm-as < %s | opt -instcombine | llvm-dis | not grep sub + +define <3 x i8> @f(<3 x i8> %a) { + %A = sub <3 x i8> zeroinitializer, %a + %B = mul <3 x i8> %A, + ret <3 x i8> %B +} +