Change default version to GLIBC_2.2.
[kopensolaris-gnu/glibc.git] / sysdeps / sparc / fpu / fraiseexcpt.c
1 /* Raise given exceptions.
2    Copyright (C) 1997, 1999, 2000 Free Software Foundation, Inc.
3    This file is part of the GNU C Library.
4
5    The GNU C Library is free software; you can redistribute it and/or
6    modify it under the terms of the GNU Library General Public License as
7    published by the Free Software Foundation; either version 2 of the
8    License, or (at your option) any later version.
9
10    The GNU C Library is distributed in the hope that it will be useful,
11    but WITHOUT ANY WARRANTY; without even the implied warranty of
12    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
13    Library General Public License for more details.
14
15    You should have received a copy of the GNU Library General Public
16    License along with the GNU C Library; see the file COPYING.LIB.  If not,
17    write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
18    Boston, MA 02111-1307, USA.  */
19
20 #include <fenv.h>
21 #include <math.h>
22
23 int
24 __feraiseexcept (int excepts)
25 {
26   static volatile double sink;
27   static const struct {
28     double zero, one, max, min, sixteen, pi;
29   } c = {
30     0.0, 1.0, DBL_MAX, DBL_MIN, 16.0, M_PI
31   };
32
33   /* Raise exceptions represented by EXPECTS.  But we must raise only
34      one signal at a time.  It is important the if the overflow/underflow
35      exception and the inexact exception are given at the same time,
36      the overflow/underflow exception follows the inexact exception.  */
37
38   /* First: invalid exception.  */
39   if ((FE_INVALID & excepts) != 0)
40     /* One example of a invalid operation is 0/0.  */
41     sink = c.zero / c.zero;
42
43   /* Next: division by zero.  */
44   if ((FE_DIVBYZERO & excepts) != 0)
45     sink = c.one / c.zero;
46
47   /* Next: overflow.  */
48   if ((FE_OVERFLOW & excepts) != 0)
49     sink = c.max * c.max;
50
51   /* Next: underflow.  */
52   if ((FE_UNDERFLOW & excepts) != 0)
53     sink = c.min / c.sixteen;
54
55   /* Last: inexact.  */
56   if ((FE_INEXACT & excepts) != 0)
57     sink = c.one / c.pi;
58
59   /* Success.  */
60   return 0;
61 }
62 strong_alias (__feraiseexcept, __old_feraiseexcept)
63 symbol_version (__old_feraiseexcept, feraiseexcept, GLIBC_2.1);
64 default_symbol_version (__feraiseexcept, feraiseexcept, GLIBC_2.2);