diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index b75e05916630..899705c0cb9e 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,9 @@ +2007-01-24 Richard Guenther + + PR testsuite/30181 + * gcc.dg/builtins-57.c: Change to a link-time testcase + to support non-C99 targets. + 2007-01-24 Jan Hubicka * gcc.dg/tree-ssa/pr23382.c: Avoid DCE from eliminating dead variable. diff --git a/gcc/testsuite/gcc.dg/builtins-57.c b/gcc/testsuite/gcc.dg/builtins-57.c index 87fbd44814ef..361826cb00a5 100644 --- a/gcc/testsuite/gcc.dg/builtins-57.c +++ b/gcc/testsuite/gcc.dg/builtins-57.c @@ -1,16 +1,25 @@ -/* { dg-do compile } */ -/* { dg-options "-fdump-tree-gimple" } */ +/* { dg-do link } */ +/* { dg-options "-std=c99 -ffinite-math-only" } */ -double foo (double x) +#include "builtins-config.h" + +extern void link_error (void); + +extern double floor (double); +extern double trunc (double); +extern double fabs (double); + +void test (double x) { - return __builtin_floor (__builtin_fabs (x)); +#ifdef HAVE_C99_RUNTIME + if (floor (fabs (x)) != trunc (fabs (x))) + link_error (); +#endif + if (__builtin_lfloor (fabs (x)) != (long)fabs (x)) + link_error (); } -long bar (double x) +int main (void) { - return __builtin_lfloor (__builtin_fabs (x)); + return 0; } - -/* { dg-final { scan-tree-dump-not "lfloor" "gimple" } } */ -/* { dg-final { scan-tree-dump "trunc" "gimple" } } */ -/* { dg-final { cleanup-tree-dump "gimple" } } */