diff options
author | nsz <nsz@port70.net> | 2012-03-18 20:52:33 +0100 |
---|---|---|
committer | nsz <nsz@port70.net> | 2012-03-18 20:52:33 +0100 |
commit | afad262440d213633144d696b8fdda7a65bf26d1 (patch) | |
tree | ce48fe2e56ad9459dec8503cf377acc81b66fd39 /src/math/lround.c | |
parent | 65db00983f3fa5449f20f2694477f9d5116f6ea5 (diff) | |
download | musl-afad262440d213633144d696b8fdda7a65bf26d1.tar.gz musl-afad262440d213633144d696b8fdda7a65bf26d1.tar.xz musl-afad262440d213633144d696b8fdda7a65bf26d1.zip |
simplify lround and llround functions
Simple wrappers around round is enough because spurious inexact exception is allowed.
Diffstat (limited to 'src/math/lround.c')
-rw-r--r-- | src/math/lround.c | 66 |
1 files changed, 3 insertions, 63 deletions
diff --git a/src/math/lround.c b/src/math/lround.c index f62c8d40..b8b79547 100644 --- a/src/math/lround.c +++ b/src/math/lround.c @@ -1,66 +1,6 @@ -/* origin: FreeBSD /usr/src/lib/msun/src/s_lround.c */ -/*- - * Copyright (c) 2005 David Schultz <das@FreeBSD.ORG> - * All rights reserved. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - * 1. Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - * 2. Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND - * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE - * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE - * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE - * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL - * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS - * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) - * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT - * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY - * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF - * SUCH DAMAGE. - */ +#include <math.h> -#include <limits.h> -#include <fenv.h> -#include "libm.h" - -#ifndef type -#define type double -#define roundit round -#define dtype long -#define DTYPE_MIN LONG_MIN -#define DTYPE_MAX LONG_MAX -#define fn lround -#endif - -/* - * If type has more precision than dtype, the endpoints dtype_(min|max) are - * of the form xxx.5; they are "out of range" because lround() rounds away - * from 0. On the other hand, if type has less precision than dtype, then - * all values that are out of range are integral, so we might as well assume - * that everything is in range. At compile time, INRANGE(x) should reduce to - * two floating-point comparisons in the former case, or TRUE otherwise. - */ -static const type dtype_min = DTYPE_MIN - 0.5; -static const type dtype_max = DTYPE_MAX + 0.5; -#define INRANGE(x) \ - (dtype_max - DTYPE_MAX != 0.5 || ((x) > dtype_min && (x) < dtype_max)) - -dtype fn(type x) +long lround(double x) { - - if (INRANGE(x)) { - x = roundit(x); - return (dtype)x; - } else { -#ifdef FE_INVALID - feraiseexcept(FE_INVALID); -#endif - return DTYPE_MAX; - } + return round(x); } |