Print this page




  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 }