aboutsummaryrefslogtreecommitdiffstats
path: root/gcc-4.9/gcc/testsuite/gcc.dg/torture/float128-truncsf-underflow.c
blob: 3f1a71366d27c50c68fc40e4f659ee31565b247b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
/* Test truncation from __float128 to float uses after-rounding
   tininess detection.  */

/* { dg-do run { target i?86-*-* x86_64-*-* ia64-*-* } } */
/* { dg-options "" } */
/* { dg-require-effective-target fenv_exceptions } */

#include <fenv.h>
#include <stdlib.h>

int
main (void)
{
  volatile __float128 a = 0x0.ffffffffffp-126q, b = 0x0.ffffffp-126q;
  volatile float r;
  r = (float) a;
  if (fetestexcept (FE_UNDERFLOW))
    abort ();
  if (r != 0x1p-126f)
    abort ();
  r = (float) b;
  if (!fetestexcept (FE_UNDERFLOW))
    abort ();
  if (r != 0x1p-126f)
    abort ();
  exit (0);
}