switch to 64-bit compilation; add flag for 32-bit
This commit is contained in:
		
							parent
							
								
									2c18a16858
								
							
						
					
					
						commit
						5a27abab52
					
				|  | @ -3,6 +3,7 @@ | ||||||
| 
 | 
 | ||||||
| * Update `rand` to 0.4 and `gcc` 0.3 to `cc` 1.0. (`rand` 0.5 exists but has a lot of breaking changes and no longer compiles with 1.14.0.) | * Update `rand` to 0.4 and `gcc` 0.3 to `cc` 1.0. (`rand` 0.5 exists but has a lot of breaking changes and no longer compiles with 1.14.0.) | ||||||
| * Remove `PublicKey::combine` from API since it cannot be used with anything else in the API | * Remove `PublicKey::combine` from API since it cannot be used with anything else in the API | ||||||
|  | * Detect whether 64-bit compilation is possible, and do it if we can (big performance improvement) | ||||||
| 
 | 
 | ||||||
| # 0.10.0 - 2018-07-25 | # 0.10.0 - 2018-07-25 | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
							
								
								
									
										26
									
								
								build.rs
								
								
								
								
							
							
						
						
									
										26
									
								
								build.rs
								
								
								
								
							|  | @ -24,6 +24,19 @@ | ||||||
| extern crate cc; | extern crate cc; | ||||||
| 
 | 
 | ||||||
| fn main() { | fn main() { | ||||||
|  |     // Check whether we can use 64-bit compilation
 | ||||||
|  |     #[cfg(target_pointer_width = "64")] | ||||||
|  |     let use_64bit_compilation = { | ||||||
|  |         cc::Build::new().file("depend/check_uint128_t.c") | ||||||
|  |                         .cargo_metadata(false) | ||||||
|  |                         .try_compile("check_uint128_t") | ||||||
|  |                         .is_ok() | ||||||
|  |     }; | ||||||
|  |     #[cfg(not(target_pointer_width = "64"))] | ||||||
|  |     let use_64bit_compilation = false; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |     // Actual build
 | ||||||
|     let mut base_config = cc::Build::new(); |     let mut base_config = cc::Build::new(); | ||||||
|     base_config.include("depend/secp256k1/") |     base_config.include("depend/secp256k1/") | ||||||
|                .include("depend/secp256k1/include") |                .include("depend/secp256k1/include") | ||||||
|  | @ -35,14 +48,19 @@ fn main() { | ||||||
|                .define("USE_NUM_NONE", Some("1")) |                .define("USE_NUM_NONE", Some("1")) | ||||||
|                .define("USE_FIELD_INV_BUILTIN", Some("1")) |                .define("USE_FIELD_INV_BUILTIN", Some("1")) | ||||||
|                .define("USE_SCALAR_INV_BUILTIN", Some("1")) |                .define("USE_SCALAR_INV_BUILTIN", Some("1")) | ||||||
|                // TODO these should use 64-bit variants on 64-bit systems
 |  | ||||||
|                .define("USE_FIELD_10X26", Some("1")) |  | ||||||
|                .define("USE_SCALAR_8X32", Some("1")) |  | ||||||
|                .define("USE_ENDOMORPHISM", Some("1")) |                .define("USE_ENDOMORPHISM", Some("1")) | ||||||
|                // These all are OK.
 |  | ||||||
|                .define("ENABLE_MODULE_ECDH", Some("1")) |                .define("ENABLE_MODULE_ECDH", Some("1")) | ||||||
|                .define("ENABLE_MODULE_RECOVERY", Some("1")); |                .define("ENABLE_MODULE_RECOVERY", Some("1")); | ||||||
| 
 | 
 | ||||||
|  |     if use_64bit_compilation { | ||||||
|  |         base_config.define("USE_FIELD_5X52", Some("1")) | ||||||
|  |                    .define("USE_SCALAR_4X64", Some("1")) | ||||||
|  |                    .define("HAVE___INT128", Some("1")); | ||||||
|  |     } else { | ||||||
|  |         base_config.define("USE_FIELD_10X26", Some("1")) | ||||||
|  |                    .define("USE_SCALAR_8X32", Some("1")); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     // secp256k1
 |     // secp256k1
 | ||||||
|     base_config.file("depend/secp256k1/contrib/lax_der_parsing.c") |     base_config.file("depend/secp256k1/contrib/lax_der_parsing.c") | ||||||
|                .file("depend/secp256k1/src/secp256k1.c") |                .file("depend/secp256k1/src/secp256k1.c") | ||||||
|  |  | ||||||
|  | @ -0,0 +1,16 @@ | ||||||
|  | 
 | ||||||
|  | #include <stdint.h> | ||||||
|  | 
 | ||||||
|  | int main(void) { | ||||||
|  |     __uint128_t var_128; | ||||||
|  |     uint64_t var_64; | ||||||
|  | 
 | ||||||
|  |     /* Try to shut up "unused variable" warnings */ | ||||||
|  |     var_64 = 100; | ||||||
|  |     var_128 = 100; | ||||||
|  |     if (var_64 == var_128) { | ||||||
|  |         var_64 = 20; | ||||||
|  |     } | ||||||
|  |     return 0; | ||||||
|  | } | ||||||
|  | 
 | ||||||
		Loading…
	
		Reference in New Issue