mirror of
				https://github.com/jart/cosmopolitan.git
				synced 2025-10-25 02:30:57 +00:00 
			
		
		
		
	Perform build and magnum tuning
Building o//third_party/python now takes 5 seconds on my PC This change works towards modifying Python to use runtime dispatching when appropriate. For example, when loading the magnums in the socket module, it's a good idea to check if the magnum is zero, because that means the local system platform doesn't support it.
This commit is contained in:
		
							parent
							
								
									ee7e296339
								
							
						
					
					
						commit
						d26d7ae0e4
					
				
					 1028 changed files with 6576 additions and 172777 deletions
				
			
		
							
								
								
									
										93
									
								
								third_party/python/Include/pymath.h
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										93
									
								
								third_party/python/Include/pymath.h
									
										
									
									
										vendored
									
									
								
							|  | @ -1,7 +1,7 @@ | |||
| #ifndef Py_PYMATH_H | ||||
| #define Py_PYMATH_H | ||||
| 
 | ||||
| #include "pyconfig.h" /* include for defines */ | ||||
| #include "third_party/python/pyconfig.h" | ||||
| /* clang-format off */ | ||||
| 
 | ||||
| /**************************************************************************
 | ||||
| Symbols and macros to supply platform-independent interfaces to mathematical | ||||
|  | @ -29,10 +29,10 @@ extern double hypot(double, double); | |||
| /* extra declarations */ | ||||
| #ifndef _MSC_VER | ||||
| #ifndef __STDC__ | ||||
| extern double fmod (double, double); | ||||
| extern double frexp (double, int *); | ||||
| extern double ldexp (double, int); | ||||
| extern double modf (double, double *); | ||||
| extern double fmod(double, double); | ||||
| extern double frexp(double, int *); | ||||
| extern double ldexp(double, int); | ||||
| extern double modf(double, double *); | ||||
| extern double pow(double, double); | ||||
| #endif /* __STDC__ */ | ||||
| #endif /* _MSC_VER */ | ||||
|  | @ -60,7 +60,6 @@ extern double pow(double, double); | |||
| #define Py_MATH_TAU 6.2831853071795864769252867665590057683943L | ||||
| #endif | ||||
| 
 | ||||
| 
 | ||||
| /* On x86, Py_FORCE_DOUBLE forces a floating-point number out of an x87 FPU
 | ||||
|    register and into a 64-bit memory location, rounding from extended | ||||
|    precision to double precision in the process.  On other platforms it does | ||||
|  | @ -69,12 +68,12 @@ extern double pow(double, double); | |||
| /* we take double rounding as evidence of x87 usage */ | ||||
| #ifndef Py_LIMITED_API | ||||
| #ifndef Py_FORCE_DOUBLE | ||||
| #  ifdef X87_DOUBLE_ROUNDING | ||||
| #ifdef X87_DOUBLE_ROUNDING | ||||
| PyAPI_FUNC(double) _Py_force_double(double); | ||||
| #    define Py_FORCE_DOUBLE(X) (_Py_force_double(X)) | ||||
| #  else | ||||
| #    define Py_FORCE_DOUBLE(X) (X) | ||||
| #  endif | ||||
| #define Py_FORCE_DOUBLE(X) (_Py_force_double(X)) | ||||
| #else | ||||
| #define Py_FORCE_DOUBLE(X) (X) | ||||
| #endif | ||||
| #endif | ||||
| #endif | ||||
| 
 | ||||
|  | @ -115,12 +114,12 @@ PyAPI_FUNC(void) _Py_set_387controlword(unsigned short); | |||
|  * Note: PC/pyconfig.h defines Py_IS_INFINITY as _isinf | ||||
|  */ | ||||
| #ifndef Py_IS_INFINITY | ||||
| #  if defined HAVE_DECL_ISINF && HAVE_DECL_ISINF == 1 | ||||
| #    define Py_IS_INFINITY(X) isinf(X) | ||||
| #  else | ||||
| #    define Py_IS_INFINITY(X) ((X) &&                                   \ | ||||
|                                (Py_FORCE_DOUBLE(X)*0.5 == Py_FORCE_DOUBLE(X))) | ||||
| #  endif | ||||
| #if defined HAVE_DECL_ISINF && HAVE_DECL_ISINF == 1 | ||||
| #define Py_IS_INFINITY(X) isinf(X) | ||||
| #else | ||||
| #define Py_IS_INFINITY(X) \ | ||||
|   ((X) && (Py_FORCE_DOUBLE(X) * 0.5 == Py_FORCE_DOUBLE(X))) | ||||
| #endif | ||||
| #endif | ||||
| 
 | ||||
| /* Py_IS_FINITE(X)
 | ||||
|  | @ -157,27 +156,29 @@ PyAPI_FUNC(void) _Py_set_387controlword(unsigned short); | |||
|  */ | ||||
| #if !defined(Py_NAN) && !defined(Py_NO_NAN) | ||||
| #if !defined(__INTEL_COMPILER) | ||||
|     #define Py_NAN (Py_HUGE_VAL * 0.) | ||||
| #define Py_NAN (Py_HUGE_VAL * 0.) | ||||
| #else /* __INTEL_COMPILER */ | ||||
|     #if defined(ICC_NAN_STRICT) | ||||
|         #pragma float_control(push) | ||||
|         #pragma float_control(precise, on) | ||||
|         #pragma float_control(except,  on) | ||||
|         #if defined(_MSC_VER) | ||||
|             __declspec(noinline) | ||||
|         #else /* Linux */ | ||||
|             __attribute__((noinline)) | ||||
|         #endif /* _MSC_VER */ | ||||
|         static double __icc_nan() | ||||
|         { | ||||
|             return sqrt(-1.0); | ||||
|         } | ||||
|         #pragma float_control (pop) | ||||
|         #define Py_NAN __icc_nan() | ||||
|     #else /* ICC_NAN_RELAXED as default for Intel Compiler */ | ||||
|         static const union { unsigned char buf[8]; double __icc_nan; } __nan_store = {0,0,0,0,0,0,0xf8,0x7f}; | ||||
|         #define Py_NAN (__nan_store.__icc_nan) | ||||
|     #endif /* ICC_NAN_STRICT */ | ||||
| #if defined(ICC_NAN_STRICT) | ||||
| #pragma float_control(push) | ||||
| #pragma float_control(precise, on) | ||||
| #pragma float_control(except, on) | ||||
| #if defined(_MSC_VER) | ||||
| __declspec(noinline) | ||||
| #else /* Linux */ | ||||
| __attribute__((noinline)) | ||||
| #endif /* _MSC_VER */ | ||||
|     static double __icc_nan() { | ||||
|   return sqrt(-1.0); | ||||
| } | ||||
| #pragma float_control(pop) | ||||
| #define Py_NAN __icc_nan() | ||||
| #else /* ICC_NAN_RELAXED as default for Intel Compiler */ | ||||
| static const union { | ||||
|   unsigned char buf[8]; | ||||
|   double __icc_nan; | ||||
| } __nan_store = {0, 0, 0, 0, 0, 0, 0xf8, 0x7f}; | ||||
| #define Py_NAN (__nan_store.__icc_nan) | ||||
| #endif /* ICC_NAN_STRICT */ | ||||
| #endif /* __INTEL_COMPILER */ | ||||
| #endif | ||||
| 
 | ||||
|  | @ -210,21 +211,25 @@ PyAPI_FUNC(void) _Py_set_387controlword(unsigned short); | |||
| #if defined(__FreeBSD__) || defined(__OpenBSD__) | ||||
| #define Py_OVERFLOWED(X) isinf(X) | ||||
| #else | ||||
| #define Py_OVERFLOWED(X) ((X) != 0.0 && (errno == ERANGE ||    \ | ||||
|                                          (X) == Py_HUGE_VAL || \ | ||||
|                                          (X) == -Py_HUGE_VAL)) | ||||
| #define Py_OVERFLOWED(X) \ | ||||
|   ((X) != 0.0 && (errno == ERANGE || (X) == Py_HUGE_VAL || (X) == -Py_HUGE_VAL)) | ||||
| #endif | ||||
| 
 | ||||
| /* Return whether integral type *type* is signed or not. */ | ||||
| #define _Py_IntegralTypeSigned(type) ((type)(-1) < 0) | ||||
| /* Return the maximum value of integral type *type*. */ | ||||
| #define _Py_IntegralTypeMax(type) ((_Py_IntegralTypeSigned(type)) ? (((((type)1 << (sizeof(type)*CHAR_BIT - 2)) - 1) << 1) + 1) : ~(type)0) | ||||
| #define _Py_IntegralTypeMax(type)                                      \ | ||||
|   ((_Py_IntegralTypeSigned(type))                                      \ | ||||
|        ? (((((type)1 << (sizeof(type) * CHAR_BIT - 2)) - 1) << 1) + 1) \ | ||||
|        : ~(type)0) | ||||
| /* Return the minimum value of integral type *type*. */ | ||||
| #define _Py_IntegralTypeMin(type) ((_Py_IntegralTypeSigned(type)) ? -_Py_IntegralTypeMax(type) - 1 : 0) | ||||
| #define _Py_IntegralTypeMin(type) \ | ||||
|   ((_Py_IntegralTypeSigned(type)) ? -_Py_IntegralTypeMax(type) - 1 : 0) | ||||
| /* Check whether *v* is in the range of integral type *type*. This is most
 | ||||
|  * useful if *v* is floating-point, since demoting a floating-point *v* to an | ||||
|  * integral type that cannot represent *v*'s integral part is undefined | ||||
|  * behavior. */ | ||||
| #define _Py_InIntegralTypeRange(type, v) (_Py_IntegralTypeMin(type) <= v && v <= _Py_IntegralTypeMax(type)) | ||||
| #define _Py_InIntegralTypeRange(type, v) \ | ||||
|   (_Py_IntegralTypeMin(type) <= v && v <= _Py_IntegralTypeMax(type)) | ||||
| 
 | ||||
| #endif /* Py_PYMATH_H */ | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue