diff options
| author | Dimitry Andric <dim@FreeBSD.org> | 2015-01-18 16:17:27 +0000 | 
|---|---|---|
| committer | Dimitry Andric <dim@FreeBSD.org> | 2015-01-18 16:17:27 +0000 | 
| commit | 67c32a98315f785a9ec9d531c1f571a0196c7463 (patch) | |
| tree | 4abb9cbeecc7901726dd0b4a37369596c852e9ef /test/CodeGen/PowerPC/fdiv-combine.ll | |
| parent | 9f61947910e6ab40de38e6b4034751ef1513200f (diff) | |
Diffstat (limited to 'test/CodeGen/PowerPC/fdiv-combine.ll')
| -rw-r--r-- | test/CodeGen/PowerPC/fdiv-combine.ll | 39 | 
1 files changed, 39 insertions, 0 deletions
| diff --git a/test/CodeGen/PowerPC/fdiv-combine.ll b/test/CodeGen/PowerPC/fdiv-combine.ll new file mode 100644 index 000000000000..d3dc3fe913fd --- /dev/null +++ b/test/CodeGen/PowerPC/fdiv-combine.ll @@ -0,0 +1,39 @@ +; RUN: llc -mcpu=ppc64 < %s | FileCheck %s +target datalayout = "E-m:e-i64:64-n32:64" +target triple = "powerpc64-unknown-linux-gnu" + +; Following test case checks: +;   a / D; b / D; c / D; +;                => +;   recip = 1.0 / D; a * recip; b * recip; c * recip; + +define void @three_fdiv_double(double %D, double %a, double %b, double %c) #0 { +; CHECK-LABEL: three_fdiv_double: +; CHECK: fdiv +; CHECK-NEXT-NOT: fdiv +; CHECK: fmul +; CHECK: fmul +; CHECK: fmul +  %div = fdiv double %a, %D +  %div1 = fdiv double %b, %D +  %div2 = fdiv double %c, %D +  tail call void @foo_3d(double %div, double %div1, double %div2) +  ret void +} + +define void @two_fdiv_double(double %D, double %a, double %b) #0 { +; CHECK-LABEL: two_fdiv_double: +; CHECK: fdiv +; CHECK: fdiv +; CHECK-NEXT-NOT: fmul +  %div = fdiv double %a, %D +  %div1 = fdiv double %b, %D +  tail call void @foo_2d(double %div, double %div1) +  ret void +} + +declare void @foo_3d(double, double, double) +declare void @foo_3_2xd(<2 x double>, <2 x double>, <2 x double>) +declare void @foo_2d(double, double) + +attributes #0 = { "unsafe-fp-math"="true" } | 
