if (s->default_nan_mode) {
*a = partsN(default_nan)(s);
} else {
- partsN(silence_nan)(a, s);
+ *a = partsN(silence_nan)(a, s);
}
break;
case float_class_qnan:
}
if (is_snan(ret->cls)) {
- partsN(silence_nan)(ret, s);
+ *ret = partsN(silence_nan)(ret, s);
}
return ret;
}
}
if (is_snan(ret->cls)) {
- partsN(silence_nan)(ret, s);
+ *ret = partsN(silence_nan)(ret, s);
}
return ret;
return frac;
}
-static void parts64_silence_nan(FloatParts64 *p, float_status *status)
+static FloatParts64 parts64_silence_nan(const FloatParts64 *p,
+ float_status *status)
{
- p->frac = parts_silence_nan_frac(p->frac, status);
- p->cls = float_class_qnan;
+ FloatParts64 r = *p;
+
+ r.frac = parts_silence_nan_frac(r.frac, status);
+ r.cls = float_class_qnan;
+ return r;
}
-static void parts128_silence_nan(FloatParts128 *p, float_status *status)
+static FloatParts128 parts128_silence_nan(const FloatParts128 *p,
+ float_status *status)
{
- p->frac_hi = parts_silence_nan_frac(p->frac_hi, status);
- p->cls = float_class_qnan;
+ FloatParts128 r = *p;
+
+ r.frac_hi = parts_silence_nan_frac(r.frac_hi, status);
+ r.cls = float_class_qnan;
+ return r;
}
/*----------------------------------------------------------------------------
FloatParts64 p = unpack_raw64(&float16_params, a);
p.frac <<= float16_params.frac_shift;
- parts64_silence_nan(&p, status);
+ p = parts64_silence_nan(&p, status);
p.frac >>= float16_params.frac_shift;
return pack_raw64(&p, &float16_params);
}
FloatParts64 p = unpack_raw64(&float32_params, a);
p.frac <<= float32_params.frac_shift;
- parts64_silence_nan(&p, status);
+ p = parts64_silence_nan(&p, status);
p.frac >>= float32_params.frac_shift;
return pack_raw64(&p, &float32_params);
}
FloatParts64 p = unpack_raw64(&float64_params, a);
p.frac <<= float64_params.frac_shift;
- parts64_silence_nan(&p, status);
+ p = parts64_silence_nan(&p, status);
p.frac >>= float64_params.frac_shift;
return pack_raw64(&p, &float64_params);
}
FloatParts64 p = unpack_raw64(&bfloat16_params, a);
p.frac <<= bfloat16_params.frac_shift;
- parts64_silence_nan(&p, status);
+ p = parts64_silence_nan(&p, status);
p.frac >>= bfloat16_params.frac_shift;
return pack_raw64(&p, &bfloat16_params);
}
FloatParts128 p = float128_unpack_raw(a);
frac128_shl(&p, float128_params.frac_shift);
- parts128_silence_nan(&p, status);
+ p = parts128_silence_nan(&p, status);
frac128_shr(&p, float128_params.frac_shift);
return float128_pack_raw(&p);
}