File tree Expand file tree Collapse file tree 1 file changed +22
-0
lines changed Expand file tree Collapse file tree 1 file changed +22
-0
lines changed Original file line number Diff line number Diff line change
1
+ ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 5
2
+ ; RUN: llc -mtriple=x86_64-- --start-before=x86-isel -mattr=+avx,+fma %s -o - | FileCheck %s
3
+
4
+ define double @fma_folding (double %x ) {
5
+ ; CHECK-LABEL: fma_folding:
6
+ ; CHECK: # %bb.0:
7
+ ; CHECK-NEXT: vmovsd {{.*#+}} xmm0 = [1.0E+0,0.0E+0]
8
+ ; CHECK-NEXT: retq
9
+ %prod = fmul contract ninf nnan double %x , 0 .0
10
+ %fused = fadd contract ninf nnan double %prod , 1 .0
11
+ ret double %fused
12
+ }
13
+
14
+ define double @fma_no_folding (double %x ) {
15
+ ; CHECK-LABEL: fma_no_folding:
16
+ ; CHECK: # %bb.0:
17
+ ; CHECK-NEXT: vxorpd %xmm1, %xmm1, %xmm1
18
+ ; CHECK-NEXT: vfmadd213sd {{.*#+}} xmm0 = (xmm1 * xmm0) + mem
19
+ ; CHECK-NEXT: retq
20
+ %fused = call contract nnan ninf double @llvm.fma.f64 (double %x , double 0 .0 , double -0 .0 )
21
+ ret double %fused
22
+ }
You can’t perform that action at this time.
0 commit comments