|
@@ -279,10 +279,8 @@ define double @select_fcmp_nnan_ole_zero(double %x) {
|
|
|
|
|
|
define double @select_fcmp_nnan_ule_zero(double %x) {
|
|
|
; CHECK-LABEL: @select_fcmp_nnan_ule_zero(
|
|
|
-; CHECK-NEXT: [[LEZERO:%.*]] = fcmp ule double [[X:%.*]], 0.000000e+00
|
|
|
-; CHECK-NEXT: [[NEGX:%.*]] = fsub nnan double 0.000000e+00, [[X]]
|
|
|
-; CHECK-NEXT: [[FABS:%.*]] = select i1 [[LEZERO]], double [[NEGX]], double [[X]]
|
|
|
-; CHECK-NEXT: ret double [[FABS]]
|
|
|
+; CHECK-NEXT: [[TMP1:%.*]] = call nnan double @llvm.fabs.f64(double [[X:%.*]])
|
|
|
+; CHECK-NEXT: ret double [[TMP1]]
|
|
|
;
|
|
|
%lezero = fcmp ule double %x, 0.0
|
|
|
%negx = fsub nnan double 0.0, %x
|
|
@@ -348,10 +346,8 @@ define half @select_fcmp_nnan_ogt_negzero(half %x) {
|
|
|
|
|
|
define half @select_fcmp_nnan_ugt_negzero(half %x) {
|
|
|
; CHECK-LABEL: @select_fcmp_nnan_ugt_negzero(
|
|
|
-; CHECK-NEXT: [[GTZERO:%.*]] = fcmp ugt half [[X:%.*]], 0xH0000
|
|
|
-; CHECK-NEXT: [[NEGX:%.*]] = fsub nnan half 0xH0000, [[X]]
|
|
|
-; CHECK-NEXT: [[FABS:%.*]] = select i1 [[GTZERO]], half [[X]], half [[NEGX]]
|
|
|
-; CHECK-NEXT: ret half [[FABS]]
|
|
|
+; CHECK-NEXT: [[TMP1:%.*]] = call nnan half @llvm.fabs.f16(half [[X:%.*]])
|
|
|
+; CHECK-NEXT: ret half [[TMP1]]
|
|
|
;
|
|
|
%gtzero = fcmp ugt half %x, -0.0
|
|
|
%negx = fsub nnan half 0.0, %x
|