1 
2 /*
3  * Copyright (c) 1998, 2001, Oracle and/or its affiliates. All rights reserved.
4  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
5  *
6  * This code is free software; you can redistribute it and/or modify it
7  * under the terms of the GNU General Public License version 2 only, as
8  * published by the Free Software Foundation.  Oracle designates this
9  * particular file as subject to the "Classpath" exception as provided
10  * by Oracle in the LICENSE file that accompanied this code.
11  *
12  * This code is distributed in the hope that it will be useful, but WITHOUT
13  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
14  * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
15  * version 2 for more details (a copy is included in the LICENSE file that
16  * accompanied this code).
17  *
18  * You should have received a copy of the GNU General Public License version
19  * 2 along with this work; if not, write to the Free Software Foundation,
20  * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
21  *
22  * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
23  * or visit www.oracle.com if you need additional information or have any
24  * questions.
25  */
26 
27 /*
28  * wrapper asin(x)
29  */
30 
31 
32 #include "fdlibm.h"
33 
34 
35 #ifdef __STDC__
asin(double x)36         double asin(double x)           /* wrapper asin */
37 #else
38         double asin(x)                  /* wrapper asin */
39         double x;
40 #endif
41 {
42 #ifdef _IEEE_LIBM
43         return __ieee754_asin(x);
44 #else
45         double z;
46         z = __ieee754_asin(x);
47         if(_LIB_VERSION == _IEEE_ || isnan(x)) return z;
48         if(fabs(x)>1.0) {
49                 return __kernel_standard(x,x,2); /* asin(|x|>1) */
50         } else
51             return z;
52 #endif
53 }
54