34 #include "libm.h" /* for isgreaterequal macro */ 35 36 long double 37 __fmaxl(long double x, long double y) { 38 union { 39 #if defined(__sparc) 40 unsigned i[4]; 41 #elif defined(__x86) 42 unsigned i[3]; 43 #else 44 #error Unknown architecture 45 #endif 46 long double ld; 47 } xx, yy; 48 unsigned s; 49 50 /* if y is nan, replace it by x */ 51 if (y != y) 52 y = x; 53 54 /* if x is less than y or x and y are unordered, replace x by y */ 55 #if defined(COMPARISON_MACRO_BUG) 56 if (x != x || x < y) 57 #else 58 if (!isgreaterequal(x, y)) 59 #endif 60 x = y; 61 62 /* 63 * now x and y are either both NaN or both numeric; clear the 64 * sign of the result if either x or y has its sign clear 65 */ 66 xx.ld = x; 67 yy.ld = y; 68 #if defined(__sparc) 69 s = ~(xx.i[0] & yy.i[0]) & 0x80000000; 70 xx.i[0] &= ~s; 71 #elif defined(__x86) 72 s = ~(xx.i[2] & yy.i[2]) & 0x8000; 73 xx.i[2] &= ~s; 74 #else 75 #error Unknown architecture 76 #endif 77 78 return (xx.ld); 79 } | 34 #include "libm.h" /* for isgreaterequal macro */ 35 36 long double 37 __fmaxl(long double x, long double y) { 38 union { 39 #if defined(__sparc) 40 unsigned i[4]; 41 #elif defined(__x86) 42 unsigned i[3]; 43 #else 44 #error Unknown architecture 45 #endif 46 long double ld; 47 } xx, yy; 48 unsigned s; 49 50 /* if y is nan, replace it by x */ 51 if (y != y) 52 y = x; 53 54 /* if x is nan, replace it by y */ 55 if (x != x) 56 x = y; 57 58 /* At this point, x and y are either both numeric, or both NaN */ 59 if (!isnan(x) && !isgreaterequal(x, y)) 60 x = y; 61 62 /* 63 * clear the sign of the result if either x or y has its sign clear 64 */ 65 xx.ld = x; 66 yy.ld = y; 67 #if defined(__sparc) 68 s = ~(xx.i[0] & yy.i[0]) & 0x80000000; 69 xx.i[0] &= ~s; 70 #elif defined(__x86) 71 s = ~(xx.i[2] & yy.i[2]) & 0x8000; 72 xx.i[2] &= ~s; 73 #else 74 #error Unknown architecture 75 #endif 76 77 return (xx.ld); 78 } |