276 lines
7.9 KiB
LLVM
276 lines
7.9 KiB
LLVM
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 5
|
|
; RUN: llc -mtriple=sparc64 --fp-contract=fast -mattr=-ua2007 < %s | FileCheck %s -check-prefix=NO-UA2007
|
|
; RUN: llc -mtriple=sparc64 --fp-contract=fast -mattr=+ua2007 < %s | FileCheck %s -check-prefix=UA2007
|
|
|
|
define float @fmadds(float %a, float %b, float %c) nounwind {
|
|
; NO-UA2007-LABEL: fmadds:
|
|
; NO-UA2007: ! %bb.0:
|
|
; NO-UA2007-NEXT: fmuls %f1, %f3, %f0
|
|
; NO-UA2007-NEXT: retl
|
|
; NO-UA2007-NEXT: fadds %f0, %f5, %f0
|
|
;
|
|
; UA2007-LABEL: fmadds:
|
|
; UA2007: ! %bb.0:
|
|
; UA2007-NEXT: retl
|
|
; UA2007-NEXT: fmadds %f1, %f3, %f5, %f0
|
|
%ret = call float @llvm.fmuladd.f32(float %a, float %b, float %c)
|
|
ret float %ret
|
|
}
|
|
|
|
define double @fmaddd(double %a, double %b, double %c) nounwind {
|
|
; NO-UA2007-LABEL: fmaddd:
|
|
; NO-UA2007: ! %bb.0:
|
|
; NO-UA2007-NEXT: fmuld %f0, %f2, %f0
|
|
; NO-UA2007-NEXT: retl
|
|
; NO-UA2007-NEXT: faddd %f0, %f4, %f0
|
|
;
|
|
; UA2007-LABEL: fmaddd:
|
|
; UA2007: ! %bb.0:
|
|
; UA2007-NEXT: retl
|
|
; UA2007-NEXT: fmaddd %f0, %f2, %f4, %f0
|
|
%ret = call double @llvm.fmuladd.f64(double %a, double %b, double %c)
|
|
ret double %ret
|
|
}
|
|
|
|
define float @fmsubs(float %a, float %b, float %c) nounwind {
|
|
; NO-UA2007-LABEL: fmsubs:
|
|
; NO-UA2007: ! %bb.0:
|
|
; NO-UA2007-NEXT: fmuls %f1, %f3, %f0
|
|
; NO-UA2007-NEXT: retl
|
|
; NO-UA2007-NEXT: fsubs %f0, %f5, %f0
|
|
;
|
|
; UA2007-LABEL: fmsubs:
|
|
; UA2007: ! %bb.0:
|
|
; UA2007-NEXT: retl
|
|
; UA2007-NEXT: fmsubs %f1, %f3, %f5, %f0
|
|
%neg = fneg float %c
|
|
%ret = call float @llvm.fmuladd.f32(float %a, float %b, float %neg)
|
|
ret float %ret
|
|
}
|
|
|
|
define double @fmsubd(double %a, double %b, double %c) nounwind {
|
|
; NO-UA2007-LABEL: fmsubd:
|
|
; NO-UA2007: ! %bb.0:
|
|
; NO-UA2007-NEXT: fmuld %f0, %f2, %f0
|
|
; NO-UA2007-NEXT: retl
|
|
; NO-UA2007-NEXT: fsubd %f0, %f4, %f0
|
|
;
|
|
; UA2007-LABEL: fmsubd:
|
|
; UA2007: ! %bb.0:
|
|
; UA2007-NEXT: retl
|
|
; UA2007-NEXT: fmsubd %f0, %f2, %f4, %f0
|
|
%neg = fneg double %c
|
|
%ret = call double @llvm.fmuladd.f64(double %a, double %b, double %neg)
|
|
ret double %ret
|
|
}
|
|
|
|
define float @fnmadds(float %a, float %b, float %c) nounwind {
|
|
; NO-UA2007-LABEL: fnmadds:
|
|
; NO-UA2007: ! %bb.0:
|
|
; NO-UA2007-NEXT: fmuls %f1, %f3, %f0
|
|
; NO-UA2007-NEXT: fadds %f0, %f5, %f0
|
|
; NO-UA2007-NEXT: retl
|
|
; NO-UA2007-NEXT: fnegs %f0, %f0
|
|
;
|
|
; UA2007-LABEL: fnmadds:
|
|
; UA2007: ! %bb.0:
|
|
; UA2007-NEXT: retl
|
|
; UA2007-NEXT: fnmadds %f1, %f3, %f5, %f0
|
|
%fma = call float @llvm.fmuladd.f32(float %a, float %b, float %c)
|
|
%ret = fneg float %fma
|
|
ret float %ret
|
|
}
|
|
|
|
define double @fnmaddd(double %a, double %b, double %c) nounwind {
|
|
; NO-UA2007-LABEL: fnmaddd:
|
|
; NO-UA2007: ! %bb.0:
|
|
; NO-UA2007-NEXT: fmuld %f0, %f2, %f0
|
|
; NO-UA2007-NEXT: faddd %f0, %f4, %f0
|
|
; NO-UA2007-NEXT: retl
|
|
; NO-UA2007-NEXT: fnegd %f0, %f0
|
|
;
|
|
; UA2007-LABEL: fnmaddd:
|
|
; UA2007: ! %bb.0:
|
|
; UA2007-NEXT: retl
|
|
; UA2007-NEXT: fnmaddd %f0, %f2, %f4, %f0
|
|
%fma = call double @llvm.fmuladd.f64(double %a, double %b, double %c)
|
|
%ret = fneg double %fma
|
|
ret double %ret
|
|
}
|
|
|
|
define float @fnmsubs(float %a, float %b, float %c) nounwind {
|
|
; NO-UA2007-LABEL: fnmsubs:
|
|
; NO-UA2007: ! %bb.0:
|
|
; NO-UA2007-NEXT: fmuls %f1, %f3, %f0
|
|
; NO-UA2007-NEXT: fsubs %f0, %f5, %f0
|
|
; NO-UA2007-NEXT: retl
|
|
; NO-UA2007-NEXT: fnegs %f0, %f0
|
|
;
|
|
; UA2007-LABEL: fnmsubs:
|
|
; UA2007: ! %bb.0:
|
|
; UA2007-NEXT: retl
|
|
; UA2007-NEXT: fnmsubs %f1, %f3, %f5, %f0
|
|
%neg = fneg float %c
|
|
%fma = call float @llvm.fmuladd.f32(float %a, float %b, float %neg)
|
|
%ret = fneg float %fma
|
|
ret float %ret
|
|
}
|
|
|
|
define double @fnmsubd(double %a, double %b, double %c) nounwind {
|
|
; NO-UA2007-LABEL: fnmsubd:
|
|
; NO-UA2007: ! %bb.0:
|
|
; NO-UA2007-NEXT: fmuld %f0, %f2, %f0
|
|
; NO-UA2007-NEXT: fsubd %f0, %f4, %f0
|
|
; NO-UA2007-NEXT: retl
|
|
; NO-UA2007-NEXT: fnegd %f0, %f0
|
|
;
|
|
; UA2007-LABEL: fnmsubd:
|
|
; UA2007: ! %bb.0:
|
|
; UA2007-NEXT: retl
|
|
; UA2007-NEXT: fnmsubd %f0, %f2, %f4, %f0
|
|
%neg = fneg double %c
|
|
%fma = call double @llvm.fmuladd.f64(double %a, double %b, double %neg)
|
|
%ret = fneg double %fma
|
|
ret double %ret
|
|
}
|
|
|
|
|
|
define float @combine_madds(float %a, float %b, float %c) nounwind {
|
|
; NO-UA2007-LABEL: combine_madds:
|
|
; NO-UA2007: ! %bb.0:
|
|
; NO-UA2007-NEXT: fmuls %f1, %f3, %f0
|
|
; NO-UA2007-NEXT: retl
|
|
; NO-UA2007-NEXT: fadds %f0, %f5, %f0
|
|
;
|
|
; UA2007-LABEL: combine_madds:
|
|
; UA2007: ! %bb.0:
|
|
; UA2007-NEXT: retl
|
|
; UA2007-NEXT: fmadds %f1, %f3, %f5, %f0
|
|
%mul = fmul float %a, %b
|
|
%add = fadd float %mul, %c
|
|
ret float %add
|
|
}
|
|
|
|
define double @combine_maddd(double %a, double %b, double %c) nounwind {
|
|
; NO-UA2007-LABEL: combine_maddd:
|
|
; NO-UA2007: ! %bb.0:
|
|
; NO-UA2007-NEXT: fmuld %f0, %f2, %f0
|
|
; NO-UA2007-NEXT: retl
|
|
; NO-UA2007-NEXT: faddd %f0, %f4, %f0
|
|
;
|
|
; UA2007-LABEL: combine_maddd:
|
|
; UA2007: ! %bb.0:
|
|
; UA2007-NEXT: retl
|
|
; UA2007-NEXT: fmaddd %f0, %f2, %f4, %f0
|
|
%mul = fmul double %a, %b
|
|
%add = fadd double %mul, %c
|
|
ret double %add
|
|
}
|
|
|
|
define float @combine_msubs(float %a, float %b, float %c) nounwind {
|
|
; NO-UA2007-LABEL: combine_msubs:
|
|
; NO-UA2007: ! %bb.0:
|
|
; NO-UA2007-NEXT: fmuls %f1, %f3, %f0
|
|
; NO-UA2007-NEXT: retl
|
|
; NO-UA2007-NEXT: fsubs %f0, %f5, %f0
|
|
;
|
|
; UA2007-LABEL: combine_msubs:
|
|
; UA2007: ! %bb.0:
|
|
; UA2007-NEXT: retl
|
|
; UA2007-NEXT: fmsubs %f1, %f3, %f5, %f0
|
|
%mul = fmul float %a, %b
|
|
%sub = fsub float %mul, %c
|
|
ret float %sub
|
|
}
|
|
|
|
define double @combine_msubd(double %a, double %b, double %c) nounwind {
|
|
; NO-UA2007-LABEL: combine_msubd:
|
|
; NO-UA2007: ! %bb.0:
|
|
; NO-UA2007-NEXT: fmuld %f0, %f2, %f0
|
|
; NO-UA2007-NEXT: retl
|
|
; NO-UA2007-NEXT: fsubd %f0, %f4, %f0
|
|
;
|
|
; UA2007-LABEL: combine_msubd:
|
|
; UA2007: ! %bb.0:
|
|
; UA2007-NEXT: retl
|
|
; UA2007-NEXT: fmsubd %f0, %f2, %f4, %f0
|
|
%mul = fmul double %a, %b
|
|
%sub = fsub double %mul, %c
|
|
ret double %sub
|
|
}
|
|
|
|
define float @combine_nmadds(float %a, float %b, float %c) nounwind {
|
|
; NO-UA2007-LABEL: combine_nmadds:
|
|
; NO-UA2007: ! %bb.0:
|
|
; NO-UA2007-NEXT: fmuls %f1, %f3, %f0
|
|
; NO-UA2007-NEXT: fadds %f0, %f5, %f0
|
|
; NO-UA2007-NEXT: retl
|
|
; NO-UA2007-NEXT: fnegs %f0, %f0
|
|
;
|
|
; UA2007-LABEL: combine_nmadds:
|
|
; UA2007: ! %bb.0:
|
|
; UA2007-NEXT: retl
|
|
; UA2007-NEXT: fnmadds %f1, %f3, %f5, %f0
|
|
%mul = fmul float %a, %b
|
|
%add = fadd float %mul, %c
|
|
%neg = fneg float %add
|
|
ret float %neg
|
|
}
|
|
|
|
define double @combine_nmaddd(double %a, double %b, double %c) nounwind {
|
|
; NO-UA2007-LABEL: combine_nmaddd:
|
|
; NO-UA2007: ! %bb.0:
|
|
; NO-UA2007-NEXT: fmuld %f0, %f2, %f0
|
|
; NO-UA2007-NEXT: faddd %f0, %f4, %f0
|
|
; NO-UA2007-NEXT: retl
|
|
; NO-UA2007-NEXT: fnegd %f0, %f0
|
|
;
|
|
; UA2007-LABEL: combine_nmaddd:
|
|
; UA2007: ! %bb.0:
|
|
; UA2007-NEXT: retl
|
|
; UA2007-NEXT: fnmaddd %f0, %f2, %f4, %f0
|
|
%mul = fmul double %a, %b
|
|
%add = fadd double %mul, %c
|
|
%neg = fneg double %add
|
|
ret double %neg
|
|
}
|
|
|
|
define float @combine_nmsubs(float %a, float %b, float %c) nounwind {
|
|
; NO-UA2007-LABEL: combine_nmsubs:
|
|
; NO-UA2007: ! %bb.0:
|
|
; NO-UA2007-NEXT: fmuls %f1, %f3, %f0
|
|
; NO-UA2007-NEXT: fsubs %f0, %f5, %f0
|
|
; NO-UA2007-NEXT: retl
|
|
; NO-UA2007-NEXT: fnegs %f0, %f0
|
|
;
|
|
; UA2007-LABEL: combine_nmsubs:
|
|
; UA2007: ! %bb.0:
|
|
; UA2007-NEXT: retl
|
|
; UA2007-NEXT: fnmsubs %f1, %f3, %f5, %f0
|
|
%mul = fmul float %a, %b
|
|
%sub = fsub float %mul, %c
|
|
%neg = fneg float %sub
|
|
ret float %neg
|
|
}
|
|
|
|
define double @combine_nmsubd(double %a, double %b, double %c) nounwind {
|
|
; NO-UA2007-LABEL: combine_nmsubd:
|
|
; NO-UA2007: ! %bb.0:
|
|
; NO-UA2007-NEXT: fmuld %f0, %f2, %f0
|
|
; NO-UA2007-NEXT: fsubd %f0, %f4, %f0
|
|
; NO-UA2007-NEXT: retl
|
|
; NO-UA2007-NEXT: fnegd %f0, %f0
|
|
;
|
|
; UA2007-LABEL: combine_nmsubd:
|
|
; UA2007: ! %bb.0:
|
|
; UA2007-NEXT: retl
|
|
; UA2007-NEXT: fnmsubd %f0, %f2, %f4, %f0
|
|
%mul = fmul double %a, %b
|
|
%sub = fsub double %mul, %c
|
|
%neg = fneg double %sub
|
|
ret double %neg
|
|
}
|
|
|
|
declare float @llvm.fmuladd.f32(float, float, float)
|
|
declare double @llvm.fmuladd.f64(double, double, double)
|