mirror of
				https://sourceware.org/git/glibc.git
				synced 2025-10-21 14:53:53 +03:00 
			
		
		
		
	The patch increase the high value to check if expl overflows. Current high mark value is not really correct, the algorithm accepts high values. It also adds a correct wrapper function to check for overflow and underflow.
		
			
				
	
	
		
			25 lines
		
	
	
		
			646 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			25 lines
		
	
	
		
			646 B
		
	
	
	
		
			C
		
	
	
	
	
	
| #include <math.h>
 | |
| #include <math_private.h>
 | |
| #include <math_ldbl_opt.h>
 | |
| 
 | |
| static const long double o_thres = 709.78271289338399678773454114191496482L;
 | |
| static const long double u_thres = -744.44007192138126231410729844608163411L;
 | |
| 
 | |
| long double __expl(long double x)	/* wrapper exp  */
 | |
| {
 | |
|   long double z;
 | |
|   z = __ieee754_expl(x);
 | |
|   if (_LIB_VERSION == _IEEE_)
 | |
|     return z;
 | |
|   if (__finitel(x))
 | |
|     {
 | |
|       if (x >= o_thres)
 | |
| 	return __kernel_standard_l(x,x,206); /* exp overflow  */
 | |
|       else if (x <= u_thres)
 | |
| 	return __kernel_standard_l(x,x,207); /* exp underflow  */
 | |
|     }
 | |
|   return z;
 | |
| }
 | |
| hidden_def (__expl)
 | |
| long_double_symbol (libm, __expl, expl);
 |