Reviewed-by: Philippe Mathieu-Daudé <[email protected]>
Signed-off-by: Richard Henderson <[email protected]>
---
fpu/softfloat.c | 8 ++++----
fpu/softfloat-parts.c.inc | 28 ++++++++++++++++------------
2 files changed, 20 insertions(+), 16 deletions(-)
diff --git a/fpu/softfloat.c b/fpu/softfloat.c
index b7d461bca4..246209072e 100644
--- a/fpu/softfloat.c
+++ b/fpu/softfloat.c
@@ -4765,15 +4765,15 @@ void normalizeFloatx80Subnormal(uint64_t aSig, int32_t
*zExpPtr,
floatx80 propagateFloatx80NaN(floatx80 a, floatx80 b, float_status *status)
{
- FloatParts128 pa, pb, *pr;
+ FloatParts128 pa, pb;
if (!floatx80_unpack_canonical(&pa, a, status) ||
!floatx80_unpack_canonical(&pb, b, status)) {
return floatx80_default_nan(status);
}
- pr = parts128_pick_nan(&pa, &pb, status);
- return floatx80_round_pack_canonical(pr, status);
+ pa = parts128_pick_nan(&pa, &pb, status);
+ return floatx80_round_pack_canonical(&pa, status);
}
/*----------------------------------------------------------------------------
@@ -5120,7 +5120,7 @@ static void parts_s390_divide_to_integer(FloatParts64 *a,
FloatParts64 *b,
{
/* POp table "Results: DIVIDE TO INTEGER (Part 1 of 2)" */
if ((float_cmask(a->cls) | float_cmask(b->cls)) & float_cmask_anynan) {
- *r = *parts64_pick_nan(a, b, status);
+ *r = parts64_pick_nan(a, b, status);
*n = *r;
*cc = 1;
} else if (a->cls == float_class_inf || b->cls == float_class_zero) {
diff --git a/fpu/softfloat-parts.c.inc b/fpu/softfloat-parts.c.inc
index ef46dd740c..40ea7e3a39 100644
--- a/fpu/softfloat-parts.c.inc
+++ b/fpu/softfloat-parts.c.inc
@@ -37,11 +37,11 @@ static FloatPartsN partsN(return_nan)(const FloatPartsN *a,
float_status *s)
return *a;
}
-static FloatPartsN *partsN(pick_nan)(FloatPartsN *a, FloatPartsN *b,
- float_status *s)
+static FloatPartsN partsN(pick_nan)(const FloatPartsN *a, const FloatPartsN *b,
+ float_status *s)
{
bool have_snan = false;
- FloatPartsN *ret;
+ const FloatPartsN *ret;
int cmp;
if (is_snan(a->cls) || is_snan(b->cls)) {
@@ -50,8 +50,7 @@ static FloatPartsN *partsN(pick_nan)(FloatPartsN *a,
FloatPartsN *b,
}
if (s->default_nan_mode) {
- *a = partsN(default_nan)(s);
- return a;
+ return partsN(default_nan)(s);
}
switch (s->float_2nan_prop_rule) {
@@ -110,9 +109,9 @@ static FloatPartsN *partsN(pick_nan)(FloatPartsN *a,
FloatPartsN *b,
}
if (is_snan(ret->cls)) {
- *ret = partsN(silence_nan)(ret, s);
+ return partsN(silence_nan)(ret, s);
}
- return ret;
+ return *ret;
}
static FloatPartsN *partsN(pick_nan_muladd)(FloatPartsN *a, FloatPartsN *b,
@@ -605,7 +604,8 @@ static FloatPartsN *partsN(addsub)(FloatPartsN *a,
FloatPartsN *b,
return b;
p_nan:
- return partsN(pick_nan)(a, b, s);
+ *a = partsN(pick_nan)(a, b, s);
+ return a;
}
/*
@@ -647,7 +647,8 @@ static FloatPartsN *partsN(mul)(FloatPartsN *a, FloatPartsN
*b,
}
if (unlikely(ab_mask & float_cmask_anynan)) {
- return partsN(pick_nan)(a, b, s);
+ *a = partsN(pick_nan)(a, b, s);
+ return a;
}
/* Multiply by 0 or Inf */
@@ -833,7 +834,8 @@ static FloatPartsN *partsN(div)(FloatPartsN *a, FloatPartsN
*b,
/* All the NaN cases */
if (unlikely(ab_mask & float_cmask_anynan)) {
- return partsN(pick_nan)(a, b, s);
+ *a = partsN(pick_nan)(a, b, s);
+ return a;
}
if ((ab_mask & float_cmask_denormal) && b->cls != float_class_zero) {
@@ -891,7 +893,8 @@ static FloatPartsN *partsN(modrem)(FloatPartsN *a,
FloatPartsN *b,
/* All the NaN cases */
if (unlikely(ab_mask & float_cmask_anynan)) {
- return partsN(pick_nan)(a, b, s);
+ *a = partsN(pick_nan)(a, b, s);
+ return a;
}
/* Inf % N; N % 0 */
@@ -1514,7 +1517,8 @@ static FloatPartsN *partsN(minmax)(FloatPartsN *a,
FloatPartsN *b,
return is_nan(a->cls) ? b : a;
}
- return partsN(pick_nan)(a, b, s);
+ *a = partsN(pick_nan)(a, b, s);
+ return a;
}
if (ab_mask & float_cmask_denormal) {
--
2.43.0