public inbox for gcc-cvs@sourceware.org
help / color / mirror / Atom feed
* [gcc(refs/users/meissner/heads/work030)] PowerPC: Force IBM long double for conversion test.
@ 2020-12-17  6:01 Michael Meissner
  0 siblings, 0 replies; only message in thread
From: Michael Meissner @ 2020-12-17  6:01 UTC (permalink / raw)
  To: gcc-cvs

https://gcc.gnu.org/g:fdbf0115a6053e68cfd31a718de12077bcda16eb

commit fdbf0115a6053e68cfd31a718de12077bcda16eb
Author: Michael Meissner <meissner@linux.ibm.com>
Date:   Thu Dec 17 01:01:04 2020 -0500

    PowerPC: Force IBM long double for conversion test.
    
    The test c-c++-common/dfp/convert-bfp-11.c explicit expects long double to use
    the IBM 128-bit extended double format.  In particular, some of the tests
    expect an infinity to be created if decimal values that are converted that are
    too large for IBM extended double.  However, the numbers do fit in the range
    for IEEE 128-bit format, since it has a larger exponent than the IBM 128-bit
    format.  The test fails because an infinity is not generated.
    
    We explicitly set the long double type to IBM extended double.
    
    gcc/testsuite/
    2020-12-17  Michael Meissner  <meissner@linux.ibm.com>
    
            * c-c++-common/dfp/convert-bfp-11.c: Force using IBM 128-bit long
            double.  Remove check for 64-bit long double.

Diff:
---
 gcc/testsuite/c-c++-common/dfp/convert-bfp-11.c | 18 ++++++++++--------
 1 file changed, 10 insertions(+), 8 deletions(-)

diff --git a/gcc/testsuite/c-c++-common/dfp/convert-bfp-11.c b/gcc/testsuite/c-c++-common/dfp/convert-bfp-11.c
index 95c433d2c24..d19d6aa9220 100644
--- a/gcc/testsuite/c-c++-common/dfp/convert-bfp-11.c
+++ b/gcc/testsuite/c-c++-common/dfp/convert-bfp-11.c
@@ -1,9 +1,14 @@
-/* { dg-skip-if "" { ! "powerpc*-*-linux*" } } */
+/* { dg-require-effective-target dfp } */
+/* { dg-require-effective-target ppc_long_double_override_ibm } */
+/* { dg-options "-O2 -mlong-double-128 -mabi=ibmlongdouble -Wno-psabi" } */
 
-/* Test decimal float conversions to and from IBM 128-bit long double. 
-   Checks are skipped at runtime if long double is not 128 bits.
-   Don't force 128-bit long doubles because runtime support depends
-   on glibc.  */
+/* We force the long double type to be IBM 128-bit because the CONVERT_TO_PINF
+   tests will fail if we use IEEE 128-bit floating point.  This is due to IEEE
+   128-bit having a larger exponent range than IBM 128-bit extended double.  So
+   tests that would generate an infinity with IBM 128-bit will generate a
+   normal number with IEEE 128-bit.  */
+
+/* Test decimal float conversions to and from IBM 128-bit long double.   */
 
 #include "convert.h"
 
@@ -36,9 +41,6 @@ CONVERT_TO_PINF (312, tf, sd, 1.6e+308L, d32)
 int
 main ()
 {
-  if (sizeof (long double) != 16)
-    return 0;
-
   convert_101 ();
   convert_102 ();


^ permalink raw reply	[flat|nested] only message in thread

only message in thread, other threads:[~2020-12-17  6:01 UTC | newest]

Thread overview: (only message) (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2020-12-17  6:01 [gcc(refs/users/meissner/heads/work030)] PowerPC: Force IBM long double for conversion test Michael Meissner

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).