1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162 |
- #if defined(LIBM_SCCS) && !defined(lint)
- static char rcsid[] = "$NetBSD: s_ceilf.c,v 1.4 1995/05/10 20:46:55 jtc Exp $";
- #endif
- #include "math.h"
- #include "math_private.h"
- #ifdef __STDC__
- static const float huge = 1.0e30;
- #else
- static float huge = 1.0e30;
- #endif
- #ifdef __STDC__
- float __ceilf(float x)
- #else
- float __ceilf(x)
- float x;
- #endif
- {
- int32_t i0,j0;
- u_int32_t i;
- GET_FLOAT_WORD(i0,x);
- j0 = ((i0>>23)&0xff)-0x7f;
- if(j0<23) {
- if(j0<0) {
- if(huge+x>(float)0.0) {
- if(i0<0) {i0=0x80000000;}
- else if(i0!=0) { i0=0x3f800000;}
- }
- } else {
- i = (0x007fffff)>>j0;
- if((i0&i)==0) return x;
- if(huge+x>(float)0.0) {
- if(i0>0) i0 += (0x00800000)>>j0;
- i0 &= (~i);
- }
- }
- } else {
- if(j0==0x80) return x+x;
- else return x;
- }
- SET_FLOAT_WORD(x,i0);
- return x;
- }
- weak_alias (__ceilf, ceilf)
|