wolfSSL SSL/TLS library, support up to TLS1.3

Dependents:   CyaSSL-Twitter-OAuth4Tw Example-client-tls-cert TwitterReader TweetTest ... more

Committer:
wolfSSL
Date:
Thu Apr 28 00:57:21 2016 +0000
Revision:
4:1b0d80432c79
wolfSSL 3.9.0

Who changed what in which revision?

UserRevisionLine numberNew contents of line
wolfSSL 4:1b0d80432c79 1 /* types.h
wolfSSL 4:1b0d80432c79 2 *
wolfSSL 4:1b0d80432c79 3 * Copyright (C) 2006-2016 wolfSSL Inc.
wolfSSL 4:1b0d80432c79 4 *
wolfSSL 4:1b0d80432c79 5 * This file is part of wolfSSL.
wolfSSL 4:1b0d80432c79 6 *
wolfSSL 4:1b0d80432c79 7 * wolfSSL is free software; you can redistribute it and/or modify
wolfSSL 4:1b0d80432c79 8 * it under the terms of the GNU General Public License as published by
wolfSSL 4:1b0d80432c79 9 * the Free Software Foundation; either version 2 of the License, or
wolfSSL 4:1b0d80432c79 10 * (at your option) any later version.
wolfSSL 4:1b0d80432c79 11 *
wolfSSL 4:1b0d80432c79 12 * wolfSSL is distributed in the hope that it will be useful,
wolfSSL 4:1b0d80432c79 13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
wolfSSL 4:1b0d80432c79 14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
wolfSSL 4:1b0d80432c79 15 * GNU General Public License for more details.
wolfSSL 4:1b0d80432c79 16 *
wolfSSL 4:1b0d80432c79 17 * You should have received a copy of the GNU General Public License
wolfSSL 4:1b0d80432c79 18 * along with this program; if not, write to the Free Software
wolfSSL 4:1b0d80432c79 19 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1335, USA
wolfSSL 4:1b0d80432c79 20 */
wolfSSL 4:1b0d80432c79 21
wolfSSL 4:1b0d80432c79 22
wolfSSL 4:1b0d80432c79 23
wolfSSL 4:1b0d80432c79 24 #ifndef WOLF_CRYPT_TYPES_H
wolfSSL 4:1b0d80432c79 25 #define WOLF_CRYPT_TYPES_H
wolfSSL 4:1b0d80432c79 26
wolfSSL 4:1b0d80432c79 27 #include <wolfssl/wolfcrypt/settings.h>
wolfSSL 4:1b0d80432c79 28 #include <wolfssl/wolfcrypt/wc_port.h>
wolfSSL 4:1b0d80432c79 29
wolfSSL 4:1b0d80432c79 30 #ifdef __cplusplus
wolfSSL 4:1b0d80432c79 31 extern "C" {
wolfSSL 4:1b0d80432c79 32 #endif
wolfSSL 4:1b0d80432c79 33
wolfSSL 4:1b0d80432c79 34
wolfSSL 4:1b0d80432c79 35 #if defined(WORDS_BIGENDIAN)
wolfSSL 4:1b0d80432c79 36 #define BIG_ENDIAN_ORDER
wolfSSL 4:1b0d80432c79 37 #endif
wolfSSL 4:1b0d80432c79 38
wolfSSL 4:1b0d80432c79 39 #ifndef BIG_ENDIAN_ORDER
wolfSSL 4:1b0d80432c79 40 #define LITTLE_ENDIAN_ORDER
wolfSSL 4:1b0d80432c79 41 #endif
wolfSSL 4:1b0d80432c79 42
wolfSSL 4:1b0d80432c79 43 #ifndef WOLFSSL_TYPES
wolfSSL 4:1b0d80432c79 44 #ifndef byte
wolfSSL 4:1b0d80432c79 45 typedef unsigned char byte;
wolfSSL 4:1b0d80432c79 46 #endif
wolfSSL 4:1b0d80432c79 47 typedef unsigned short word16;
wolfSSL 4:1b0d80432c79 48 typedef unsigned int word32;
wolfSSL 4:1b0d80432c79 49 #endif
wolfSSL 4:1b0d80432c79 50
wolfSSL 4:1b0d80432c79 51
wolfSSL 4:1b0d80432c79 52 /* try to set SIZEOF_LONG or LONG_LONG if user didn't */
wolfSSL 4:1b0d80432c79 53 #if !defined(_MSC_VER) && !defined(__BCPLUSPLUS__)
wolfSSL 4:1b0d80432c79 54 #if !defined(SIZEOF_LONG_LONG) && !defined(SIZEOF_LONG)
wolfSSL 4:1b0d80432c79 55 #if (defined(__alpha__) || defined(__ia64__) || defined(_ARCH_PPC64) \
wolfSSL 4:1b0d80432c79 56 || defined(__mips64) || defined(__x86_64__))
wolfSSL 4:1b0d80432c79 57 /* long should be 64bit */
wolfSSL 4:1b0d80432c79 58 #define SIZEOF_LONG 8
wolfSSL 4:1b0d80432c79 59 #elif defined(__i386__) || defined(__CORTEX_M3__)
wolfSSL 4:1b0d80432c79 60 /* long long should be 64bit */
wolfSSL 4:1b0d80432c79 61 #define SIZEOF_LONG_LONG 8
wolfSSL 4:1b0d80432c79 62 #endif
wolfSSL 4:1b0d80432c79 63 #endif
wolfSSL 4:1b0d80432c79 64 #endif
wolfSSL 4:1b0d80432c79 65
wolfSSL 4:1b0d80432c79 66
wolfSSL 4:1b0d80432c79 67 #if defined(_MSC_VER) || defined(__BCPLUSPLUS__)
wolfSSL 4:1b0d80432c79 68 #define WORD64_AVAILABLE
wolfSSL 4:1b0d80432c79 69 #define W64LIT(x) x##ui64
wolfSSL 4:1b0d80432c79 70 typedef unsigned __int64 word64;
wolfSSL 4:1b0d80432c79 71 #elif defined(SIZEOF_LONG) && SIZEOF_LONG == 8
wolfSSL 4:1b0d80432c79 72 #define WORD64_AVAILABLE
wolfSSL 4:1b0d80432c79 73 #define W64LIT(x) x##LL
wolfSSL 4:1b0d80432c79 74 typedef unsigned long word64;
wolfSSL 4:1b0d80432c79 75 #elif defined(SIZEOF_LONG_LONG) && SIZEOF_LONG_LONG == 8
wolfSSL 4:1b0d80432c79 76 #define WORD64_AVAILABLE
wolfSSL 4:1b0d80432c79 77 #define W64LIT(x) x##LL
wolfSSL 4:1b0d80432c79 78 typedef unsigned long long word64;
wolfSSL 4:1b0d80432c79 79 #elif defined(__SIZEOF_LONG_LONG__) && __SIZEOF_LONG_LONG__ == 8
wolfSSL 4:1b0d80432c79 80 #define WORD64_AVAILABLE
wolfSSL 4:1b0d80432c79 81 #define W64LIT(x) x##LL
wolfSSL 4:1b0d80432c79 82 typedef unsigned long long word64;
wolfSSL 4:1b0d80432c79 83 #else
wolfSSL 4:1b0d80432c79 84 #define MP_16BIT /* for mp_int, mp_word needs to be twice as big as
wolfSSL 4:1b0d80432c79 85 mp_digit, no 64 bit type so make mp_digit 16 bit */
wolfSSL 4:1b0d80432c79 86 #endif
wolfSSL 4:1b0d80432c79 87
wolfSSL 4:1b0d80432c79 88
wolfSSL 4:1b0d80432c79 89 /* These platforms have 64-bit CPU registers. */
wolfSSL 4:1b0d80432c79 90 #if (defined(__alpha__) || defined(__ia64__) || defined(_ARCH_PPC64) || \
wolfSSL 4:1b0d80432c79 91 defined(__mips64) || defined(__x86_64__) || defined(_M_X64))
wolfSSL 4:1b0d80432c79 92 typedef word64 wolfssl_word;
wolfSSL 4:1b0d80432c79 93 #else
wolfSSL 4:1b0d80432c79 94 typedef word32 wolfssl_word;
wolfSSL 4:1b0d80432c79 95 #ifdef WORD64_AVAILABLE
wolfSSL 4:1b0d80432c79 96 #define WOLFCRYPT_SLOW_WORD64
wolfSSL 4:1b0d80432c79 97 #endif
wolfSSL 4:1b0d80432c79 98 #endif
wolfSSL 4:1b0d80432c79 99
wolfSSL 4:1b0d80432c79 100
wolfSSL 4:1b0d80432c79 101 enum {
wolfSSL 4:1b0d80432c79 102 WOLFSSL_WORD_SIZE = sizeof(wolfssl_word),
wolfSSL 4:1b0d80432c79 103 WOLFSSL_BIT_SIZE = 8,
wolfSSL 4:1b0d80432c79 104 WOLFSSL_WORD_BITS = WOLFSSL_WORD_SIZE * WOLFSSL_BIT_SIZE
wolfSSL 4:1b0d80432c79 105 };
wolfSSL 4:1b0d80432c79 106
wolfSSL 4:1b0d80432c79 107 #define WOLFSSL_MAX_16BIT 0xffffU
wolfSSL 4:1b0d80432c79 108
wolfSSL 4:1b0d80432c79 109 /* use inlining if compiler allows */
wolfSSL 4:1b0d80432c79 110 #ifndef INLINE
wolfSSL 4:1b0d80432c79 111 #ifndef NO_INLINE
wolfSSL 4:1b0d80432c79 112 #ifdef _MSC_VER
wolfSSL 4:1b0d80432c79 113 #define INLINE __inline
wolfSSL 4:1b0d80432c79 114 #elif defined(__GNUC__)
wolfSSL 4:1b0d80432c79 115 #ifdef WOLFSSL_VXWORKS
wolfSSL 4:1b0d80432c79 116 #define INLINE __inline__
wolfSSL 4:1b0d80432c79 117 #else
wolfSSL 4:1b0d80432c79 118 #define INLINE inline
wolfSSL 4:1b0d80432c79 119 #endif
wolfSSL 4:1b0d80432c79 120 #elif defined(__IAR_SYSTEMS_ICC__)
wolfSSL 4:1b0d80432c79 121 #define INLINE inline
wolfSSL 4:1b0d80432c79 122 #elif defined(THREADX)
wolfSSL 4:1b0d80432c79 123 #define INLINE _Inline
wolfSSL 4:1b0d80432c79 124 #else
wolfSSL 4:1b0d80432c79 125 #define INLINE
wolfSSL 4:1b0d80432c79 126 #endif
wolfSSL 4:1b0d80432c79 127 #else
wolfSSL 4:1b0d80432c79 128 #define INLINE
wolfSSL 4:1b0d80432c79 129 #endif
wolfSSL 4:1b0d80432c79 130 #endif
wolfSSL 4:1b0d80432c79 131
wolfSSL 4:1b0d80432c79 132
wolfSSL 4:1b0d80432c79 133 /* set up rotate style */
wolfSSL 4:1b0d80432c79 134 #if defined(_MSC_VER) || defined(__BCPLUSPLUS__)
wolfSSL 4:1b0d80432c79 135 #define INTEL_INTRINSICS
wolfSSL 4:1b0d80432c79 136 #define FAST_ROTATE
wolfSSL 4:1b0d80432c79 137 #elif defined(__MWERKS__) && TARGET_CPU_PPC
wolfSSL 4:1b0d80432c79 138 #define PPC_INTRINSICS
wolfSSL 4:1b0d80432c79 139 #define FAST_ROTATE
wolfSSL 4:1b0d80432c79 140 #elif defined(__GNUC__) && defined(__i386__)
wolfSSL 4:1b0d80432c79 141 /* GCC does peephole optimizations which should result in using rotate
wolfSSL 4:1b0d80432c79 142 instructions */
wolfSSL 4:1b0d80432c79 143 #define FAST_ROTATE
wolfSSL 4:1b0d80432c79 144 #endif
wolfSSL 4:1b0d80432c79 145
wolfSSL 4:1b0d80432c79 146
wolfSSL 4:1b0d80432c79 147 /* set up thread local storage if available */
wolfSSL 4:1b0d80432c79 148 #ifdef HAVE_THREAD_LS
wolfSSL 4:1b0d80432c79 149 #if defined(_MSC_VER)
wolfSSL 4:1b0d80432c79 150 #define THREAD_LS_T __declspec(thread)
wolfSSL 4:1b0d80432c79 151 /* Thread local storage only in FreeRTOS v8.2.1 and higher */
wolfSSL 4:1b0d80432c79 152 #elif defined(FREERTOS)
wolfSSL 4:1b0d80432c79 153 #define THREAD_LS_T
wolfSSL 4:1b0d80432c79 154 #else
wolfSSL 4:1b0d80432c79 155 #define THREAD_LS_T __thread
wolfSSL 4:1b0d80432c79 156 #endif
wolfSSL 4:1b0d80432c79 157 #else
wolfSSL 4:1b0d80432c79 158 #define THREAD_LS_T
wolfSSL 4:1b0d80432c79 159 #endif
wolfSSL 4:1b0d80432c79 160
wolfSSL 4:1b0d80432c79 161
wolfSSL 4:1b0d80432c79 162 /* Micrium will use Visual Studio for compilation but not the Win32 API */
wolfSSL 4:1b0d80432c79 163 #if defined(_WIN32) && !defined(MICRIUM) && !defined(FREERTOS) && !defined(FREERTOS_TCP) \
wolfSSL 4:1b0d80432c79 164 && !defined(EBSNET)
wolfSSL 4:1b0d80432c79 165 #define USE_WINDOWS_API
wolfSSL 4:1b0d80432c79 166 #endif
wolfSSL 4:1b0d80432c79 167
wolfSSL 4:1b0d80432c79 168
wolfSSL 4:1b0d80432c79 169 /* idea to add global alloc override by Moises Guimaraes */
wolfSSL 4:1b0d80432c79 170 /* default to libc stuff */
wolfSSL 4:1b0d80432c79 171 /* XREALLOC is used once in normal math lib, not in fast math lib */
wolfSSL 4:1b0d80432c79 172 /* XFREE on some embeded systems doesn't like free(0) so test */
wolfSSL 4:1b0d80432c79 173 #if defined(XMALLOC_USER)
wolfSSL 4:1b0d80432c79 174 /* prototypes for user heap override functions */
wolfSSL 4:1b0d80432c79 175 #include <stddef.h> /* for size_t */
wolfSSL 4:1b0d80432c79 176 extern void *XMALLOC(size_t n, void* heap, int type);
wolfSSL 4:1b0d80432c79 177 extern void *XREALLOC(void *p, size_t n, void* heap, int type);
wolfSSL 4:1b0d80432c79 178 extern void XFREE(void *p, void* heap, int type);
wolfSSL 4:1b0d80432c79 179 #elif defined(NO_WOLFSSL_MEMORY)
wolfSSL 4:1b0d80432c79 180 /* just use plain C stdlib stuff if desired */
wolfSSL 4:1b0d80432c79 181 #include <stdlib.h>
wolfSSL 4:1b0d80432c79 182 #define XMALLOC(s, h, t) ((void)h, (void)t, malloc((s)))
wolfSSL 4:1b0d80432c79 183 #define XFREE(p, h, t) {void* xp = (p); if((xp)) free((xp));}
wolfSSL 4:1b0d80432c79 184 #define XREALLOC(p, n, h, t) realloc((p), (n))
wolfSSL 4:1b0d80432c79 185 #elif !defined(MICRIUM_MALLOC) && !defined(EBSNET) \
wolfSSL 4:1b0d80432c79 186 && !defined(WOLFSSL_SAFERTOS) && !defined(FREESCALE_MQX) \
wolfSSL 4:1b0d80432c79 187 && !defined(FREESCALE_KSDK_MQX) && !defined(FREESCALE_FREE_RTOS) \
wolfSSL 4:1b0d80432c79 188 && !defined(WOLFSSL_LEANPSK) && !defined(FREERTOS) && !defined(FREERTOS_TCP)\
wolfSSL 4:1b0d80432c79 189 && !defined(WOLFSSL_uITRON4) && !defined(WOLFSSL_uTKERNEL2)
wolfSSL 4:1b0d80432c79 190 /* default C runtime, can install different routines at runtime via cbs */
wolfSSL 4:1b0d80432c79 191 #include <wolfssl/wolfcrypt/memory.h>
wolfSSL 4:1b0d80432c79 192 #define XMALLOC(s, h, t) ((void)h, (void)t, wolfSSL_Malloc((s)))
wolfSSL 4:1b0d80432c79 193 #define XFREE(p, h, t) {void* xp = (p); if((xp)) wolfSSL_Free((xp));}
wolfSSL 4:1b0d80432c79 194 #define XREALLOC(p, n, h, t) wolfSSL_Realloc((p), (n))
wolfSSL 4:1b0d80432c79 195 #endif
wolfSSL 4:1b0d80432c79 196
wolfSSL 4:1b0d80432c79 197 #ifndef STRING_USER
wolfSSL 4:1b0d80432c79 198 #include <string.h>
wolfSSL 4:1b0d80432c79 199 char* mystrnstr(const char* s1, const char* s2, unsigned int n);
wolfSSL 4:1b0d80432c79 200
wolfSSL 4:1b0d80432c79 201 #define XMEMCPY(d,s,l) memcpy((d),(s),(l))
wolfSSL 4:1b0d80432c79 202 #define XMEMSET(b,c,l) memset((b),(c),(l))
wolfSSL 4:1b0d80432c79 203 #define XMEMCMP(s1,s2,n) memcmp((s1),(s2),(n))
wolfSSL 4:1b0d80432c79 204 #define XMEMMOVE(d,s,l) memmove((d),(s),(l))
wolfSSL 4:1b0d80432c79 205
wolfSSL 4:1b0d80432c79 206 #define XSTRLEN(s1) strlen((s1))
wolfSSL 4:1b0d80432c79 207 #define XSTRNCPY(s1,s2,n) strncpy((s1),(s2),(n))
wolfSSL 4:1b0d80432c79 208 /* strstr, strncmp, and strncat only used by wolfSSL proper,
wolfSSL 4:1b0d80432c79 209 * not required for wolfCrypt only */
wolfSSL 4:1b0d80432c79 210 #define XSTRSTR(s1,s2) strstr((s1),(s2))
wolfSSL 4:1b0d80432c79 211 #define XSTRNSTR(s1,s2,n) mystrnstr((s1),(s2),(n))
wolfSSL 4:1b0d80432c79 212 #define XSTRNCMP(s1,s2,n) strncmp((s1),(s2),(n))
wolfSSL 4:1b0d80432c79 213 #define XSTRNCAT(s1,s2,n) strncat((s1),(s2),(n))
wolfSSL 4:1b0d80432c79 214 #ifndef USE_WINDOWS_API
wolfSSL 4:1b0d80432c79 215 #define XSTRNCASECMP(s1,s2,n) strncasecmp((s1),(s2),(n))
wolfSSL 4:1b0d80432c79 216 #else
wolfSSL 4:1b0d80432c79 217 #define XSTRNCASECMP(s1,s2,n) _strnicmp((s1),(s2),(n))
wolfSSL 4:1b0d80432c79 218 #endif
wolfSSL 4:1b0d80432c79 219
wolfSSL 4:1b0d80432c79 220 #if defined(WOLFSSL_CERT_EXT) || defined(HAVE_ALPN)
wolfSSL 4:1b0d80432c79 221 /* use only Thread Safe version of strtok */
wolfSSL 4:1b0d80432c79 222 #ifndef USE_WINDOWS_API
wolfSSL 4:1b0d80432c79 223 #define XSTRTOK strtok_r
wolfSSL 4:1b0d80432c79 224 #else
wolfSSL 4:1b0d80432c79 225 #define XSTRTOK strtok_s
wolfSSL 4:1b0d80432c79 226 #endif
wolfSSL 4:1b0d80432c79 227 #endif
wolfSSL 4:1b0d80432c79 228 #endif
wolfSSL 4:1b0d80432c79 229
wolfSSL 4:1b0d80432c79 230 #ifndef CTYPE_USER
wolfSSL 4:1b0d80432c79 231 #include <ctype.h>
wolfSSL 4:1b0d80432c79 232 #if defined(HAVE_ECC) || defined(HAVE_OCSP) || defined(WOLFSSL_KEY_GEN)
wolfSSL 4:1b0d80432c79 233 #define XTOUPPER(c) toupper((c))
wolfSSL 4:1b0d80432c79 234 #define XISALPHA(c) isalpha((c))
wolfSSL 4:1b0d80432c79 235 #endif
wolfSSL 4:1b0d80432c79 236 /* needed by wolfSSL_check_domain_name() */
wolfSSL 4:1b0d80432c79 237 #define XTOLOWER(c) tolower((c))
wolfSSL 4:1b0d80432c79 238 #endif
wolfSSL 4:1b0d80432c79 239
wolfSSL 4:1b0d80432c79 240
wolfSSL 4:1b0d80432c79 241 /* memory allocation types for user hints */
wolfSSL 4:1b0d80432c79 242 enum {
wolfSSL 4:1b0d80432c79 243 DYNAMIC_TYPE_CA = 1,
wolfSSL 4:1b0d80432c79 244 DYNAMIC_TYPE_CERT = 2,
wolfSSL 4:1b0d80432c79 245 DYNAMIC_TYPE_KEY = 3,
wolfSSL 4:1b0d80432c79 246 DYNAMIC_TYPE_FILE = 4,
wolfSSL 4:1b0d80432c79 247 DYNAMIC_TYPE_SUBJECT_CN = 5,
wolfSSL 4:1b0d80432c79 248 DYNAMIC_TYPE_PUBLIC_KEY = 6,
wolfSSL 4:1b0d80432c79 249 DYNAMIC_TYPE_SIGNER = 7,
wolfSSL 4:1b0d80432c79 250 DYNAMIC_TYPE_NONE = 8,
wolfSSL 4:1b0d80432c79 251 DYNAMIC_TYPE_BIGINT = 9,
wolfSSL 4:1b0d80432c79 252 DYNAMIC_TYPE_RSA = 10,
wolfSSL 4:1b0d80432c79 253 DYNAMIC_TYPE_METHOD = 11,
wolfSSL 4:1b0d80432c79 254 DYNAMIC_TYPE_OUT_BUFFER = 12,
wolfSSL 4:1b0d80432c79 255 DYNAMIC_TYPE_IN_BUFFER = 13,
wolfSSL 4:1b0d80432c79 256 DYNAMIC_TYPE_INFO = 14,
wolfSSL 4:1b0d80432c79 257 DYNAMIC_TYPE_DH = 15,
wolfSSL 4:1b0d80432c79 258 DYNAMIC_TYPE_DOMAIN = 16,
wolfSSL 4:1b0d80432c79 259 DYNAMIC_TYPE_SSL = 17,
wolfSSL 4:1b0d80432c79 260 DYNAMIC_TYPE_CTX = 18,
wolfSSL 4:1b0d80432c79 261 DYNAMIC_TYPE_WRITEV = 19,
wolfSSL 4:1b0d80432c79 262 DYNAMIC_TYPE_OPENSSL = 20,
wolfSSL 4:1b0d80432c79 263 DYNAMIC_TYPE_DSA = 21,
wolfSSL 4:1b0d80432c79 264 DYNAMIC_TYPE_CRL = 22,
wolfSSL 4:1b0d80432c79 265 DYNAMIC_TYPE_REVOKED = 23,
wolfSSL 4:1b0d80432c79 266 DYNAMIC_TYPE_CRL_ENTRY = 24,
wolfSSL 4:1b0d80432c79 267 DYNAMIC_TYPE_CERT_MANAGER = 25,
wolfSSL 4:1b0d80432c79 268 DYNAMIC_TYPE_CRL_MONITOR = 26,
wolfSSL 4:1b0d80432c79 269 DYNAMIC_TYPE_OCSP_STATUS = 27,
wolfSSL 4:1b0d80432c79 270 DYNAMIC_TYPE_OCSP_ENTRY = 28,
wolfSSL 4:1b0d80432c79 271 DYNAMIC_TYPE_ALTNAME = 29,
wolfSSL 4:1b0d80432c79 272 DYNAMIC_TYPE_SUITES = 30,
wolfSSL 4:1b0d80432c79 273 DYNAMIC_TYPE_CIPHER = 31,
wolfSSL 4:1b0d80432c79 274 DYNAMIC_TYPE_RNG = 32,
wolfSSL 4:1b0d80432c79 275 DYNAMIC_TYPE_ARRAYS = 33,
wolfSSL 4:1b0d80432c79 276 DYNAMIC_TYPE_DTLS_POOL = 34,
wolfSSL 4:1b0d80432c79 277 DYNAMIC_TYPE_SOCKADDR = 35,
wolfSSL 4:1b0d80432c79 278 DYNAMIC_TYPE_LIBZ = 36,
wolfSSL 4:1b0d80432c79 279 DYNAMIC_TYPE_ECC = 37,
wolfSSL 4:1b0d80432c79 280 DYNAMIC_TYPE_TMP_BUFFER = 38,
wolfSSL 4:1b0d80432c79 281 DYNAMIC_TYPE_DTLS_MSG = 39,
wolfSSL 4:1b0d80432c79 282 DYNAMIC_TYPE_CAVIUM_TMP = 40,
wolfSSL 4:1b0d80432c79 283 DYNAMIC_TYPE_CAVIUM_RSA = 41,
wolfSSL 4:1b0d80432c79 284 DYNAMIC_TYPE_X509 = 42,
wolfSSL 4:1b0d80432c79 285 DYNAMIC_TYPE_TLSX = 43,
wolfSSL 4:1b0d80432c79 286 DYNAMIC_TYPE_OCSP = 44,
wolfSSL 4:1b0d80432c79 287 DYNAMIC_TYPE_SIGNATURE = 45,
wolfSSL 4:1b0d80432c79 288 DYNAMIC_TYPE_HASHES = 46,
wolfSSL 4:1b0d80432c79 289 DYNAMIC_TYPE_SRP = 47,
wolfSSL 4:1b0d80432c79 290 DYNAMIC_TYPE_COOKIE_PWD = 48,
wolfSSL 4:1b0d80432c79 291 DYNAMIC_TYPE_USER_CRYPTO = 49,
wolfSSL 4:1b0d80432c79 292 DYNAMIC_TYPE_OCSP_REQUEST = 50,
wolfSSL 4:1b0d80432c79 293 DYNAMIC_TYPE_X509_EXT = 51,
wolfSSL 4:1b0d80432c79 294 DYNAMIC_TYPE_X509_STORE = 52,
wolfSSL 4:1b0d80432c79 295 DYNAMIC_TYPE_X509_CTX = 53,
wolfSSL 4:1b0d80432c79 296 DYNAMIC_TYPE_URL = 54,
wolfSSL 4:1b0d80432c79 297 DYNAMIC_TYPE_DTLS_FRAG = 55,
wolfSSL 4:1b0d80432c79 298 DYNAMIC_TYPE_DTLS_BUFFER = 56
wolfSSL 4:1b0d80432c79 299 };
wolfSSL 4:1b0d80432c79 300
wolfSSL 4:1b0d80432c79 301 /* max error buffer string size */
wolfSSL 4:1b0d80432c79 302 enum {
wolfSSL 4:1b0d80432c79 303 WOLFSSL_MAX_ERROR_SZ = 80
wolfSSL 4:1b0d80432c79 304 };
wolfSSL 4:1b0d80432c79 305
wolfSSL 4:1b0d80432c79 306 /* stack protection */
wolfSSL 4:1b0d80432c79 307 enum {
wolfSSL 4:1b0d80432c79 308 MIN_STACK_BUFFER = 8
wolfSSL 4:1b0d80432c79 309 };
wolfSSL 4:1b0d80432c79 310
wolfSSL 4:1b0d80432c79 311
wolfSSL 4:1b0d80432c79 312
wolfSSL 4:1b0d80432c79 313 /* settings detection for compile vs runtime math incompatibilities */
wolfSSL 4:1b0d80432c79 314 enum {
wolfSSL 4:1b0d80432c79 315 #if !defined(USE_FAST_MATH) && !defined(SIZEOF_LONG) && !defined(SIZEOF_LONG_LONG)
wolfSSL 4:1b0d80432c79 316 CTC_SETTINGS = 0x0
wolfSSL 4:1b0d80432c79 317 #elif !defined(USE_FAST_MATH) && defined(SIZEOF_LONG) && (SIZEOF_LONG == 8)
wolfSSL 4:1b0d80432c79 318 CTC_SETTINGS = 0x1
wolfSSL 4:1b0d80432c79 319 #elif !defined(USE_FAST_MATH) && defined(SIZEOF_LONG_LONG) && (SIZEOF_LONG_LONG == 8)
wolfSSL 4:1b0d80432c79 320 CTC_SETTINGS = 0x2
wolfSSL 4:1b0d80432c79 321 #elif !defined(USE_FAST_MATH) && defined(SIZEOF_LONG_LONG) && (SIZEOF_LONG_LONG == 4)
wolfSSL 4:1b0d80432c79 322 CTC_SETTINGS = 0x4
wolfSSL 4:1b0d80432c79 323 #elif defined(USE_FAST_MATH) && !defined(SIZEOF_LONG) && !defined(SIZEOF_LONG_LONG)
wolfSSL 4:1b0d80432c79 324 CTC_SETTINGS = 0x8
wolfSSL 4:1b0d80432c79 325 #elif defined(USE_FAST_MATH) && defined(SIZEOF_LONG) && (SIZEOF_LONG == 8)
wolfSSL 4:1b0d80432c79 326 CTC_SETTINGS = 0x10
wolfSSL 4:1b0d80432c79 327 #elif defined(USE_FAST_MATH) && defined(SIZEOF_LONG_LONG) && (SIZEOF_LONG_LONG == 8)
wolfSSL 4:1b0d80432c79 328 CTC_SETTINGS = 0x20
wolfSSL 4:1b0d80432c79 329 #elif defined(USE_FAST_MATH) && defined(SIZEOF_LONG_LONG) && (SIZEOF_LONG_LONG == 4)
wolfSSL 4:1b0d80432c79 330 CTC_SETTINGS = 0x40
wolfSSL 4:1b0d80432c79 331 #else
wolfSSL 4:1b0d80432c79 332 #error "bad math long / long long settings"
wolfSSL 4:1b0d80432c79 333 #endif
wolfSSL 4:1b0d80432c79 334 };
wolfSSL 4:1b0d80432c79 335
wolfSSL 4:1b0d80432c79 336
wolfSSL 4:1b0d80432c79 337 WOLFSSL_API word32 CheckRunTimeSettings(void);
wolfSSL 4:1b0d80432c79 338
wolfSSL 4:1b0d80432c79 339 /* If user uses RSA, DH, DSA, or ECC math lib directly then fast math and long
wolfSSL 4:1b0d80432c79 340 types need to match at compile time and run time, CheckCtcSettings will
wolfSSL 4:1b0d80432c79 341 return 1 if a match otherwise 0 */
wolfSSL 4:1b0d80432c79 342 #define CheckCtcSettings() (CTC_SETTINGS == CheckRunTimeSettings())
wolfSSL 4:1b0d80432c79 343
wolfSSL 4:1b0d80432c79 344
wolfSSL 4:1b0d80432c79 345 #ifdef __cplusplus
wolfSSL 4:1b0d80432c79 346 } /* extern "C" */
wolfSSL 4:1b0d80432c79 347 #endif
wolfSSL 4:1b0d80432c79 348
wolfSSL 4:1b0d80432c79 349 #endif /* WOLF_CRYPT_TYPES_H */
wolfSSL 4:1b0d80432c79 350