* indicated otherwise.
*/
-static void partsN(return_nan)(FloatPartsN *a, float_status *s)
+static FloatPartsN partsN(return_nan)(const FloatPartsN *a, float_status *s)
{
switch (a->cls) {
case float_class_snan:
float_raise(float_flag_invalid | float_flag_invalid_snan, s);
if (s->default_nan_mode) {
- *a = partsN(default_nan)(s);
+ return partsN(default_nan)(s);
} else {
- *a = partsN(silence_nan)(a, s);
+ return partsN(silence_nan)(a, s);
}
break;
case float_class_qnan:
if (s->default_nan_mode) {
- *a = partsN(default_nan)(s);
+ return partsN(default_nan)(s);
}
break;
default:
g_assert_not_reached();
}
+ return *a;
}
static FloatPartsN *partsN(pick_nan)(FloatPartsN *a, FloatPartsN *b,
break;
case float_class_snan:
case float_class_qnan:
- partsN(return_nan)(a, status);
+ *a = partsN(return_nan)(a, status);
return;
case float_class_zero:
return;
switch (a->cls) {
case float_class_qnan:
case float_class_snan:
- partsN(return_nan)(a, s);
+ *a = partsN(return_nan)(a, s);
break;
case float_class_zero:
case float_class_inf:
switch (a->cls) {
case float_class_snan:
case float_class_qnan:
- partsN(return_nan)(a, s);
+ *a = partsN(return_nan)(a, s);
break;
case float_class_zero:
case float_class_inf:
switch (a->cls) {
case float_class_snan:
case float_class_qnan:
- parts64_return_nan(a, s);
+ *a = parts64_return_nan(a, s);
break;
case float_class_inf:
static void parts64_float_to_float(FloatParts64 *a, float_status *s)
{
if (is_nan(a->cls)) {
- parts64_return_nan(a, s);
+ *a = parts64_return_nan(a, s);
}
if (a->cls == float_class_denormal) {
float_raise(float_flag_input_denormal_used, s);
static void parts128_float_to_float(FloatParts128 *a, float_status *s)
{
if (is_nan(a->cls)) {
- parts128_return_nan(a, s);
+ *a = parts128_return_nan(a, s);
}
if (a->cls == float_class_denormal) {
float_raise(float_flag_input_denormal_used, s);
case float_class_qnan:
/* Discard the low bits of the NaN. */
r.frac = b->frac_hi;
- parts64_return_nan(&r, s);
+ r = parts64_return_nan(&r, s);
break;
default:
break;
switch (r.cls) {
case float_class_qnan:
case float_class_snan:
- parts128_return_nan(&r, s);
+ r = parts128_return_nan(&r, s);
break;
case float_class_denormal:
float_raise(float_flag_input_denormal_used, s);
break;
case float_class_snan:
case float_class_qnan:
- parts64_return_nan(a, s);
+ *a = parts64_return_nan(a, s);
return;
case float_class_zero:
float_raise(float_flag_divbyzero, s);
break;
case float_class_snan:
case float_class_qnan:
- parts64_return_nan(&xp, status);
+ xp = parts64_return_nan(&xp, status);
return float32_round_pack_canonical(&xp, status);
case float_class_inf:
return xp.sign ? float32_zero : a;