14 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15 * If applicable, add the following below this CDDL HEADER, with the
16 * fields enclosed by brackets "[]" replaced with your own identifying
17 * information: Portions Copyright [yyyy] [name of copyright owner]
18 *
19 * CDDL HEADER END
20 */
21
22 /*
23 * Copyright 2011 Nexenta Systems, Inc. All rights reserved.
24 */
25 /*
26 * Copyright 2006 Sun Microsystems, Inc. All rights reserved.
27 * Use is subject to license terms.
28 */
29
30 #pragma weak sincospif = __sincospif
31
32 #include "libm.h"
33
34 void sincospi(double x, double *s, double *c);
35
36 void
37 sincospif(float x, float *s, float *c) {
38 double ds, dc;
39
40 #if defined(FPADD_TRAPS_INCOMPLETE_ON_NAN)
41 if (isnanf(x))
42 *s = *c = x * x;
43 else {
44 #endif
45 sincospi((double) x, &ds, &dc);
46 *s = (float) ds;
47 *c = (float) dc;
48 #if defined(FPADD_TRAPS_INCOMPLETE_ON_NAN)
49 }
50 #endif
51 }
|
14 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15 * If applicable, add the following below this CDDL HEADER, with the
16 * fields enclosed by brackets "[]" replaced with your own identifying
17 * information: Portions Copyright [yyyy] [name of copyright owner]
18 *
19 * CDDL HEADER END
20 */
21
22 /*
23 * Copyright 2011 Nexenta Systems, Inc. All rights reserved.
24 */
25 /*
26 * Copyright 2006 Sun Microsystems, Inc. All rights reserved.
27 * Use is subject to license terms.
28 */
29
30 #pragma weak sincospif = __sincospif
31
32 #include "libm.h"
33
34 extern void sincospi(double, double *, double *);
35
36 void
37 sincospif(float x, float *s, float *c) {
38 double ds, dc;
39
40 #if defined(FPADD_TRAPS_INCOMPLETE_ON_NAN)
41 if (isnanf(x))
42 *s = *c = x * x;
43 else {
44 #endif
45 sincospi((double) x, &ds, &dc);
46 *s = (float) ds;
47 *c = (float) dc;
48 #if defined(FPADD_TRAPS_INCOMPLETE_ON_NAN)
49 }
50 #endif
51 }
|