Convert "denormal-fp-math" and "denormal-fp-math-f32" into a first class denormal_fpenv attribute. Previously the query for the effective denormal mode involved two string attribute queries with parsing. I'm introducing more uses of this, so it makes sense to convert this to a more efficient encoding. The old representation was also awkward since it was split across two separate attributes. The new encoding just stores the default and float modes as bitfields, largely avoiding the need to consider if the other mode is set. The syntax in the common cases looks like this: `denormal_fpenv(preservesign,preservesign)` `denormal_fpenv(float: preservesign,preservesign)` `denormal_fpenv(dynamic,dynamic float: preservesign,preservesign)` I wasn't sure about reusing the float type name instead of adding a new keyword. It's parsed as a type but only accepts float. I'm also debating switching the name to subnormal to match the current preferred IEEE terminology (also used by nofpclass and other contexts). This has a behavior change when using the command flag debug options to set the denormal mode. The behavior of the flag ignored functions with an explicit attribute set, per the default and f32 version. Now that these are one attribute, the flag logic can't distinguish which of the two components were explicitly set on the function. Only one test appeared to rely on this behavior, so I just avoided using the flags in it. This also does not perform all the code cleanups this enables. In particular the attributor handling could be cleaned up. I also guessed at how to support this in MLIR. I followed MemoryEffects as a reference; it appears bitfields are expanded into arguments to attributes, so the representation there is a bit uglier with the 2 2-element fields flattened into 4 arguments.
797 lines
43 KiB
LLVM
797 lines
43 KiB
LLVM
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 2
|
|
; RUN: opt -aa-pipeline=basic-aa -passes=attributor -attributor-manifest-internal -S < %s | FileCheck %s --check-prefixes=CHECK,TUNIT
|
|
|
|
declare float @llvm.minimumnum.f32(float, float)
|
|
declare float @llvm.maximumnum.f32(float, float)
|
|
declare <2 x float> @llvm.minimumnum.v2f32(<2 x float>, <2 x float>)
|
|
|
|
define float @ret_minimumnum(float %arg0, float %arg1) #0 {
|
|
; CHECK-LABEL: define float @ret_minimumnum
|
|
; CHECK-SAME: (float [[ARG0:%.*]], float [[ARG1:%.*]]) #[[ATTR1:[0-9]+]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call float @llvm.minimumnum.f32(float [[ARG0]], float [[ARG1]]) #[[ATTR9:[0-9]+]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.minimumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_minimumnum_noinf__noinf(float nofpclass(inf) %arg0, float nofpclass(inf) %arg1) #0 {
|
|
; CHECK-LABEL: define nofpclass(inf) float @ret_minimumnum_noinf__noinf
|
|
; CHECK-SAME: (float nofpclass(inf) [[ARG0:%.*]], float nofpclass(inf) [[ARG1:%.*]]) #[[ATTR1]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call nofpclass(inf) float @llvm.minimumnum.f32(float nofpclass(inf) [[ARG0]], float nofpclass(inf) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.minimumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_minimumnum_noinf__nonan(float nofpclass(inf) %arg0, float nofpclass(nan) %arg1) #0 {
|
|
; CHECK-LABEL: define nofpclass(nan) float @ret_minimumnum_noinf__nonan
|
|
; CHECK-SAME: (float nofpclass(inf) [[ARG0:%.*]], float nofpclass(nan) [[ARG1:%.*]]) #[[ATTR1]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call nofpclass(nan) float @llvm.minimumnum.f32(float nofpclass(inf) [[ARG0]], float nofpclass(nan) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.minimumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_minimumnum_nonan__noinf(float nofpclass(nan) %arg0, float nofpclass(inf) %arg1) #0 {
|
|
; CHECK-LABEL: define nofpclass(nan) float @ret_minimumnum_nonan__noinf
|
|
; CHECK-SAME: (float nofpclass(nan) [[ARG0:%.*]], float nofpclass(inf) [[ARG1:%.*]]) #[[ATTR1]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call nofpclass(nan) float @llvm.minimumnum.f32(float nofpclass(nan) [[ARG0]], float nofpclass(inf) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.minimumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_minimumnum_noinf_nonan__nonan(float nofpclass(inf nan) %arg0, float nofpclass(nan) %arg1) #0 {
|
|
; CHECK-LABEL: define nofpclass(nan) float @ret_minimumnum_noinf_nonan__nonan
|
|
; CHECK-SAME: (float nofpclass(nan inf) [[ARG0:%.*]], float nofpclass(nan) [[ARG1:%.*]]) #[[ATTR1]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call nofpclass(nan) float @llvm.minimumnum.f32(float nofpclass(nan inf) [[ARG0]], float nofpclass(nan) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.minimumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_minimumnum_nonan__noinf_nonan(float nofpclass(nan) %arg0, float nofpclass(inf nan) %arg1) #0 {
|
|
; CHECK-LABEL: define nofpclass(nan) float @ret_minimumnum_nonan__noinf_nonan
|
|
; CHECK-SAME: (float nofpclass(nan) [[ARG0:%.*]], float nofpclass(nan inf) [[ARG1:%.*]]) #[[ATTR1]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call nofpclass(nan) float @llvm.minimumnum.f32(float nofpclass(nan) [[ARG0]], float nofpclass(nan inf) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.minimumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_minimumnum_norm_zero__norm_sub(float nofpclass(norm zero) %arg0, float nofpclass(norm sub) %arg1) #0 {
|
|
; CHECK-LABEL: define nofpclass(norm) float @ret_minimumnum_norm_zero__norm_sub
|
|
; CHECK-SAME: (float nofpclass(zero norm) [[ARG0:%.*]], float nofpclass(sub norm) [[ARG1:%.*]]) #[[ATTR1]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call nofpclass(norm) float @llvm.minimumnum.f32(float nofpclass(zero norm) [[ARG0]], float nofpclass(sub norm) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.minimumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_maximumnum(float %arg0, float %arg1) #0 {
|
|
; CHECK-LABEL: define float @ret_maximumnum
|
|
; CHECK-SAME: (float [[ARG0:%.*]], float [[ARG1:%.*]]) #[[ATTR1]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call float @llvm.maximumnum.f32(float [[ARG0]], float [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.maximumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_maximumnum_noinf__noinf(float nofpclass(inf) %arg0, float nofpclass(inf) %arg1) #0 {
|
|
; CHECK-LABEL: define nofpclass(inf) float @ret_maximumnum_noinf__noinf
|
|
; CHECK-SAME: (float nofpclass(inf) [[ARG0:%.*]], float nofpclass(inf) [[ARG1:%.*]]) #[[ATTR1]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call nofpclass(inf) float @llvm.maximumnum.f32(float nofpclass(inf) [[ARG0]], float nofpclass(inf) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.maximumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_maximumnum_noinf__nonan(float nofpclass(inf) %arg0, float nofpclass(nan) %arg1) #0 {
|
|
; CHECK-LABEL: define nofpclass(nan) float @ret_maximumnum_noinf__nonan
|
|
; CHECK-SAME: (float nofpclass(inf) [[ARG0:%.*]], float nofpclass(nan) [[ARG1:%.*]]) #[[ATTR1]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call nofpclass(nan) float @llvm.maximumnum.f32(float nofpclass(inf) [[ARG0]], float nofpclass(nan) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.maximumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_maximumnum_nonan__noinf(float nofpclass(nan) %arg0, float nofpclass(inf) %arg1) #0 {
|
|
; CHECK-LABEL: define nofpclass(nan) float @ret_maximumnum_nonan__noinf
|
|
; CHECK-SAME: (float nofpclass(nan) [[ARG0:%.*]], float nofpclass(inf) [[ARG1:%.*]]) #[[ATTR1]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call nofpclass(nan) float @llvm.maximumnum.f32(float nofpclass(nan) [[ARG0]], float nofpclass(inf) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.maximumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_maximumnum_noinf_nonan__nonan(float nofpclass(inf nan) %arg0, float nofpclass(nan) %arg1) #0 {
|
|
; CHECK-LABEL: define nofpclass(nan) float @ret_maximumnum_noinf_nonan__nonan
|
|
; CHECK-SAME: (float nofpclass(nan inf) [[ARG0:%.*]], float nofpclass(nan) [[ARG1:%.*]]) #[[ATTR1]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call nofpclass(nan) float @llvm.maximumnum.f32(float nofpclass(nan inf) [[ARG0]], float nofpclass(nan) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.maximumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_maximumnum_nonan__noinf_nonan(float nofpclass(nan) %arg0, float nofpclass(inf nan) %arg1) #0 {
|
|
; CHECK-LABEL: define nofpclass(nan) float @ret_maximumnum_nonan__noinf_nonan
|
|
; CHECK-SAME: (float nofpclass(nan) [[ARG0:%.*]], float nofpclass(nan inf) [[ARG1:%.*]]) #[[ATTR1]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call nofpclass(nan) float @llvm.maximumnum.f32(float nofpclass(nan) [[ARG0]], float nofpclass(nan inf) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.maximumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_maximumnum_norm_zero__norm_sub(float nofpclass(norm zero) %arg0, float nofpclass(norm sub) %arg1) #0 {
|
|
; CHECK-LABEL: define nofpclass(norm) float @ret_maximumnum_norm_zero__norm_sub
|
|
; CHECK-SAME: (float nofpclass(zero norm) [[ARG0:%.*]], float nofpclass(sub norm) [[ARG1:%.*]]) #[[ATTR1]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call nofpclass(norm) float @llvm.maximumnum.f32(float nofpclass(zero norm) [[ARG0]], float nofpclass(sub norm) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.maximumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_minimumnum_daz_daz(float %arg0, float %arg1) #1 {
|
|
; CHECK-LABEL: define float @ret_minimumnum_daz_daz
|
|
; CHECK-SAME: (float [[ARG0:%.*]], float [[ARG1:%.*]]) #[[ATTR2:[0-9]+]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call float @llvm.minimumnum.f32(float [[ARG0]], float [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.minimumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_minimumnum_dapz_dappz(float %arg0, float %arg1) #2 {
|
|
; CHECK-LABEL: define float @ret_minimumnum_dapz_dappz
|
|
; CHECK-SAME: (float [[ARG0:%.*]], float [[ARG1:%.*]]) #[[ATTR3:[0-9]+]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call float @llvm.minimumnum.f32(float [[ARG0]], float [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.minimumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
define float @ret_minimumnum_dynamic_dynamic(float %arg0, float %arg1) #3 {
|
|
; CHECK-LABEL: define float @ret_minimumnum_dynamic_dynamic
|
|
; CHECK-SAME: (float [[ARG0:%.*]], float [[ARG1:%.*]]) #[[ATTR4:[0-9]+]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call float @llvm.minimumnum.f32(float [[ARG0]], float [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.minimumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_minimumnum_noinf_nozero__noinf_nozero(float nofpclass(inf zero) %arg0, float nofpclass(inf zero) %arg1) #1 {
|
|
; CHECK-LABEL: define nofpclass(inf zero) float @ret_minimumnum_noinf_nozero__noinf_nozero
|
|
; CHECK-SAME: (float nofpclass(inf zero) [[ARG0:%.*]], float nofpclass(inf zero) [[ARG1:%.*]]) #[[ATTR2]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call nofpclass(inf zero) float @llvm.minimumnum.f32(float nofpclass(inf zero) [[ARG0]], float nofpclass(inf zero) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.minimumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define <2 x float> @ret_minimumnum_noinf_nozero__noinf_nozero_v2f32(<2 x float> nofpclass(inf zero) %arg0, <2 x float> nofpclass(inf zero) %arg1) #1 {
|
|
; CHECK-LABEL: define nofpclass(inf zero) <2 x float> @ret_minimumnum_noinf_nozero__noinf_nozero_v2f32
|
|
; CHECK-SAME: (<2 x float> nofpclass(inf zero) [[ARG0:%.*]], <2 x float> nofpclass(inf zero) [[ARG1:%.*]]) #[[ATTR2]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call nofpclass(inf zero) <2 x float> @llvm.minimumnum.v2f32(<2 x float> nofpclass(inf zero) [[ARG0]], <2 x float> nofpclass(inf zero) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret <2 x float> [[CALL]]
|
|
;
|
|
%call = call <2 x float> @llvm.minimumnum.v2f32(<2 x float> %arg0, <2 x float> %arg1)
|
|
ret <2 x float> %call
|
|
}
|
|
|
|
define float @ret_minimumnum_daz_daz_nozero__nozero(float nofpclass(zero) %arg0, float nofpclass(zero) %arg1) #1 {
|
|
; CHECK-LABEL: define nofpclass(zero) float @ret_minimumnum_daz_daz_nozero__nozero
|
|
; CHECK-SAME: (float nofpclass(zero) [[ARG0:%.*]], float nofpclass(zero) [[ARG1:%.*]]) #[[ATTR2]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call nofpclass(zero) float @llvm.minimumnum.f32(float nofpclass(zero) [[ARG0]], float nofpclass(zero) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.minimumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_minimumnum_dapz_dapz_nozero__nozero(float nofpclass(zero) %arg0, float nofpclass(zero) %arg1) #2 {
|
|
; CHECK-LABEL: define nofpclass(zero) float @ret_minimumnum_dapz_dapz_nozero__nozero
|
|
; CHECK-SAME: (float nofpclass(zero) [[ARG0:%.*]], float nofpclass(zero) [[ARG1:%.*]]) #[[ATTR3]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call nofpclass(zero) float @llvm.minimumnum.f32(float nofpclass(zero) [[ARG0]], float nofpclass(zero) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.minimumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_minimumnum_dynamic_dynamic_nozero__nozero(float nofpclass(zero) %arg0, float nofpclass(zero) %arg1) #3 {
|
|
; CHECK-LABEL: define nofpclass(zero) float @ret_minimumnum_dynamic_dynamic_nozero__nozero
|
|
; CHECK-SAME: (float nofpclass(zero) [[ARG0:%.*]], float nofpclass(zero) [[ARG1:%.*]]) #[[ATTR4]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call nofpclass(zero) float @llvm.minimumnum.f32(float nofpclass(zero) [[ARG0]], float nofpclass(zero) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.minimumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_minimumnum_daz_daz_nozero_nosub__nozero_nosub(float nofpclass(zero sub) %arg0, float nofpclass(zero sub) %arg1) #1 {
|
|
; CHECK-LABEL: define nofpclass(zero sub) float @ret_minimumnum_daz_daz_nozero_nosub__nozero_nosub
|
|
; CHECK-SAME: (float nofpclass(zero sub) [[ARG0:%.*]], float nofpclass(zero sub) [[ARG1:%.*]]) #[[ATTR2]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call nofpclass(zero sub) float @llvm.minimumnum.f32(float nofpclass(zero sub) [[ARG0]], float nofpclass(zero sub) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.minimumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_minimumnum_dynamic_dynamic_nozero_nosub__nozero_nosub(float nofpclass(zero sub) %arg0, float nofpclass(zero sub) %arg1) #3 {
|
|
; CHECK-LABEL: define nofpclass(zero sub) float @ret_minimumnum_dynamic_dynamic_nozero_nosub__nozero_nosub
|
|
; CHECK-SAME: (float nofpclass(zero sub) [[ARG0:%.*]], float nofpclass(zero sub) [[ARG1:%.*]]) #[[ATTR4]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call nofpclass(zero sub) float @llvm.minimumnum.f32(float nofpclass(zero sub) [[ARG0]], float nofpclass(zero sub) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.minimumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_minimumnum_daz_daz_nopzero__nopzero(float nofpclass(pzero) %arg0, float nofpclass(pzero) %arg1) #1 {
|
|
; CHECK-LABEL: define float @ret_minimumnum_daz_daz_nopzero__nopzero
|
|
; CHECK-SAME: (float nofpclass(pzero) [[ARG0:%.*]], float nofpclass(pzero) [[ARG1:%.*]]) #[[ATTR2]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call float @llvm.minimumnum.f32(float nofpclass(pzero) [[ARG0]], float nofpclass(pzero) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.minimumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_minimumnum_daz_daz_nonzero__nonzero(float nofpclass(nzero) %arg0, float nofpclass(nzero) %arg1) #1 {
|
|
; CHECK-LABEL: define float @ret_minimumnum_daz_daz_nonzero__nonzero
|
|
; CHECK-SAME: (float nofpclass(nzero) [[ARG0:%.*]], float nofpclass(nzero) [[ARG1:%.*]]) #[[ATTR2]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call float @llvm.minimumnum.f32(float nofpclass(nzero) [[ARG0]], float nofpclass(nzero) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.minimumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_minimumnum_daz_daz_nonzero_nonsub__nonzero_nonsub(float nofpclass(nzero nsub) %arg0, float nofpclass(nzero nsub) %arg1) #1 {
|
|
; CHECK-LABEL: define nofpclass(nsub) float @ret_minimumnum_daz_daz_nonzero_nonsub__nonzero_nonsub
|
|
; CHECK-SAME: (float nofpclass(nzero nsub) [[ARG0:%.*]], float nofpclass(nzero nsub) [[ARG1:%.*]]) #[[ATTR2]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call nofpclass(nsub) float @llvm.minimumnum.f32(float nofpclass(nzero nsub) [[ARG0]], float nofpclass(nzero nsub) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.minimumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_minimumnum_dapz_dapz_nopzero__nopzero(float nofpclass(pzero) %arg0, float nofpclass(pzero) %arg1) #2 {
|
|
; CHECK-LABEL: define float @ret_minimumnum_dapz_dapz_nopzero__nopzero
|
|
; CHECK-SAME: (float nofpclass(pzero) [[ARG0:%.*]], float nofpclass(pzero) [[ARG1:%.*]]) #[[ATTR3]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call float @llvm.minimumnum.f32(float nofpclass(pzero) [[ARG0]], float nofpclass(pzero) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.minimumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_minimumnum_dapz_dapz_nopzero_nopsub__nopzero_nopsub(float nofpclass(pzero psub) %arg0, float nofpclass(pzero psub) %arg1) #2 {
|
|
; CHECK-LABEL: define nofpclass(psub) float @ret_minimumnum_dapz_dapz_nopzero_nopsub__nopzero_nopsub
|
|
; CHECK-SAME: (float nofpclass(pzero psub) [[ARG0:%.*]], float nofpclass(pzero psub) [[ARG1:%.*]]) #[[ATTR3]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call nofpclass(psub) float @llvm.minimumnum.f32(float nofpclass(pzero psub) [[ARG0]], float nofpclass(pzero psub) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.minimumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_minimumnum_dapz_dapz_nonzero__nonzero(float nofpclass(nzero) %arg0, float nofpclass(nzero) %arg1) #2 {
|
|
; CHECK-LABEL: define float @ret_minimumnum_dapz_dapz_nonzero__nonzero
|
|
; CHECK-SAME: (float nofpclass(nzero) [[ARG0:%.*]], float nofpclass(nzero) [[ARG1:%.*]]) #[[ATTR3]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call float @llvm.minimumnum.f32(float nofpclass(nzero) [[ARG0]], float nofpclass(nzero) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.minimumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_minimumnum_ieee_daz_nozero__nozero(float nofpclass(zero) %arg0, float nofpclass(zero) %arg1) #4 {
|
|
; CHECK-LABEL: define nofpclass(zero) float @ret_minimumnum_ieee_daz_nozero__nozero
|
|
; CHECK-SAME: (float nofpclass(zero) [[ARG0:%.*]], float nofpclass(zero) [[ARG1:%.*]]) #[[ATTR5:[0-9]+]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call nofpclass(zero) float @llvm.minimumnum.f32(float nofpclass(zero) [[ARG0]], float nofpclass(zero) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.minimumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_minimumnum_daz_ieee_nozero__nozero(float nofpclass(zero) %arg0, float nofpclass(zero) %arg1) #5 {
|
|
; CHECK-LABEL: define nofpclass(zero) float @ret_minimumnum_daz_ieee_nozero__nozero
|
|
; CHECK-SAME: (float nofpclass(zero) [[ARG0:%.*]], float nofpclass(zero) [[ARG1:%.*]]) #[[ATTR6:[0-9]+]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call nofpclass(zero) float @llvm.minimumnum.f32(float nofpclass(zero) [[ARG0]], float nofpclass(zero) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.minimumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_minimumnum_ieee_dapz_nozero__nozero(float nofpclass(zero) %arg0, float nofpclass(zero) %arg1) #6 {
|
|
; CHECK-LABEL: define nofpclass(zero) float @ret_minimumnum_ieee_dapz_nozero__nozero
|
|
; CHECK-SAME: (float nofpclass(zero) [[ARG0:%.*]], float nofpclass(zero) [[ARG1:%.*]]) #[[ATTR7:[0-9]+]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call nofpclass(zero) float @llvm.minimumnum.f32(float nofpclass(zero) [[ARG0]], float nofpclass(zero) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.minimumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_minimumnum_dapz_ieee_nozero__nozero(float nofpclass(zero) %arg0, float nofpclass(zero) %arg1) #7 {
|
|
; CHECK-LABEL: define nofpclass(zero) float @ret_minimumnum_dapz_ieee_nozero__nozero
|
|
; CHECK-SAME: (float nofpclass(zero) [[ARG0:%.*]], float nofpclass(zero) [[ARG1:%.*]]) #[[ATTR8:[0-9]+]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call nofpclass(zero) float @llvm.minimumnum.f32(float nofpclass(zero) [[ARG0]], float nofpclass(zero) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.minimumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_minimumnum_noneg_nan__any(float nofpclass(ninf nsub nnorm nan) %arg0, float %arg1) #3 {
|
|
; CHECK-LABEL: define nofpclass(nan) float @ret_minimumnum_noneg_nan__any
|
|
; CHECK-SAME: (float nofpclass(nan ninf nsub nnorm) [[ARG0:%.*]], float [[ARG1:%.*]]) #[[ATTR4]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call nofpclass(nan) float @llvm.minimumnum.f32(float nofpclass(nan ninf nsub nnorm) [[ARG0]], float [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.minimumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_minimumnum_any__noneg_nan(float %arg0, float nofpclass(ninf nsub nnorm nan) %arg1) #3 {
|
|
; CHECK-LABEL: define nofpclass(nan) float @ret_minimumnum_any__noneg_nan
|
|
; CHECK-SAME: (float [[ARG0:%.*]], float nofpclass(nan ninf nsub nnorm) [[ARG1:%.*]]) #[[ATTR4]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call nofpclass(nan) float @llvm.minimumnum.f32(float [[ARG0]], float nofpclass(nan ninf nsub nnorm) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.minimumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_minimumnum_nopos_nan__any(float nofpclass(pinf psub pnorm nan) %arg0, float %arg1) #3 {
|
|
; CHECK-LABEL: define nofpclass(nan pinf psub pnorm) float @ret_minimumnum_nopos_nan__any
|
|
; CHECK-SAME: (float nofpclass(nan pinf psub pnorm) [[ARG0:%.*]], float [[ARG1:%.*]]) #[[ATTR4]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call nofpclass(nan pinf psub pnorm) float @llvm.minimumnum.f32(float nofpclass(nan pinf psub pnorm) [[ARG0]], float [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.minimumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_minimumnum_any__nopos_nan(float %arg0, float nofpclass(pinf psub pnorm nan) %arg1) #3 {
|
|
; CHECK-LABEL: define nofpclass(nan pinf psub pnorm) float @ret_minimumnum_any__nopos_nan
|
|
; CHECK-SAME: (float [[ARG0:%.*]], float nofpclass(nan pinf psub pnorm) [[ARG1:%.*]]) #[[ATTR4]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call nofpclass(nan pinf psub pnorm) float @llvm.minimumnum.f32(float [[ARG0]], float nofpclass(nan pinf psub pnorm) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.minimumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_minimumnum_noneg__any(float nofpclass(ninf nsub nnorm) %arg0, float %arg1) #3 {
|
|
; CHECK-LABEL: define float @ret_minimumnum_noneg__any
|
|
; CHECK-SAME: (float nofpclass(ninf nsub nnorm) [[ARG0:%.*]], float [[ARG1:%.*]]) #[[ATTR4]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call float @llvm.minimumnum.f32(float nofpclass(ninf nsub nnorm) [[ARG0]], float [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.minimumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_minimumnum_any__noneg(float %arg0, float nofpclass(ninf nsub nnorm) %arg1) #3 {
|
|
; CHECK-LABEL: define float @ret_minimumnum_any__noneg
|
|
; CHECK-SAME: (float [[ARG0:%.*]], float nofpclass(ninf nsub nnorm) [[ARG1:%.*]]) #[[ATTR4]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call float @llvm.minimumnum.f32(float [[ARG0]], float nofpclass(ninf nsub nnorm) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.minimumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_minimumnum_nopos__any(float nofpclass(pinf psub pnorm) %arg0, float %arg1) #3 {
|
|
; CHECK-LABEL: define float @ret_minimumnum_nopos__any
|
|
; CHECK-SAME: (float nofpclass(pinf psub pnorm) [[ARG0:%.*]], float [[ARG1:%.*]]) #[[ATTR4]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call float @llvm.minimumnum.f32(float nofpclass(pinf psub pnorm) [[ARG0]], float [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.minimumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_minimumnum_any__nopos(float %arg0, float nofpclass(pinf psub pnorm) %arg1) #3 {
|
|
; CHECK-LABEL: define float @ret_minimumnum_any__nopos
|
|
; CHECK-SAME: (float [[ARG0:%.*]], float nofpclass(pinf psub pnorm) [[ARG1:%.*]]) #[[ATTR4]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call float @llvm.minimumnum.f32(float [[ARG0]], float nofpclass(pinf psub pnorm) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.minimumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_maximumnum_noneg_nan__any(float nofpclass(ninf nsub nnorm nan) %arg0, float %arg1) #3 {
|
|
; CHECK-LABEL: define nofpclass(nan ninf nsub nnorm) float @ret_maximumnum_noneg_nan__any
|
|
; CHECK-SAME: (float nofpclass(nan ninf nsub nnorm) [[ARG0:%.*]], float [[ARG1:%.*]]) #[[ATTR4]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call nofpclass(nan ninf nsub nnorm) float @llvm.maximumnum.f32(float nofpclass(nan ninf nsub nnorm) [[ARG0]], float [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.maximumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_maximumnum_any__noneg_nan(float %arg0, float nofpclass(ninf nsub nnorm nan) %arg1) #3 {
|
|
; CHECK-LABEL: define nofpclass(nan ninf nsub nnorm) float @ret_maximumnum_any__noneg_nan
|
|
; CHECK-SAME: (float [[ARG0:%.*]], float nofpclass(nan ninf nsub nnorm) [[ARG1:%.*]]) #[[ATTR4]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call nofpclass(nan ninf nsub nnorm) float @llvm.maximumnum.f32(float [[ARG0]], float nofpclass(nan ninf nsub nnorm) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.maximumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_maximumnum_nopos_nan__any(float nofpclass(pinf psub pnorm nan) %arg0, float %arg1) #3 {
|
|
; CHECK-LABEL: define nofpclass(nan) float @ret_maximumnum_nopos_nan__any
|
|
; CHECK-SAME: (float nofpclass(nan pinf psub pnorm) [[ARG0:%.*]], float [[ARG1:%.*]]) #[[ATTR4]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call nofpclass(nan) float @llvm.maximumnum.f32(float nofpclass(nan pinf psub pnorm) [[ARG0]], float [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.maximumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_maximumnum_any__nopos_nan(float %arg0, float nofpclass(pinf psub pnorm nan) %arg1) #3 {
|
|
; CHECK-LABEL: define nofpclass(nan) float @ret_maximumnum_any__nopos_nan
|
|
; CHECK-SAME: (float [[ARG0:%.*]], float nofpclass(nan pinf psub pnorm) [[ARG1:%.*]]) #[[ATTR4]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call nofpclass(nan) float @llvm.maximumnum.f32(float [[ARG0]], float nofpclass(nan pinf psub pnorm) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.maximumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_maximumnum_noneg__any(float nofpclass(ninf nsub nnorm) %arg0, float %arg1) #3 {
|
|
; CHECK-LABEL: define float @ret_maximumnum_noneg__any
|
|
; CHECK-SAME: (float nofpclass(ninf nsub nnorm) [[ARG0:%.*]], float [[ARG1:%.*]]) #[[ATTR4]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call float @llvm.maximumnum.f32(float nofpclass(ninf nsub nnorm) [[ARG0]], float [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.maximumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_maximumnum_any__noneg(float %arg0, float nofpclass(ninf nsub nnorm) %arg1) #3 {
|
|
; CHECK-LABEL: define float @ret_maximumnum_any__noneg
|
|
; CHECK-SAME: (float [[ARG0:%.*]], float nofpclass(ninf nsub nnorm) [[ARG1:%.*]]) #[[ATTR4]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call float @llvm.maximumnum.f32(float [[ARG0]], float nofpclass(ninf nsub nnorm) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.maximumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_maximumnum_nopos__any(float nofpclass(pinf psub pnorm) %arg0, float %arg1) #3 {
|
|
; CHECK-LABEL: define float @ret_maximumnum_nopos__any
|
|
; CHECK-SAME: (float nofpclass(pinf psub pnorm) [[ARG0:%.*]], float [[ARG1:%.*]]) #[[ATTR4]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call float @llvm.maximumnum.f32(float nofpclass(pinf psub pnorm) [[ARG0]], float [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.maximumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_maximumnum_any__nopos(float %arg0, float nofpclass(pinf psub pnorm) %arg1) #3 {
|
|
; CHECK-LABEL: define float @ret_maximumnum_any__nopos
|
|
; CHECK-SAME: (float [[ARG0:%.*]], float nofpclass(pinf psub pnorm) [[ARG1:%.*]]) #[[ATTR4]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call float @llvm.maximumnum.f32(float [[ARG0]], float nofpclass(pinf psub pnorm) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.maximumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_minimumnum_nopos__nonan(float nofpclass(pinf pnorm psub pzero) %arg0, float nofpclass(nan) %arg1) #0 {
|
|
; CHECK-LABEL: define nofpclass(nan) float @ret_minimumnum_nopos__nonan
|
|
; CHECK-SAME: (float nofpclass(pinf pzero psub pnorm) [[ARG0:%.*]], float nofpclass(nan) [[ARG1:%.*]]) #[[ATTR1]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call nofpclass(nan) float @llvm.minimumnum.f32(float nofpclass(pinf pzero psub pnorm) [[ARG0]], float nofpclass(nan) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.minimumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_minimumnum_nonan__nopos(float nofpclass(nan) %arg0, float nofpclass(pinf pnorm psub pzero) %arg1) #0 {
|
|
; CHECK-LABEL: define nofpclass(nan) float @ret_minimumnum_nonan__nopos
|
|
; CHECK-SAME: (float nofpclass(nan) [[ARG0:%.*]], float nofpclass(pinf pzero psub pnorm) [[ARG1:%.*]]) #[[ATTR1]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call nofpclass(nan) float @llvm.minimumnum.f32(float nofpclass(nan) [[ARG0]], float nofpclass(pinf pzero psub pnorm) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.minimumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_minimumnum_nopos_nonan__any(float nofpclass(nan pinf pnorm psub pzero) %arg0, float %arg1) #0 {
|
|
; CHECK-LABEL: define nofpclass(nan pinf pzero psub pnorm) float @ret_minimumnum_nopos_nonan__any
|
|
; CHECK-SAME: (float nofpclass(nan pinf pzero psub pnorm) [[ARG0:%.*]], float [[ARG1:%.*]]) #[[ATTR1]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call nofpclass(nan pinf pzero psub pnorm) float @llvm.minimumnum.f32(float nofpclass(nan pinf pzero psub pnorm) [[ARG0]], float [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.minimumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_minimumnum_any__nopos_nonan(float %arg0, float nofpclass(nan pinf pnorm psub pzero) %arg1) #0 {
|
|
; CHECK-LABEL: define nofpclass(nan pinf pzero psub pnorm) float @ret_minimumnum_any__nopos_nonan
|
|
; CHECK-SAME: (float [[ARG0:%.*]], float nofpclass(nan pinf pzero psub pnorm) [[ARG1:%.*]]) #[[ATTR1]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call nofpclass(nan pinf pzero psub pnorm) float @llvm.minimumnum.f32(float [[ARG0]], float nofpclass(nan pinf pzero psub pnorm) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.minimumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_minimumnum_noneg__nonan(float nofpclass(ninf nnorm nsub nzero) %arg0, float nofpclass(nan) %arg1) #0 {
|
|
; CHECK-LABEL: define nofpclass(nan) float @ret_minimumnum_noneg__nonan
|
|
; CHECK-SAME: (float nofpclass(ninf nzero nsub nnorm) [[ARG0:%.*]], float nofpclass(nan) [[ARG1:%.*]]) #[[ATTR1]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call nofpclass(nan) float @llvm.minimumnum.f32(float nofpclass(ninf nzero nsub nnorm) [[ARG0]], float nofpclass(nan) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.minimumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_minimumnum_nonan__noneg(float nofpclass(nan) %arg0, float nofpclass(ninf nnorm nsub nzero) %arg1) #0 {
|
|
; CHECK-LABEL: define nofpclass(nan) float @ret_minimumnum_nonan__noneg
|
|
; CHECK-SAME: (float nofpclass(nan) [[ARG0:%.*]], float nofpclass(ninf nzero nsub nnorm) [[ARG1:%.*]]) #[[ATTR1]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call nofpclass(nan) float @llvm.minimumnum.f32(float nofpclass(nan) [[ARG0]], float nofpclass(ninf nzero nsub nnorm) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.minimumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_minimumnum_noneg_nonan__any(float nofpclass(nan ninf nnorm nsub nzero) %arg0, float %arg1) #0 {
|
|
; CHECK-LABEL: define nofpclass(nan) float @ret_minimumnum_noneg_nonan__any
|
|
; CHECK-SAME: (float nofpclass(nan ninf nzero nsub nnorm) [[ARG0:%.*]], float [[ARG1:%.*]]) #[[ATTR1]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call nofpclass(nan) float @llvm.minimumnum.f32(float nofpclass(nan ninf nzero nsub nnorm) [[ARG0]], float [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.minimumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_minimumnum_any__noneg_nonan(float %arg0, float nofpclass(nan ninf nnorm nsub nzero) %arg1) #0 {
|
|
; CHECK-LABEL: define nofpclass(nan) float @ret_minimumnum_any__noneg_nonan
|
|
; CHECK-SAME: (float [[ARG0:%.*]], float nofpclass(nan ninf nzero nsub nnorm) [[ARG1:%.*]]) #[[ATTR1]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call nofpclass(nan) float @llvm.minimumnum.f32(float [[ARG0]], float nofpclass(nan ninf nzero nsub nnorm) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.minimumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_maximumnum_nopos__nonan(float nofpclass(pinf pnorm psub pzero) %arg0, float nofpclass(nan) %arg1) #0 {
|
|
; CHECK-LABEL: define nofpclass(nan) float @ret_maximumnum_nopos__nonan
|
|
; CHECK-SAME: (float nofpclass(pinf pzero psub pnorm) [[ARG0:%.*]], float nofpclass(nan) [[ARG1:%.*]]) #[[ATTR1]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call nofpclass(nan) float @llvm.maximumnum.f32(float nofpclass(pinf pzero psub pnorm) [[ARG0]], float nofpclass(nan) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.maximumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_maximumnum_nonan__nopos(float nofpclass(nan) %arg0, float nofpclass(pinf pnorm psub pzero) %arg1) #0 {
|
|
; CHECK-LABEL: define nofpclass(nan) float @ret_maximumnum_nonan__nopos
|
|
; CHECK-SAME: (float nofpclass(nan) [[ARG0:%.*]], float nofpclass(pinf pzero psub pnorm) [[ARG1:%.*]]) #[[ATTR1]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call nofpclass(nan) float @llvm.maximumnum.f32(float nofpclass(nan) [[ARG0]], float nofpclass(pinf pzero psub pnorm) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.maximumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_maximumnum_nopos_nonan__any(float nofpclass(nan pinf pnorm psub pzero) %arg0, float %arg1) #0 {
|
|
; CHECK-LABEL: define nofpclass(nan) float @ret_maximumnum_nopos_nonan__any
|
|
; CHECK-SAME: (float nofpclass(nan pinf pzero psub pnorm) [[ARG0:%.*]], float [[ARG1:%.*]]) #[[ATTR1]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call nofpclass(nan) float @llvm.maximumnum.f32(float nofpclass(nan pinf pzero psub pnorm) [[ARG0]], float [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.maximumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_maximumnum_any__nopos_nonan(float %arg0, float nofpclass(nan pinf pnorm psub pzero) %arg1) #0 {
|
|
; CHECK-LABEL: define nofpclass(nan) float @ret_maximumnum_any__nopos_nonan
|
|
; CHECK-SAME: (float [[ARG0:%.*]], float nofpclass(nan pinf pzero psub pnorm) [[ARG1:%.*]]) #[[ATTR1]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call nofpclass(nan) float @llvm.maximumnum.f32(float [[ARG0]], float nofpclass(nan pinf pzero psub pnorm) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.maximumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_maximumnum_noneg__nonan(float nofpclass(ninf nnorm nsub nzero) %arg0, float nofpclass(nan) %arg1) #0 {
|
|
; CHECK-LABEL: define nofpclass(nan) float @ret_maximumnum_noneg__nonan
|
|
; CHECK-SAME: (float nofpclass(ninf nzero nsub nnorm) [[ARG0:%.*]], float nofpclass(nan) [[ARG1:%.*]]) #[[ATTR1]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call nofpclass(nan) float @llvm.maximumnum.f32(float nofpclass(ninf nzero nsub nnorm) [[ARG0]], float nofpclass(nan) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.maximumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_maximumnum_nonan__noneg(float nofpclass(nan) %arg0, float nofpclass(ninf nnorm nsub nzero) %arg1) #0 {
|
|
; CHECK-LABEL: define nofpclass(nan) float @ret_maximumnum_nonan__noneg
|
|
; CHECK-SAME: (float nofpclass(nan) [[ARG0:%.*]], float nofpclass(ninf nzero nsub nnorm) [[ARG1:%.*]]) #[[ATTR1]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call nofpclass(nan) float @llvm.maximumnum.f32(float nofpclass(nan) [[ARG0]], float nofpclass(ninf nzero nsub nnorm) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.maximumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_maximumnum_noneg_nonan__any(float nofpclass(ninf nnorm nsub nzero) %arg0, float %arg1) #0 {
|
|
; CHECK-LABEL: define float @ret_maximumnum_noneg_nonan__any
|
|
; CHECK-SAME: (float nofpclass(ninf nzero nsub nnorm) [[ARG0:%.*]], float [[ARG1:%.*]]) #[[ATTR1]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call float @llvm.maximumnum.f32(float nofpclass(ninf nzero nsub nnorm) [[ARG0]], float [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.maximumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_maximumnum_any__noneg_nonan(float %arg0, float nofpclass(ninf nnorm nsub nzero) %arg1) #0 {
|
|
; CHECK-LABEL: define float @ret_maximumnum_any__noneg_nonan
|
|
; CHECK-SAME: (float [[ARG0:%.*]], float nofpclass(ninf nzero nsub nnorm) [[ARG1:%.*]]) #[[ATTR1]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call float @llvm.maximumnum.f32(float [[ARG0]], float nofpclass(ninf nzero nsub nnorm) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.maximumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_minimumnum_nosnan__any(float nofpclass(snan) %arg0, float %arg1) #0 {
|
|
; CHECK-LABEL: define float @ret_minimumnum_nosnan__any
|
|
; CHECK-SAME: (float nofpclass(snan) [[ARG0:%.*]], float [[ARG1:%.*]]) #[[ATTR1]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call float @llvm.minimumnum.f32(float nofpclass(snan) [[ARG0]], float [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.minimumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_minimumnum_any__nosnan(float %arg0, float nofpclass(snan) %arg1) #0 {
|
|
; CHECK-LABEL: define float @ret_minimumnum_any__nosnan
|
|
; CHECK-SAME: (float [[ARG0:%.*]], float nofpclass(snan) [[ARG1:%.*]]) #[[ATTR1]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call float @llvm.minimumnum.f32(float [[ARG0]], float nofpclass(snan) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.minimumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_maximumnum_nosnan__any(float nofpclass(snan) %arg0, float %arg1) #0 {
|
|
; CHECK-LABEL: define float @ret_maximumnum_nosnan__any
|
|
; CHECK-SAME: (float nofpclass(snan) [[ARG0:%.*]], float [[ARG1:%.*]]) #[[ATTR1]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call float @llvm.maximumnum.f32(float nofpclass(snan) [[ARG0]], float [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.maximumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_maximumnum_any__nosnan(float %arg0, float nofpclass(snan) %arg1) #0 {
|
|
; CHECK-LABEL: define float @ret_maximumnum_any__nosnan
|
|
; CHECK-SAME: (float [[ARG0:%.*]], float nofpclass(snan) [[ARG1:%.*]]) #[[ATTR1]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call float @llvm.maximumnum.f32(float [[ARG0]], float nofpclass(snan) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.maximumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_minimumnum_noqnan__any(float nofpclass(qnan) %arg0, float %arg1) #0 {
|
|
; CHECK-LABEL: define float @ret_minimumnum_noqnan__any
|
|
; CHECK-SAME: (float nofpclass(qnan) [[ARG0:%.*]], float [[ARG1:%.*]]) #[[ATTR1]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call float @llvm.minimumnum.f32(float nofpclass(qnan) [[ARG0]], float [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.minimumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_minimumnum_any__noqnan(float %arg0, float nofpclass(qnan) %arg1) #0 {
|
|
; CHECK-LABEL: define float @ret_minimumnum_any__noqnan
|
|
; CHECK-SAME: (float [[ARG0:%.*]], float nofpclass(qnan) [[ARG1:%.*]]) #[[ATTR1]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call float @llvm.minimumnum.f32(float [[ARG0]], float nofpclass(qnan) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.minimumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_maximumnum_noqnan__any(float nofpclass(qnan) %arg0, float %arg1) #0 {
|
|
; CHECK-LABEL: define float @ret_maximumnum_noqnan__any
|
|
; CHECK-SAME: (float nofpclass(qnan) [[ARG0:%.*]], float [[ARG1:%.*]]) #[[ATTR1]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call float @llvm.maximumnum.f32(float nofpclass(qnan) [[ARG0]], float [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.maximumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_maximumnum_any__noqnan(float %arg0, float nofpclass(qnan) %arg1) #0 {
|
|
; CHECK-LABEL: define float @ret_maximumnum_any__noqnan
|
|
; CHECK-SAME: (float [[ARG0:%.*]], float nofpclass(qnan) [[ARG1:%.*]]) #[[ATTR1]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call float @llvm.maximumnum.f32(float [[ARG0]], float nofpclass(qnan) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.maximumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_minimumnum_nosnan__nosnan(float nofpclass(snan) %arg0, float nofpclass(snan) %arg1) #0 {
|
|
; CHECK-LABEL: define nofpclass(snan) float @ret_minimumnum_nosnan__nosnan
|
|
; CHECK-SAME: (float nofpclass(snan) [[ARG0:%.*]], float nofpclass(snan) [[ARG1:%.*]]) #[[ATTR1]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call nofpclass(snan) float @llvm.minimumnum.f32(float nofpclass(snan) [[ARG0]], float nofpclass(snan) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.minimumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_maximumnum_nosnan__nosnan(float nofpclass(snan) %arg0, float nofpclass(snan) %arg1) #0 {
|
|
; CHECK-LABEL: define nofpclass(snan) float @ret_maximumnum_nosnan__nosnan
|
|
; CHECK-SAME: (float nofpclass(snan) [[ARG0:%.*]], float nofpclass(snan) [[ARG1:%.*]]) #[[ATTR1]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call nofpclass(snan) float @llvm.maximumnum.f32(float nofpclass(snan) [[ARG0]], float nofpclass(snan) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.maximumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_minimumnum_nosnan__noqnan(float nofpclass(snan) %arg0, float nofpclass(qnan) %arg1) #0 {
|
|
; CHECK-LABEL: define float @ret_minimumnum_nosnan__noqnan
|
|
; CHECK-SAME: (float nofpclass(snan) [[ARG0:%.*]], float nofpclass(qnan) [[ARG1:%.*]]) #[[ATTR1]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call float @llvm.minimumnum.f32(float nofpclass(snan) [[ARG0]], float nofpclass(qnan) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.minimumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
define float @ret_maximumnum_noqnan__nosnan(float nofpclass(qnan) %arg0, float nofpclass(qnan) %arg1) #0 {
|
|
; CHECK-LABEL: define nofpclass(qnan) float @ret_maximumnum_noqnan__nosnan
|
|
; CHECK-SAME: (float nofpclass(qnan) [[ARG0:%.*]], float nofpclass(qnan) [[ARG1:%.*]]) #[[ATTR1]] {
|
|
; CHECK-NEXT: [[CALL:%.*]] = call nofpclass(qnan) float @llvm.maximumnum.f32(float nofpclass(qnan) [[ARG0]], float nofpclass(qnan) [[ARG1]]) #[[ATTR9]]
|
|
; CHECK-NEXT: ret float [[CALL]]
|
|
;
|
|
%call = call float @llvm.maximumnum.f32(float %arg0, float %arg1)
|
|
ret float %call
|
|
}
|
|
|
|
attributes #0 = { denormal_fpenv(ieee|ieee) }
|
|
attributes #1 = { denormal_fpenv(preservesign) }
|
|
attributes #2 = { denormal_fpenv(positivezero|positivezero) }
|
|
attributes #3 = { denormal_fpenv(dynamic) }
|
|
attributes #4 = { denormal_fpenv(ieee|preservesign) }
|
|
attributes #5 = { denormal_fpenv(preservesign|ieee) }
|
|
attributes #6 = { denormal_fpenv(ieee|positivezero) }
|
|
attributes #7 = { denormal_fpenv(positivezero|ieee) }
|
|
;; NOTE: These prefixes are unused and the list is autogenerated. Do not add tests below this line:
|
|
; TUNIT: {{.*}}
|