dfp: Fix decimal_to_binary [PR94111]
authorJakub Jelinek <jakub@redhat.com>
Wed, 11 Mar 2020 08:33:52 +0000 (09:33 +0100)
committerJakub Jelinek <jakub@redhat.com>
Wed, 11 Mar 2020 08:33:52 +0000 (09:33 +0100)
commit312992f5a07ca25f94d538b08401789c2c764293
tree5a36177be134d3b68ae168cd0c6f05442a373e7d
parent05ac4d9c7b336e30413dd80c3630981151499f9e
dfp: Fix decimal_to_binary [PR94111]

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.

2020-03-11  Jakub Jelinek  <jakub@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/ChangeLog
gcc/dfp.c
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.dg/dfp/pr94111.c [new file with mode: 0644]