github.com/klaytn/klaytn@v1.12.1/crypto/secp256k1/libsecp256k1/src/util.h (about) 1 /********************************************************************** 2 * Copyright (c) 2013, 2014 Pieter Wuille * 3 * Distributed under the MIT software license, see the accompanying * 4 * file COPYING or http://www.opensource.org/licenses/mit-license.php.* 5 **********************************************************************/ 6 7 #ifndef _SECP256K1_UTIL_H_ 8 #define _SECP256K1_UTIL_H_ 9 10 #if defined HAVE_CONFIG_H 11 #include "libsecp256k1-config.h" 12 #endif 13 14 #include <stdlib.h> 15 #include <stdint.h> 16 #include <stdio.h> 17 18 typedef struct { 19 void (*fn)(const char *text, void* data); 20 const void* data; 21 } secp256k1_callback; 22 23 static SECP256K1_INLINE void secp256k1_callback_call(const secp256k1_callback * const cb, const char * const text) { 24 cb->fn(text, (void*)cb->data); 25 } 26 27 #ifdef DETERMINISTIC 28 #define TEST_FAILURE(msg) do { \ 29 fprintf(stderr, "%s\n", msg); \ 30 abort(); \ 31 } while(0); 32 #else 33 #define TEST_FAILURE(msg) do { \ 34 fprintf(stderr, "%s:%d: %s\n", __FILE__, __LINE__, msg); \ 35 abort(); \ 36 } while(0) 37 #endif 38 39 #ifdef HAVE_BUILTIN_EXPECT 40 #define EXPECT(x,c) __builtin_expect((x),(c)) 41 #else 42 #define EXPECT(x,c) (x) 43 #endif 44 45 #ifdef DETERMINISTIC 46 #define CHECK(cond) do { \ 47 if (EXPECT(!(cond), 0)) { \ 48 TEST_FAILURE("test condition failed"); \ 49 } \ 50 } while(0) 51 #else 52 #define CHECK(cond) do { \ 53 if (EXPECT(!(cond), 0)) { \ 54 TEST_FAILURE("test condition failed: " #cond); \ 55 } \ 56 } while(0) 57 #endif 58 59 /* Like assert(), but when VERIFY is defined, and side-effect safe. */ 60 #if defined(COVERAGE) 61 #define VERIFY_CHECK(check) 62 #define VERIFY_SETUP(stmt) 63 #elif defined(VERIFY) 64 #define VERIFY_CHECK CHECK 65 #define VERIFY_SETUP(stmt) do { stmt; } while(0) 66 #else 67 #define VERIFY_CHECK(cond) do { (void)(cond); } while(0) 68 #define VERIFY_SETUP(stmt) 69 #endif 70 71 static SECP256K1_INLINE void *checked_malloc(const secp256k1_callback* cb, size_t size) { 72 void *ret = malloc(size); 73 if (ret == NULL) { 74 secp256k1_callback_call(cb, "Out of memory"); 75 } 76 return ret; 77 } 78 79 /* Macro for restrict, when available and not in a VERIFY build. */ 80 #if defined(SECP256K1_BUILD) && defined(VERIFY) 81 # define SECP256K1_RESTRICT 82 #else 83 # if (!defined(__STDC_VERSION__) || (__STDC_VERSION__ < 199901L) ) 84 # if SECP256K1_GNUC_PREREQ(3,0) 85 # define SECP256K1_RESTRICT __restrict__ 86 # elif (defined(_MSC_VER) && _MSC_VER >= 1400) 87 # define SECP256K1_RESTRICT __restrict 88 # else 89 # define SECP256K1_RESTRICT 90 # endif 91 # else 92 # define SECP256K1_RESTRICT restrict 93 # endif 94 #endif 95 96 #if defined(_WIN32) 97 # define I64FORMAT "I64d" 98 # define I64uFORMAT "I64u" 99 #else 100 # define I64FORMAT "lld" 101 # define I64uFORMAT "llu" 102 #endif 103 104 #if defined(HAVE___INT128) 105 # if defined(__GNUC__) 106 # define SECP256K1_GNUC_EXT __extension__ 107 # else 108 # define SECP256K1_GNUC_EXT 109 # endif 110 SECP256K1_GNUC_EXT typedef unsigned __int128 uint128_t; 111 #endif 112 113 #endif