From: Chad Rosier Date: Thu, 9 Oct 2014 20:06:29 +0000 (+0000) Subject: [Reassociate] Don't canonicalize X - undef to X + (-undef). X-Git-Url: http://plrg.eecs.uci.edu/git/?a=commitdiff_plain;h=c2bf8fbdf4c9f9cc6077f8cf97160eee4a1a5941;p=oota-llvm.git [Reassociate] Don't canonicalize X - undef to X + (-undef). Phabricator Revision: http://reviews.llvm.org/D5674 PR21205 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@219434 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Transforms/Scalar/Reassociate.cpp b/lib/Transforms/Scalar/Reassociate.cpp index b8fb25d0b9a..0d5ad7311fb 100644 --- a/lib/Transforms/Scalar/Reassociate.cpp +++ b/lib/Transforms/Scalar/Reassociate.cpp @@ -967,6 +967,10 @@ static bool ShouldBreakUpSubtract(Instruction *Sub) { if (BinaryOperator::isNeg(Sub) || BinaryOperator::isFNeg(Sub)) return false; + // Don't breakup X - undef. + if (isa(Sub->getOperand(1))) + return false; + // Don't bother to break this up unless either the LHS is an associable add or // subtract or if this is only used by one. Value *V0 = Sub->getOperand(0); diff --git a/test/Transforms/Reassociate/pr21205.ll b/test/Transforms/Reassociate/pr21205.ll new file mode 100644 index 00000000000..fcc7150478e --- /dev/null +++ b/test/Transforms/Reassociate/pr21205.ll @@ -0,0 +1,21 @@ +; RUN: opt -reassociate -S < %s | FileCheck %s +; PR21205 + +@a = common global i32 0, align 4 +@b = common global i32 0, align 4 + +; Don't canonicalize %conv - undef into %conv + (-undef). +; CHECK-LABEL: @test1 +; CHECK: %sub = fsub fast float %conv, undef +; CHECK: %sub1 = fadd fast float %sub, -1.000000e+00 + +define i32 @test1() { +entry: + %0 = load i32* @a, align 4 + %conv = sitofp i32 %0 to float + %sub = fsub fast float %conv, undef + %sub1 = fadd fast float %sub, -1.000000e+00 + %conv2 = fptosi float %sub1 to i32 + store i32 %conv2, i32* @b, align 4 + ret i32 undef +}