On Wed, 11 Mar 2020, Jakub Jelinek wrote:

> Hi!
> 
> As e.g. decimal_from_decnumber shows, the REAL_VALUE_TYPE representation
> contains a decimal128 embedded in ->sig only if it is rvc_normal, for
> other kinds like rvc_inf or rvc_nan, ->sig is ignored and everything is
> contained in the REAL_VALUE_TYPE flags (cl, sign, signalling and decimal).
> decimal_to_binary which is used when folding a decimal{32,64,128} constant
> to a binary floating point type ignores this and thus folds infinities and
> NaNs into +0.0.
> The following patch fixes that by only doing that for rvc_normal.
> Similarly to the binary to decimal folding, it goes through a string, in
> order to e.g. deal with canonical NaN mantissas, or binary float formats
> that don't support infinities and/or NaNs.
> 
> Bootstrapped/regtested on x86_64-linux and i686-linux, ok for trunk?

OK.

Thanks,
Richard.

> 2020-03-11  Jakub Jelinek  <ja...@redhat.com>
> 
>       PR middle-end/94111
>       * dfp.c (decimal_to_binary): Only use decimal128ToString if from->cl
>       is rvc_normal, otherwise use real_to_decimal to print the number to
>       string.
> 
>       * gcc.dg/dfp/pr94111.c: New test.
> 
> --- gcc/dfp.c.jj      2020-01-12 11:54:36.530411644 +0100
> +++ gcc/dfp.c 2020-03-10 12:32:07.246961100 +0100
> @@ -342,9 +342,13 @@ decimal_to_binary (REAL_VALUE_TYPE *to,
>                  const real_format *fmt)
>  {
>    char string[256];
> -  const decimal128 *const d128 = (const decimal128 *) from->sig;
> -
> -  decimal128ToString (d128, string);
> +  if (from->cl == rvc_normal)
> +    {
> +      const decimal128 *const d128 = (const decimal128 *) from->sig;
> +      decimal128ToString (d128, string);
> +    }
> +  else
> +    real_to_decimal (string, from, sizeof (string), 0, 1);
>    real_from_string3 (to, string, fmt);
>  }
>  
> --- gcc/testsuite/gcc.dg/dfp/pr94111.c.jj     2020-03-10 12:38:20.175451924 
> +0100
> +++ gcc/testsuite/gcc.dg/dfp/pr94111.c        2020-03-10 12:38:12.832560341 
> +0100
> @@ -0,0 +1,12 @@
> +/* PR middle-end/94111 */
> +/* { dg-do run } */
> +/* { dg-options "-O2" } */
> +
> +int
> +main ()
> +{
> +  _Decimal32 d = (_Decimal32) __builtin_inff ();
> +  if (!__builtin_isinf ((double) d))
> +    __builtin_abort ();
> +  return 0;
> +}
> 
>       Jakub
> 
> 

-- 
Richard Biener <rguent...@suse.de>
SUSE Software Solutions Germany GmbH, Maxfeldstrasse 5, 90409 Nuernberg,
Germany; GF: Felix Imendörffer; HRB 36809 (AG Nuernberg)

Reply via email to