1 /* Multiply a 'float' by a power of 2.
2 Copyright 2002-2003, 2007-2024 Free Software Foundation, Inc.
4 This file is free software: you can redistribute it and/or modify
5 it under the terms of the GNU Lesser General Public License as
6 published by the Free Software Foundation; either version 2.1 of the
7 License, or (at your option) any later version.
9 This file is distributed in the hope that it will be useful,
10 but WITHOUT ANY WARRANTY; without even the implied warranty of
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 GNU Lesser General Public License for more details.
14 You should have received a copy of the GNU Lesser General Public License
15 along with this program. If not, see <https://www.gnu.org/licenses/>. */
17 /* Written by Paolo Bonzini and Bruno Haible. */
25 #ifdef USE_LONG_DOUBLE
29 /* Avoid some warnings from "gcc -Wshadow".
30 This file doesn't use the exp() function. */
34 #ifdef USE_LONG_DOUBLE
36 # define DOUBLE long double
38 # define DECL_ROUNDING DECL_LONG_DOUBLE_ROUNDING
39 # define BEGIN_ROUNDING() BEGIN_LONG_DOUBLE_ROUNDING ()
40 # define END_ROUNDING() END_LONG_DOUBLE_ROUNDING ()
41 # define L_(literal) literal##L
44 # define DOUBLE double
46 # define DECL_ROUNDING
47 # define BEGIN_ROUNDING()
48 # define END_ROUNDING()
49 # define L_(literal) literal
53 FUNC (DOUBLE x
, int exp
)
59 /* Check for zero, nan and infinity. */
60 if (!(ISNAN (x
) || x
+ x
== x
))
62 DOUBLE factor
= exp
< 0 ? L_(0.5) : L_(2.0);
71 factor
= factor
* factor
;