blob: ad2188218e4dbe53062e7977ce5fdabe667190d9 [file] [log] [blame]
Dan Gohmanfce288f2009-09-09 00:09:15 +00001; RUN: llc < %s -march=arm -mattr=+vfp2 | FileCheck %s
David Goodwin9843a932009-10-01 22:19:57 +00002; RUN: llc < %s -march=arm -mattr=+neon -arm-use-neon-fp=1 | FileCheck %s
3; RUN: llc < %s -march=arm -mattr=+neon -arm-use-neon-fp=0 | FileCheck %s
Dan Gohmanfce288f2009-09-09 00:09:15 +00004; RUN: llc < %s -march=arm -mcpu=cortex-a8 | FileCheck %s
5; RUN: llc < %s -march=arm -mcpu=cortex-a9 | FileCheck %s
David Goodwin42a83f22009-08-04 17:53:06 +00006
Dan Gohman5743a3f2009-08-10 16:48:40 +00007define float @test1(float %acc, float %a, float %b) nounwind {
Jim Grosbache5165492009-11-09 00:11:35 +00008; CHECK: vnmla.f32 s2, s1, s0
David Goodwin42a83f22009-08-04 17:53:06 +00009entry:
10 %0 = fmul float %a, %b
David Goodwinaeb66fe2009-08-10 22:31:04 +000011 %1 = fsub float -0.0, %0
David Goodwin42a83f22009-08-04 17:53:06 +000012 %2 = fsub float %1, %acc
13 ret float %2
14}
15
Dan Gohman5743a3f2009-08-10 16:48:40 +000016define float @test2(float %acc, float %a, float %b) nounwind {
Jim Grosbache5165492009-11-09 00:11:35 +000017; CHECK: vnmla.f32 s2, s1, s0
David Goodwin831b5002009-08-04 18:11:59 +000018entry:
19 %0 = fmul float %a, %b
20 %1 = fmul float -1.0, %0
21 %2 = fsub float %1, %acc
22 ret float %2
23}
24