/* Test of rounding to nearest, breaking ties away from zero.
- Copyright (C) 2007-2010 Free Software Foundation, Inc.
+ Copyright (C) 2007-2011 Free Software Foundation, Inc.
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
#include "fpucw.h"
#include "isnanl-nolibm.h"
#include "minus-zero.h"
+#include "infinity.h"
#include "nan.h"
#include "macros.h"
/* Zero. */
ASSERT (roundl (0.0L) == 0.0L);
- ASSERT (!signbit (roundl (0.0L)));
ASSERT (roundl (minus_zerol) == 0.0L);
- ASSERT (!!signbit (minus_zerol) == !!signbit (roundl (minus_zerol)));
/* Positive numbers. */
ASSERT (roundl (0.3L) == 0.0L);
ASSERT (roundl (0.5L) == 1.0L);
ASSERT (roundl (-65536.001L) == -65536.0L);
ASSERT (roundl (-2.341e31L) == -2.341e31L);
/* Infinite numbers. */
- ASSERT (roundl (1.0 / 0.0L) == 1.0 / 0.0L);
- ASSERT (roundl (-1.0 / 0.0L) == -1.0 / 0.0L);
+ ASSERT (roundl (Infinityl ()) == Infinityl ());
+ ASSERT (roundl (- Infinityl ()) == - Infinityl ());
/* NaNs. */
ASSERT (isnanl (roundl (NaNl ())));