All of lore.kernel.org
 help / color / mirror / Atom feed
From: "Alex Bennée" <alex.bennee@linaro.org>
To: Richard Henderson <richard.henderson@linaro.org>
Cc: qemu-devel@nongnu.org, peter.maydell@linaro.org
Subject: Re: [Qemu-devel] [PATCH v5 20/28] fpu/softfloat: Use float*_silence_nan in propagateFloat*NaN
Date: Tue, 15 May 2018 14:40:25 +0100	[thread overview]
Message-ID: <87efidf35i.fsf@linaro.org> (raw)
In-Reply-To: <20180514221219.7091-21-richard.henderson@linaro.org>


Richard Henderson <richard.henderson@linaro.org> writes:

> We have already checked the arguments for SNaN;
> we don't need to do it again.
>
> Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
> Signed-off-by: Richard Henderson <richard.henderson@linaro.org>

Reviewed-by: Alex Bennée <alex.bennee@linaro.org>

> ---
>  fpu/softfloat-specialize.h | 44 +++++++++++++++++++++++++++++---------
>  1 file changed, 34 insertions(+), 10 deletions(-)
>
> diff --git a/fpu/softfloat-specialize.h b/fpu/softfloat-specialize.h
> index 995a0132c6..4fa068a5dc 100644
> --- a/fpu/softfloat-specialize.h
> +++ b/fpu/softfloat-specialize.h
> @@ -498,7 +498,7 @@ static float32 commonNaNToFloat32(commonNaNT a, float_status *status)
>  | The routine is passed various bits of information about the
>  | two NaNs and should return 0 to select NaN a and 1 for NaN b.
>  | Note that signalling NaNs are always squashed to quiet NaNs
> -| by the caller, by calling floatXX_maybe_silence_nan() before
> +| by the caller, by calling floatXX_silence_nan() before
>  | returning them.
>  |
>  | aIsLargerSignificand is only valid if both a and b are NaNs
> @@ -536,7 +536,7 @@ static int pickNaN(flag aIsQNaN, flag aIsSNaN, flag bIsQNaN, flag bIsSNaN,
>  {
>      /* According to MIPS specifications, if one of the two operands is
>       * a sNaN, a new qNaN has to be generated. This is done in
> -     * floatXX_maybe_silence_nan(). For qNaN inputs the specifications
> +     * floatXX_silence_nan(). For qNaN inputs the specifications
>       * says: "When possible, this QNaN result is one of the operand QNaN
>       * values." In practice it seems that most implementations choose
>       * the first operand if both operands are qNaN. In short this gives
> @@ -788,9 +788,15 @@ static float32 propagateFloat32NaN(float32 a, float32 b, float_status *status)
>
>      if (pickNaN(aIsQuietNaN, aIsSignalingNaN, bIsQuietNaN, bIsSignalingNaN,
>                  aIsLargerSignificand)) {
> -        return float32_maybe_silence_nan(b, status);
> +        if (bIsSignalingNaN) {
> +            return float32_silence_nan(b, status);
> +        }
> +        return b;
>      } else {
> -        return float32_maybe_silence_nan(a, status);
> +        if (aIsSignalingNaN) {
> +            return float32_silence_nan(a, status);
> +        }
> +        return a;
>      }
>  }
>
> @@ -950,9 +956,15 @@ static float64 propagateFloat64NaN(float64 a, float64 b, float_status *status)
>
>      if (pickNaN(aIsQuietNaN, aIsSignalingNaN, bIsQuietNaN, bIsSignalingNaN,
>                  aIsLargerSignificand)) {
> -        return float64_maybe_silence_nan(b, status);
> +        if (bIsSignalingNaN) {
> +            return float64_silence_nan(b, status);
> +        }
> +        return b;
>      } else {
> -        return float64_maybe_silence_nan(a, status);
> +        if (aIsSignalingNaN) {
> +            return float64_silence_nan(a, status);
> +        }
> +        return a;
>      }
>  }
>
> @@ -1121,9 +1133,15 @@ floatx80 propagateFloatx80NaN(floatx80 a, floatx80 b, float_status *status)
>
>      if (pickNaN(aIsQuietNaN, aIsSignalingNaN, bIsQuietNaN, bIsSignalingNaN,
>                  aIsLargerSignificand)) {
> -        return floatx80_maybe_silence_nan(b, status);
> +        if (bIsSignalingNaN) {
> +            return floatx80_silence_nan(b, status);
> +        }
> +        return b;
>      } else {
> -        return floatx80_maybe_silence_nan(a, status);
> +        if (aIsSignalingNaN) {
> +            return floatx80_silence_nan(a, status);
> +        }
> +        return a;
>      }
>  }
>
> @@ -1270,8 +1288,14 @@ static float128 propagateFloat128NaN(float128 a, float128 b,
>
>      if (pickNaN(aIsQuietNaN, aIsSignalingNaN, bIsQuietNaN, bIsSignalingNaN,
>                  aIsLargerSignificand)) {
> -        return float128_maybe_silence_nan(b, status);
> +        if (bIsSignalingNaN) {
> +            return float128_silence_nan(b, status);
> +        }
> +        return b;
>      } else {
> -        return float128_maybe_silence_nan(a, status);
> +        if (aIsSignalingNaN) {
> +            return float128_silence_nan(a, status);
> +        }
> +        return a;
>      }
>  }


--
Alex Bennée

  reply	other threads:[~2018-05-15 13:40 UTC|newest]

Thread overview: 55+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2018-05-14 22:11 [Qemu-devel] [PATCH v5 00/28] softfloat patch roundup Richard Henderson
2018-05-14 22:11 ` [Qemu-devel] [PATCH v5 01/28] fpu/softfloat: Fix conversion from uint64 to float128 Richard Henderson
2018-05-15 10:52   ` Alex Bennée
2018-05-14 22:11 ` [Qemu-devel] [PATCH v5 02/28] fpu/softfloat: Merge NO_SIGNALING_NANS definitions Richard Henderson
2018-05-14 22:11 ` [Qemu-devel] [PATCH v5 03/28] fpu/softfloat: Split floatXX_silence_nan from floatXX_maybe_silence_nan Richard Henderson
2018-05-14 22:11 ` [Qemu-devel] [PATCH v5 04/28] fpu/softfloat: Move softfloat-specialize.h below FloatParts definition Richard Henderson
2018-05-14 22:11 ` [Qemu-devel] [PATCH v5 05/28] fpu/softfloat: Canonicalize NaN fraction Richard Henderson
2018-05-15 10:50   ` Peter Maydell
2018-05-15 11:44   ` Alex Bennée
2018-05-14 22:11 ` [Qemu-devel] [PATCH v5 06/28] fpu/softfloat: Introduce parts_is_snan_frac Richard Henderson
2018-05-15 11:44   ` Alex Bennée
2018-05-14 22:11 ` [Qemu-devel] [PATCH v5 07/28] fpu/softfloat: Replace float_class_dnan with parts_default_nan Richard Henderson
2018-05-15 11:46   ` Alex Bennée
2018-05-14 22:11 ` [Qemu-devel] [PATCH v5 08/28] fpu/softfloat: Replace float_class_msnan with parts_silence_nan Richard Henderson
2018-05-15 11:51   ` Alex Bennée
2018-05-14 22:12 ` [Qemu-devel] [PATCH v5 09/28] target/arm: Use floatX_silence_nan when we have already checked for SNaN Richard Henderson
2018-05-15 13:19   ` Alex Bennée
2018-05-14 22:12 ` [Qemu-devel] [PATCH v5 10/28] target/arm: convert conversion helpers to fpst/ahp_flag Richard Henderson
2018-05-15 10:08   ` Peter Maydell
2018-05-15 15:01     ` Richard Henderson
2018-05-14 22:12 ` [Qemu-devel] [PATCH v5 11/28] target/arm: squash FZ16 behaviour for conversions Richard Henderson
2018-05-14 22:12 ` [Qemu-devel] [PATCH v5 12/28] target/arm: Remove floatX_maybe_silence_nan from conversions Richard Henderson
2018-05-15 13:34   ` Alex Bennée
2018-05-14 22:12 ` [Qemu-devel] [PATCH v5 13/28] fpu/softfloat: Partial support for ARM Alternative half-precision Richard Henderson
2018-05-15 10:52   ` Peter Maydell
2018-05-14 22:12 ` [Qemu-devel] [PATCH v5 14/28] fpu/softfloat: re-factor float to float conversions Richard Henderson
2018-05-15 10:53   ` Peter Maydell
2018-05-14 22:12 ` [Qemu-devel] [PATCH v5 15/28] target/hppa: Remove floatX_maybe_silence_nan from conversions Richard Henderson
2018-05-15 13:39   ` Alex Bennée
2018-05-14 22:12 ` [Qemu-devel] [PATCH v5 16/28] target/m68k: Use floatX_silence_nan when we have already checked for SNaN Richard Henderson
2018-05-14 22:12 ` [Qemu-devel] [PATCH v5 17/28] target/mips: Remove floatX_maybe_silence_nan from conversions Richard Henderson
2018-05-14 22:12 ` [Qemu-devel] [PATCH v5 18/28] target/riscv: " Richard Henderson
2018-05-14 22:12 ` [Qemu-devel] [PATCH v5 19/28] target/s390x: " Richard Henderson
2018-05-14 22:12 ` [Qemu-devel] [PATCH v5 20/28] fpu/softfloat: Use float*_silence_nan in propagateFloat*NaN Richard Henderson
2018-05-15 13:40   ` Alex Bennée [this message]
2018-05-14 22:12 ` [Qemu-devel] [PATCH v5 21/28] fpu/softfloat: Remove floatX_maybe_silence_nan Richard Henderson
2018-05-15 13:41   ` Alex Bennée
2018-05-14 22:12 ` [Qemu-devel] [PATCH v5 22/28] fpu/softfloat: Specialize on snan_bit_is_one Richard Henderson
2018-05-15 10:57   ` Peter Maydell
2018-05-15 13:51   ` Alex Bennée
2018-05-14 22:12 ` [Qemu-devel] [PATCH v5 23/28] fpu/softfloat: Make is_nan et al available to softfloat-specialize.h Richard Henderson
2018-05-15 10:59   ` Peter Maydell
2018-05-15 13:51   ` Alex Bennée
2018-05-14 22:12 ` [Qemu-devel] [PATCH v5 24/28] fpu/softfloat: Pass FloatClass to pickNaN Richard Henderson
2018-05-14 22:12 ` [Qemu-devel] [PATCH v5 25/28] fpu/softfloat: Pass FloatClass to pickNaNMulAdd Richard Henderson
2018-05-14 22:12 ` [Qemu-devel] [PATCH v5 26/28] fpu/softfloat: Define floatN_default_nan in terms of parts_default_nan Richard Henderson
2018-05-15 10:38   ` Peter Maydell
2018-05-14 22:12 ` [Qemu-devel] [PATCH v5 27/28] fpu/softfloat: Clean up parts_default_nan Richard Henderson
2018-05-15 13:42   ` Alex Bennée
2018-05-14 22:12 ` [Qemu-devel] [PATCH v5 28/28] fpu/softfloat: Define floatN_silence_nan in terms of parts_silence_nan Richard Henderson
2018-05-15 13:45   ` Alex Bennée
2018-05-15 15:41     ` Richard Henderson
2018-05-15 16:14       ` Richard Henderson
2018-05-15 11:43 ` [Qemu-devel] [PATCH v5 00/28] softfloat patch roundup Alex Bennée
2018-05-15 13:57 ` Alex Bennée

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=87efidf35i.fsf@linaro.org \
    --to=alex.bennee@linaro.org \
    --cc=peter.maydell@linaro.org \
    --cc=qemu-devel@nongnu.org \
    --cc=richard.henderson@linaro.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.