|
@@ -83,13 +83,11 @@ define float @fdiv_fneg_fneg_fast(float %x, float %y) {
|
|
|
ret float %div
|
|
|
}
|
|
|
|
|
|
-; FIXME:
|
|
|
; X / (X * Y) --> 1.0 / Y
|
|
|
|
|
|
define float @div_factor(float %x, float %y) {
|
|
|
; CHECK-LABEL: @div_factor(
|
|
|
-; CHECK-NEXT: [[M:%.*]] = fmul float [[X:%.*]], [[Y:%.*]]
|
|
|
-; CHECK-NEXT: [[D:%.*]] = fdiv reassoc nnan float [[X]], [[M]]
|
|
|
+; CHECK-NEXT: [[D:%.*]] = fdiv reassoc nnan float 1.000000e+00, [[Y:%.*]]
|
|
|
; CHECK-NEXT: ret float [[D]]
|
|
|
;
|
|
|
%m = fmul float %x, %y
|
|
@@ -110,14 +108,12 @@ define float @div_factor_too_strict(float %x, float %y) {
|
|
|
ret float %d
|
|
|
}
|
|
|
|
|
|
-; FIXME:
|
|
|
; Commute, verify vector types, and show that we are not dropping extra FMF.
|
|
|
; X / (Y * X) --> 1.0 / Y
|
|
|
|
|
|
define <2 x float> @div_factor_commute(<2 x float> %x, <2 x float> %y) {
|
|
|
; CHECK-LABEL: @div_factor_commute(
|
|
|
-; CHECK-NEXT: [[M:%.*]] = fmul <2 x float> [[Y:%.*]], [[X:%.*]]
|
|
|
-; CHECK-NEXT: [[D:%.*]] = fdiv reassoc nnan ninf nsz <2 x float> [[X]], [[M]]
|
|
|
+; CHECK-NEXT: [[D:%.*]] = fdiv reassoc nnan ninf nsz <2 x float> <float 1.000000e+00, float 1.000000e+00>, [[Y:%.*]]
|
|
|
; CHECK-NEXT: ret <2 x float> [[D]]
|
|
|
;
|
|
|
%m = fmul <2 x float> %y, %x
|