diff options
| author | Eric Christopher <echristo@gmail.com> | 2013-10-21 23:14:06 +0000 |
|---|---|---|
| committer | Eric Christopher <echristo@gmail.com> | 2013-10-21 23:14:06 +0000 |
| commit | 874fa0f6c7958250bc4f545fd4fd31202c19bc4d (patch) | |
| tree | 3b2db756c16c8f960324dc6816de716a3edd7408 /llvm/test/CodeGen/X86/dagcombine-unsafe-math.ll | |
| parent | fe3233a568272f1187e3f2df8fd5179d863bbcd3 (diff) | |
| download | bcm5719-llvm-874fa0f6c7958250bc4f545fd4fd31202c19bc4d.tar.gz bcm5719-llvm-874fa0f6c7958250bc4f545fd4fd31202c19bc4d.zip | |
Fix spelling, grammar, and match naming convention for test files.
llvm-svn: 193130
Diffstat (limited to 'llvm/test/CodeGen/X86/dagcombine-unsafe-math.ll')
| -rw-r--r-- | llvm/test/CodeGen/X86/dagcombine-unsafe-math.ll | 56 |
1 files changed, 56 insertions, 0 deletions
diff --git a/llvm/test/CodeGen/X86/dagcombine-unsafe-math.ll b/llvm/test/CodeGen/X86/dagcombine-unsafe-math.ll new file mode 100644 index 00000000000..f06d9f1dc4b --- /dev/null +++ b/llvm/test/CodeGen/X86/dagcombine-unsafe-math.ll @@ -0,0 +1,56 @@ +; RUN: llc < %s -enable-unsafe-fp-math -mtriple=x86_64-apple-darwin -mcpu=corei7-avx | FileCheck %s + + +; rdar://13126763 +; Expression "x + x*x" was mistakenly transformed into "x * 3.0f". + +define float @test1(float %x) { + %t1 = fmul fast float %x, %x + %t2 = fadd fast float %t1, %x + ret float %t2 +; CHECK: test1 +; CHECK: vaddss +} + +; (x + x) + x => x * 3.0 +define float @test2(float %x) { + %t1 = fadd fast float %x, %x + %t2 = fadd fast float %t1, %x + ret float %t2 +; CHECK: .long 1077936128 +; CHECK: test2 +; CHECK: vmulss LCPI1_0(%rip), %xmm0, %xmm0 +} + +; x + (x + x) => x * 3.0 +define float @test3(float %x) { + %t1 = fadd fast float %x, %x + %t2 = fadd fast float %t1, %x + ret float %t2 +; CHECK: .long 1077936128 +; CHECK: test3 +; CHECK: vmulss LCPI2_0(%rip), %xmm0, %xmm0 +} + +; (y + x) + x != x * 3.0 +define float @test4(float %x, float %y) { + %t1 = fadd fast float %x, %y + %t2 = fadd fast float %t1, %x + ret float %t2 +; CHECK: test4 +; CHECK: vaddss +} + +; rdar://13445387 +; "x + x + x => 3.0 * x" should be disabled after legalization because +; Instruction-Selection doesn't know how to handle "3.0" +; +define float @test5() { + %mul.i.i151 = fmul <4 x float> zeroinitializer, zeroinitializer + %vecext.i8.i152 = extractelement <4 x float> %mul.i.i151, i32 1 + %vecext1.i9.i153 = extractelement <4 x float> %mul.i.i151, i32 0 + %add.i10.i154 = fadd float %vecext1.i9.i153, %vecext.i8.i152 + %vecext.i7.i155 = extractelement <4 x float> %mul.i.i151, i32 2 + %add.i.i156 = fadd float %vecext.i7.i155, %add.i10.i154 + ret float %add.i.i156 +} |

