1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2024-11-23 19:23:23 +01:00
llvm-mirror/test/Transforms/InstCombine/zero-point-zero-add.ll
David Majnemer 9e0160358c [InstCombine] We folded an fcmp to an i1 instead of a vector of i1
Remove an ad-hoc transform in InstCombine and replace it with more
general machinery (ValueTracking, InstructionSimplify and VectorUtils).

This fixes PR27332.

llvm-svn: 266175
2016-04-13 06:55:52 +00:00

25 lines
651 B
LLVM

; NOTE: Assertions have been autogenerated by update_test_checks.py
; RUN: opt < %s -instcombine -S | FileCheck %s
declare double @fabs(double) readonly
define double @test(double %X) {
; CHECK-LABEL: @test(
; CHECK-NEXT: [[Y:%.*]] = fadd double %X, 0.000000e+00
; CHECK-NEXT: ret double [[Y]]
;
%Y = fadd double %X, 0.0 ;; Should be a single add x, 0.0
%Z = fadd double %Y, 0.0
ret double %Z
}
define double @test1(double %X) {
; CHECK-LABEL: @test1(
; CHECK-NEXT: [[Y:%.*]] = call double @fabs(double %X)
; CHECK-NEXT: ret double [[Y]]
;
%Y = call double @fabs(double %X)
%Z = fadd double %Y, 0.0
ret double %Z
}