6 #ifndef CRYPTOPP_CONFIG_H 7 #define CRYPTOPP_CONFIG_H 13 #if !defined(CRYPTOPP_LITTLE_ENDIAN) && !defined(CRYPTOPP_BIG_ENDIAN) && (defined(__BIG_ENDIAN__) || (defined(__s390__) || defined(__s390x__) || defined(__zarch__)) || (defined(__m68k__) || defined(__MC68K__)) || defined(__sparc) || defined(__sparc__) || defined(__hppa__) || defined(__MIPSEB__) || defined(__ARMEB__) || (defined(__MWERKS__) && !defined(__INTEL__))) 14 # define CRYPTOPP_BIG_ENDIAN 1 19 #if !defined(CRYPTOPP_BIG_ENDIAN) && !defined(CRYPTOPP_LITTLE_ENDIAN) 20 # define CRYPTOPP_LITTLE_ENDIAN 1 25 #if (CRYPTOPP_BIG_ENDIAN) && defined(__GNUC__) && defined(__BYTE_ORDER__) && (__BYTE_ORDER__ != __ORDER_BIG_ENDIAN__) 26 # error "(CRYPTOPP_BIG_ENDIAN) is set, but __BYTE_ORDER__ is not __ORDER_BIG_ENDIAN__" 28 #if (CRYPTOPP_LITTLE_ENDIAN) && defined(__GNUC__) && defined(__BYTE_ORDER__) && (__BYTE_ORDER__ != __ORDER_LITTLE_ENDIAN__) 29 # error "(CRYPTOPP_LITTLE_ENDIAN) is set, but __BYTE_ORDER__ is not __ORDER_LITTLE_ENDIAN__" 50 #if !defined(USE_MS_CRYPTOAPI) && !defined(USE_MS_CNGAPI) 51 # if !defined(_USING_V110_SDK71_) && ((WINVER >= 0x0602 ) || (_WIN32_WINNT >= 0x0602 )) 52 # define USE_MS_CNGAPI 54 # define USE_MS_CRYPTOAPI 67 #if defined(__native_client__) 68 # define CRYPTOPP_DISABLE_ASM 1 95 #define CRYPTOPP_VERSION 700 102 #ifndef CRYPTOPP_DATA_DIR 103 # define CRYPTOPP_DATA_DIR "" 123 #if !defined(GZIP_OS_CODE) 124 # if defined(__macintosh__) 125 # define GZIP_OS_CODE 7 126 # elif defined(__unix__) || defined(__linux__) 127 # define GZIP_OS_CODE 3 129 # define GZIP_OS_CODE 0 154 #define CRYPTOPP_SLOW_ARMV8_SHIFT 1 164 #define CRYPTOPP_RIJNDAEL_NAME "AES" 172 #if (defined(DEBUG) || defined(_DEBUG)) && !defined(CRYPTOPP_DEBUG) 173 # define CRYPTOPP_DEBUG 1 181 # error namespace support is now required 184 #ifdef CRYPTOPP_DOXYGEN_PROCESSING 199 # define CRYPTOPP_ENABLE_NAMESPACE_WEAK 1 203 # define NAMESPACE_BEGIN(x) 204 # define NAMESPACE_END 206 # define DOCUMENTED_TYPEDEF(x, y) class y : public x {}; 208 # define protected private 210 # define NAMESPACE_BEGIN(x) namespace x { 211 # define NAMESPACE_END } 212 # define DOCUMENTED_TYPEDEF(x, y) typedef x y; 214 #define ANONYMOUS_NAMESPACE_BEGIN namespace { 215 #define ANONYMOUS_NAMESPACE_END } 216 #define USING_NAMESPACE(x) using namespace x; 217 #define DOCUMENTED_NAMESPACE_BEGIN(x) namespace x { 218 #define DOCUMENTED_NAMESPACE_END } 224 #define CRYPTOPP_NO_GLOBAL_BYTE 1 231 typedef unsigned char byte;
232 typedef unsigned short word16;
233 typedef unsigned int word32;
235 typedef signed char sbyte;
236 typedef signed short sword16;
237 typedef signed int sword32;
239 #if defined(_MSC_VER) || defined(__BORLANDC__) 240 typedef signed __int64 sword64;
241 typedef unsigned __int64 word64;
242 #define SW64LIT(x) x##i64 243 #define W64LIT(x) x##ui64 244 #elif (_LP64 || __LP64__) 245 typedef signed long sword64;
246 typedef unsigned long word64;
247 #define SW64LIT(x) x##L 248 #define W64LIT(x) x##UL 250 typedef signed long long sword64;
251 typedef unsigned long long word64;
252 #define SW64LIT(x) x##LL 253 #define W64LIT(x) x##ULL 257 typedef word64 lword;
258 const lword LWORD_MAX = W64LIT(0xffffffffffffffff);
266 #if (defined(_MSC_VER) && defined(__clang__)) 267 # error: "Unsupported configuration" 271 #define CRYPTOPP_GCC_VERSION (__GNUC__ * 10000 + __GNUC_MINOR__ * 100 + __GNUC_PATCHLEVEL__) 274 #if defined(__xlc__) || defined(__xlC__) 275 #define CRYPTOPP_XLC_VERSION ((__xlC__ / 256) * 10000 + (__xlC__ % 256) * 100) 279 #if defined(__clang__) && defined(__apple_build_version__) 280 #define CRYPTOPP_APPLE_CLANG_VERSION (__clang_major__ * 10000 + __clang_minor__ * 100 + __clang_patchlevel__) 281 #elif defined(__clang__) 282 #define CRYPTOPP_LLVM_CLANG_VERSION (__clang_major__ * 10000 + __clang_minor__ * 100 + __clang_patchlevel__) 286 #define CRYPTOPP_MSC_VERSION (_MSC_VER) 290 #if (CRYPTOPP_GCC_VERSION >= 40600) || (CRYPTOPP_LLVM_CLANG_VERSION >= 10700) || (CRYPTOPP_APPLE_CLANG_VERSION >= 20000) 291 #define CRYPTOPP_GCC_DIAGNOSTIC_AVAILABLE 1 302 #if (defined(_MSC_VER) && (!defined(__INTEL_COMPILER) || __INTEL_COMPILER >= 1000) && (defined(_M_X64) || defined(_M_IA64))) || (defined(__DECCXX) && defined(__alpha__)) || (defined(__INTEL_COMPILER) && defined(__x86_64__)) || (defined(__SUNPRO_CC) && defined(__x86_64__)) 303 typedef word32 hword;
306 #define CRYPTOPP_NATIVE_DWORD_AVAILABLE 1 307 #if defined(__alpha__) || defined(__ia64__) || defined(_ARCH_PPC64) || defined(__x86_64__) || defined(__mips64) || defined(__sparc64__) 308 #if ((CRYPTOPP_GCC_VERSION >= 30400) || (CRYPTOPP_LLVM_CLANG_VERSION >= 30000) || (CRYPTOPP_APPLE_CLANG_VERSION >= 40300)) && (__SIZEOF_INT128__ >= 16) 312 typedef word32 hword;
314 typedef __uint128_t dword;
315 typedef __uint128_t word128;
316 #define CRYPTOPP_WORD128_AVAILABLE 1 319 typedef word16 hword;
321 typedef word64 dword;
325 #define CRYPTOPP_BOOL_SLOW_WORD64 1 326 typedef word16 hword;
328 typedef word64 dword;
331 #ifndef CRYPTOPP_BOOL_SLOW_WORD64 332 #define CRYPTOPP_BOOL_SLOW_WORD64 0 335 const unsigned int WORD_SIZE =
sizeof(word);
336 const unsigned int WORD_BITS = WORD_SIZE * 8;
340 #ifndef CRYPTOPP_L1_CACHE_LINE_SIZE 343 #if defined(_M_X64) || defined(__x86_64__) || defined(__arm64__) || defined(__aarch64__) || defined(__powerpc64__) || defined(_ARCH_PPC64) 344 #define CRYPTOPP_L1_CACHE_LINE_SIZE 64 347 #define CRYPTOPP_L1_CACHE_LINE_SIZE 32 355 #ifndef CRYPTOPP_ALIGN_DATA 356 #if defined(_MSC_VER) 357 #define CRYPTOPP_ALIGN_DATA(x) __declspec(align(x)) 358 #elif defined(__GNUC__) || (__SUNPRO_CC >= 0x5100) 359 #define CRYPTOPP_ALIGN_DATA(x) __attribute__((aligned(x))) 360 #elif defined(__xlc__) || defined(__xlC__) 361 #define CRYPTOPP_ALIGN_DATA(x) __attribute__((aligned(x))) 363 #define CRYPTOPP_ALIGN_DATA(x) 368 #if ((defined(__MACH__) && defined(__APPLE__)) && ((CRYPTOPP_LLVM_CLANG_VERSION >= 30600) || (CRYPTOPP_APPLE_CLANG_VERSION >= 70100) || (CRYPTOPP_GCC_VERSION >= 40300))) 369 #define CRYPTOPP_SECTION_INIT __attribute__((section ("__DATA,__data"))) 370 #elif (defined(__ELF__) && (CRYPTOPP_GCC_VERSION >= 40300)) 371 #define CRYPTOPP_SECTION_INIT __attribute__((section ("nocommon"))) 372 #elif defined(__ELF__) && (defined(__xlC__) || defined(__ibmxl__)) 373 #define CRYPTOPP_SECTION_INIT __attribute__((section ("nocommon"))) 375 #define CRYPTOPP_SECTION_INIT 378 #if defined(_MSC_VER) || defined(__fastcall) 379 #define CRYPTOPP_FASTCALL __fastcall 381 #define CRYPTOPP_FASTCALL 385 #define CRYPTOPP_NO_VTABLE __declspec(novtable) 387 #define CRYPTOPP_NO_VTABLE 395 # pragma warning(disable: 4127 4512 4661 4910) 398 # pragma warning(once: 4191 4242 4263 4264 4266 4302 4826 4905 4906 4928) 407 #if CRYPTOPP_GCC_DIAGNOSTIC_AVAILABLE 408 # pragma GCC diagnostic ignored "-Wunknown-pragmas" 409 # pragma GCC diagnostic ignored "-Wunused-function" 415 #if (defined(_MSC_VER) && _MSC_VER <= 1300) || defined(__MWERKS__) || (defined(_STLPORT_VERSION) && ((_STLPORT_VERSION < 0x450) || defined(_STLP_NO_UNCAUGHT_EXCEPT_SUPPORT))) 416 #define CRYPTOPP_DISABLE_UNCAUGHT_EXCEPTION 419 #ifndef CRYPTOPP_DISABLE_UNCAUGHT_EXCEPTION 420 #define CRYPTOPP_UNCAUGHT_EXCEPTION_AVAILABLE 430 #if (defined(__ILP32__) || defined(_ILP32)) && defined(__x86_64__) 431 #define CRYPTOPP_BOOL_X32 1 435 #if (defined(_M_IX86) || defined(__i386__) || defined(__i386) || defined(_X86_) || defined(__I86__) || defined(__INTEL__)) && !CRYPTOPP_BOOL_X32 436 #define CRYPTOPP_BOOL_X86 1 439 #if (defined(_M_X64) || defined(__x86_64__)) && !CRYPTOPP_BOOL_X32 440 #define CRYPTOPP_BOOL_X64 1 444 #if CRYPTOPP_BOOL_X32 445 # undef CRYPTOPP_BOOL_X64 446 # undef CRYPTOPP_X64_ASM_AVAILABLE 447 # undef CRYPTOPP_X64_MASM_AVAILABLE 451 #if defined(__arm64__) || defined(__aarch32__) || defined(__aarch64__) || defined(_M_ARM64) 452 #define CRYPTOPP_BOOL_ARMV8 1 453 #elif defined(__arm__) || defined(_M_ARM) 454 #define CRYPTOPP_BOOL_ARM32 1 458 #if defined(__ppc64__) || defined(__powerpc64__) || defined(_ARCH_PPC64) 459 #define CRYPTOPP_BOOL_PPC64 1 460 #elif defined(__powerpc__) || defined(_ARCH_PPC) 461 #define CRYPTOPP_BOOL_PPC32 1 465 #if defined(__mips64__) 466 #define CRYPTOPP_BOOL_MIPS64 1 467 #elif defined(__mips__) 468 #define CRYPTOPP_BOOL_MIPS32 1 471 #if defined(_MSC_VER) || defined(__BORLANDC__) 472 # define CRYPTOPP_MS_STYLE_INLINE_ASSEMBLY 1 474 # define CRYPTOPP_GNU_STYLE_INLINE_ASSEMBLY 1 479 #if (CRYPTOPP_BOOL_X86 || CRYPTOPP_BOOL_X32 || CRYPTOPP_BOOL_X64) 482 #if defined(CRYPTOPP_APPLE_CLANG_VERSION) && (CRYPTOPP_APPLE_CLANG_VERSION < 50000) 483 # define CRYPTOPP_DISABLE_ASM 1 488 #if !defined(CRYPTOPP_DISABLE_ASM) && defined(__SUNPRO_CC) && (__SUNPRO_CC < 0x5100) 489 # define CRYPTOPP_DISABLE_ASM 1 492 #if !defined(CRYPTOPP_DISABLE_ASM) && ((defined(_MSC_VER) && defined(_M_IX86)) || (defined(__GNUC__) && (defined(__i386__) || defined(__x86_64__)))) 494 #define CRYPTOPP_X86_ASM_AVAILABLE 1 496 #if !defined(CRYPTOPP_DISABLE_SSE2) && (defined(_MSC_VER) || CRYPTOPP_GCC_VERSION >= 30300 || defined(__SSE2__)) 497 #define CRYPTOPP_SSE2_ASM_AVAILABLE 1 500 #if !defined(CRYPTOPP_DISABLE_SSSE3) && (_MSC_VER >= 1500 || CRYPTOPP_GCC_VERSION >= 40300 || defined(__SSSE3__)) 501 #define CRYPTOPP_SSSE3_ASM_AVAILABLE 1 505 #if !defined(CRYPTOPP_DISABLE_ASM) && defined(_MSC_VER) && defined(_M_X64) 506 #define CRYPTOPP_X64_MASM_AVAILABLE 1 509 #if !defined(CRYPTOPP_DISABLE_ASM) && defined(__GNUC__) && defined(__x86_64__) 510 #define CRYPTOPP_X64_ASM_AVAILABLE 1 514 #if !defined(CRYPTOPP_DISABLE_ASM) && (defined(_MSC_VER) || CRYPTOPP_GCC_VERSION >= 30300 || defined(__SSE2__) || (__SUNPRO_CC >= 0x5100)) 515 #define CRYPTOPP_SSE2_INTRIN_AVAILABLE 1 518 #if !defined(CRYPTOPP_DISABLE_ASM) && !defined(CRYPTOPP_DISABLE_SSSE3) 519 # if defined(__SSSE3__) || (_MSC_VER >= 1500) || \ 520 (CRYPTOPP_GCC_VERSION >= 40300) || (__INTEL_COMPILER >= 1000) || (__SUNPRO_CC >= 0x5110) || \ 521 (CRYPTOPP_LLVM_CLANG_VERSION >= 20300) || (CRYPTOPP_APPLE_CLANG_VERSION >= 40000) 522 #define CRYPTOPP_SSSE3_AVAILABLE 1 529 #if !defined(CRYPTOPP_DISABLE_SSE4) && defined(CRYPTOPP_SSSE3_AVAILABLE) && \ 530 (defined(__SSE4_1__) || (CRYPTOPP_MSC_VERSION >= 1500) || \ 531 (CRYPTOPP_GCC_VERSION >= 40300) || (__INTEL_COMPILER >= 1000) || (__SUNPRO_CC >= 0x5110) || \ 532 (CRYPTOPP_LLVM_CLANG_VERSION >= 20300) || (CRYPTOPP_APPLE_CLANG_VERSION >= 40000)) 533 #define CRYPTOPP_SSE41_AVAILABLE 1 536 #if !defined(CRYPTOPP_DISABLE_SSE4) && defined(CRYPTOPP_SSSE3_AVAILABLE) && \ 537 (defined(__SSE4_2__) || (CRYPTOPP_MSC_VERSION >= 1500) || (__SUNPRO_CC >= 0x5110) || \ 538 (CRYPTOPP_GCC_VERSION >= 40300) || (__INTEL_COMPILER >= 1000) || \ 539 (CRYPTOPP_LLVM_CLANG_VERSION >= 20300) || (CRYPTOPP_APPLE_CLANG_VERSION >= 40000)) 540 #define CRYPTOPP_SSE42_AVAILABLE 1 545 #if defined(CRYPTOPP_DISABLE_AESNI) 546 #define CRYPTOPP_DISABLE_CLMUL 1 550 #if !defined(CRYPTOPP_DISABLE_ASM) && !defined(CRYPTOPP_DISABLE_CLMUL) && defined(CRYPTOPP_SSE42_AVAILABLE) && \ 551 (defined(__PCLMUL__) || (_MSC_FULL_VER >= 150030729) || (__SUNPRO_CC >= 0x5120) || \ 552 (CRYPTOPP_GCC_VERSION >= 40300) || (__INTEL_COMPILER >= 1110) || \ 553 (CRYPTOPP_LLVM_CLANG_VERSION >= 30200) || (CRYPTOPP_APPLE_CLANG_VERSION >= 40300)) 554 #define CRYPTOPP_CLMUL_AVAILABLE 1 558 #if !defined(CRYPTOPP_DISABLE_ASM) && !defined(CRYPTOPP_DISABLE_AESNI) && defined(CRYPTOPP_SSE42_AVAILABLE) && \ 559 (defined(__AES__) || (_MSC_FULL_VER >= 150030729) || (__SUNPRO_CC >= 0x5120) || \ 560 (CRYPTOPP_GCC_VERSION >= 40300) || (__INTEL_COMPILER >= 1110) || \ 561 (CRYPTOPP_LLVM_CLANG_VERSION >= 30200) || (CRYPTOPP_APPLE_CLANG_VERSION >= 40300)) 562 #define CRYPTOPP_AESNI_AVAILABLE 1 566 #if !defined(CRYPTOPP_DISABLE_AVX) && defined(CRYPTOPP_SSE42_AVAILABLE) && \ 567 (defined(__AVX2__) || (CRYPTOPP_MSC_VERSION >= 1800) || (__SUNPRO_CC >= 0x5130) || \ 568 (CRYPTOPP_GCC_VERSION >= 40700) || (__INTEL_COMPILER >= 1400) || \ 569 (CRYPTOPP_LLVM_CLANG_VERSION >= 30100) || (CRYPTOPP_APPLE_CLANG_VERSION >= 40600)) 570 #define CRYPTOPP_AVX_AVAILABLE 1 574 #if !defined(CRYPTOPP_DISABLE_AVX2) && defined(CRYPTOPP_AVX_AVAILABLE) && \ 575 (defined(__AVX2__) || (CRYPTOPP_MSC_VERSION >= 1800) || (__SUNPRO_CC >= 0x5130) || \ 576 (CRYPTOPP_GCC_VERSION >= 40700) || (__INTEL_COMPILER >= 1400) || \ 577 (CRYPTOPP_LLVM_CLANG_VERSION >= 30100) || (CRYPTOPP_APPLE_CLANG_VERSION >= 40600)) 578 #define CRYPTOPP_AVX2_AVAILABLE 1 583 #if !defined(CRYPTOPP_DISABLE_ASM) && !defined(CRYPTOPP_DISABLE_SHANI) && defined(CRYPTOPP_SSE42_AVAILABLE) && \ 584 (defined(__SHA__) || (CRYPTOPP_MSC_VERSION >= 1900) || (__SUNPRO_CC >= 0x5160) || \ 585 (CRYPTOPP_GCC_VERSION >= 40900) || (__INTEL_COMPILER >= 1300) || \ 586 (CRYPTOPP_LLVM_CLANG_VERSION >= 30400) || (CRYPTOPP_APPLE_CLANG_VERSION >= 50100)) 587 #define CRYPTOPP_SHANI_AVAILABLE 1 591 #if (defined(__ANDROID__) || defined(ANDROID)) 592 # if (CRYPTOPP_BOOL_X86) 593 # undef CRYPTOPP_SSE41_AVAILABLE 594 # undef CRYPTOPP_SSE42_AVAILABLE 595 # undef CRYPTOPP_CLMUL_AVAILABLE 596 # undef CRYPTOPP_AESNI_AVAILABLE 597 # undef CRYPTOPP_SHANI_AVAILABLE 599 # if (CRYPTOPP_BOOL_X64) 600 # undef CRYPTOPP_CLMUL_AVAILABLE 601 # undef CRYPTOPP_AESNI_AVAILABLE 602 # undef CRYPTOPP_SHANI_AVAILABLE 607 #if defined(__SUNPRO_CC) && (__SUNPRO_CC <= 0x5130) 608 # undef CRYPTOPP_AESNI_AVAILABLE 613 #if defined(__SUNPRO_CC) && (__SUNPRO_CC <= 0x5150) 614 # undef CRYPTOPP_CLMUL_AVAILABLE 617 #endif // X86, X32, X64 621 #if (CRYPTOPP_BOOL_ARM32 || CRYPTOPP_BOOL_ARMV8) 625 #if (CRYPTOPP_BIG_ENDIAN) 626 # define CRYPTOPP_DISABLE_ASM 1 632 #if !defined(CRYPTOPP_ARM_NEON_AVAILABLE) && !defined(CRYPTOPP_DISABLE_ASM) 633 # if defined(__arm__) || defined(__ARM_NEON) || defined(__ARM_FEATURE_NEON) || defined(_M_ARM) 634 # if (CRYPTOPP_GCC_VERSION >= 40300) || (CRYPTOPP_CLANG_VERSION >= 20800) || \ 635 (CRYPTOPP_MSC_VERSION >= 1700) 636 # define CRYPTOPP_ARM_NEON_AVAILABLE 1 644 #if !defined(CRYPTOPP_ARM_ASIMD_AVAILABLE) && !defined(CRYPTOPP_DISABLE_ASM) 645 # if defined(__aarch32__) || defined(__aarch64__) || defined(_M_ARM64) 646 # if defined(__ARM_NEON) || defined(__ARM_FEATURE_NEON) || defined(__ARM_FEATURE_ASIMD) || \ 647 (CRYPTOPP_GCC_VERSION >= 40800) || (CRYPTOPP_CLANG_VERSION >= 30300) || \ 648 (CRYPTOPP_MSC_VERSION >= 1910) 649 # define CRYPTOPP_ARM_NEON_AVAILABLE 1 650 # define CRYPTOPP_ARM_ASIMD_AVAILABLE 1 658 #if !defined(CRYPTOPP_ARM_CRC32_AVAILABLE) && !defined(CRYPTOPP_DISABLE_ASM) 659 # if defined(__aarch32__) || defined(__aarch64__) || defined(_M_ARM64) 660 # if defined(__ARM_FEATURE_CRC32) || (CRYPTOPP_GCC_VERSION >= 40800) || \ 661 (CRYPTOPP_CLANG_VERSION >= 30300) || (CRYPTOPP_MSC_VERSION >= 1910) 662 # define CRYPTOPP_ARM_CRC32_AVAILABLE 1 670 #if !defined(CRYPTOPP_ARM_PMULL_AVAILABLE) && !defined(CRYPTOPP_DISABLE_ASM) 671 # if defined(__aarch32__) || defined(__aarch64__) || defined(_M_ARM64) 672 # if defined(__ARM_FEATURE_CRYPTO) || (CRYPTOPP_GCC_VERSION >= 40800) || \ 673 (CRYPTOPP_CLANG_VERSION >= 30300) || (CRYPTOPP_MSC_VERSION >= 1910) 674 # define CRYPTOPP_ARM_PMULL_AVAILABLE 1 682 #if !defined(CRYPTOPP_ARM_AES_AVAILABLE) && !defined(CRYPTOPP_DISABLE_ASM) 683 # if defined(__aarch32__) || defined(__aarch64__) || defined(_M_ARM64) 684 # if defined(__ARM_FEATURE_CRYPTO) || (CRYPTOPP_GCC_VERSION >= 40800) || \ 685 (CRYPTOPP_CLANG_VERSION >= 30300) || (CRYPTOPP_MSC_VERSION >= 1910) 686 # define CRYPTOPP_ARM_AES_AVAILABLE 1 694 #if !defined(CRYPTOPP_ARM_SHA_AVAILABLE) && !defined(CRYPTOPP_DISABLE_ASM) 695 # if defined(__aarch32__) || defined(__aarch64__) || defined(_M_ARM64) 696 # if defined(__ARM_FEATURE_CRYPTO) || (CRYPTOPP_GCC_VERSION >= 40800) || \ 697 (CRYPTOPP_CLANG_VERSION >= 30300) || (CRYPTOPP_MSC_VERSION >= 1910) 698 # define CRYPTOPP_ARM_SHA1_AVAILABLE 1 699 # define CRYPTOPP_ARM_SHA2_AVAILABLE 1 707 #if !defined(CRYPTOPP_ARM_SHA_AVAILABLE) && !defined(CRYPTOPP_DISABLE_ASM) 708 # if defined(__aarch32__) || defined(__aarch64__) || defined(_M_ARM64) 709 # if defined(__ARM_FEATURE_SHA3) || (CRYPTOPP_GCC_VERSION >= 80000) || \ 710 (CRYPTOPP_MSC_VERSION >= 2100) 711 # define CRYPTOPP_ARM_SHA512_AVAILABLE 1 712 # define CRYPTOPP_ARM_SHA3_AVAILABLE 1 720 #if !defined(CRYPTOPP_ARM_SM3_AVAILABLE) && !defined(CRYPTOPP_DISABLE_ASM) 721 # if defined(__aarch32__) || defined(__aarch64__) || defined(_M_ARM64) 722 # if defined(__ARM_FEATURE_SM3) || (CRYPTOPP_GCC_VERSION >= 80000) || \ 723 (CRYPTOPP_MSC_VERSION >= 2100) 724 # define CRYPTOPP_ARM_SM3_AVAILABLE 1 725 # define CRYPTOPP_ARM_SM4_AVAILABLE 1 731 #if !defined(CRYPTOPP_ARM_ACLE_AVAILABLE) 732 # if defined(__aarch32__) || defined(__aarch64__) || (__ARM_ARCH >= 8) || defined(__ARM_ACLE) 733 # if !defined(__ANDROID__) && !defined(ANDROID) && !defined(__APPLE__) 734 # define CRYPTOPP_ARM_ACLE_AVAILABLE 1 741 #if defined(CRYPTOPP_APPLE_CLANG_VERSION) && (CRYPTOPP_APPLE_CLANG_VERSION < 70000) 742 # undef CRYPTOPP_ARM_PMULL_AVAILABLE 746 #if (defined(__ANDROID__) || defined(ANDROID)) && !defined(__ARM_FEATURE_CRC32) 747 # undef CRYPTOPP_ARM_CRC32_AVAILABLE 751 #if (defined(__ANDROID__) || defined(ANDROID)) && !defined(__ARM_FEATURE_CRYPTO) 752 # undef CRYPTOPP_ARM_PMULL_AVAILABLE 753 # undef CRYPTOPP_ARM_AES_AVAILABLE 754 # undef CRYPTOPP_ARM_SHA1_AVAILABLE 755 # undef CRYPTOPP_ARM_SHA2_AVAILABLE 764 #if !defined(CRYPTOPP_DISABLE_ASM) && defined(__arm__) 765 # if defined(__GNUC__) && !defined(__clang__) 766 # define CRYPTOGAMS_ARM_AES 1 770 #endif // ARM32, ARM64 774 #if (CRYPTOPP_BOOL_PPC32 || CRYPTOPP_BOOL_PPC64) 776 #if defined(CRYPTOPP_DISABLE_ALTIVEC) || defined(CRYPTOPP_DISABLE_ASM) 777 # undef CRYPTOPP_DISABLE_ALTIVEC 778 # undef CRYPTOPP_DISABLE_POWER7 779 # undef CRYPTOPP_DISABLE_POWER8 780 # undef CRYPTOPP_DISABLE_POWER9 781 # define CRYPTOPP_DISABLE_ALTIVEC 1 782 # define CRYPTOPP_DISABLE_POWER7 1 783 # define CRYPTOPP_DISABLE_POWER8 1 784 # define CRYPTOPP_DISABLE_POWER9 1 788 #if !defined(CRYPTOPP_ALTIVEC_AVAILABLE) && !defined(CRYPTOPP_DISABLE_ALTIVEC) 789 # if defined(_ARCH_PWR4) || defined(__ALTIVEC__) || \ 790 (CRYPTOPP_XLC_VERSION >= 100000) || (CRYPTOPP_GCC_VERSION >= 40001) || \ 791 (CRYPTOPP_CLANG_VERSION >= 20900) 792 # define CRYPTOPP_ALTIVEC_AVAILABLE 1 797 #if !defined(CRYPTOPP_POWER7_AVAILABLE) && !defined(CRYPTOPP_DISABLE_POWER7) && defined(CRYPTOPP_ALTIVEC_AVAILABLE) 798 # if defined(_ARCH_PWR7) || (CRYPTOPP_XLC_VERSION >= 100000) || \ 799 (CRYPTOPP_GCC_VERSION >= 40100) || (CRYPTOPP_CLANG_VERSION >= 30100) 800 # define CRYPTOPP_POWER7_AVAILABLE 1 805 #if !defined(CRYPTOPP_POWER8_AVAILABLE) && !defined(CRYPTOPP_DISABLE_POWER8) && defined(CRYPTOPP_POWER7_AVAILABLE) 806 # if defined(_ARCH_PWR8) || (CRYPTOPP_XLC_VERSION >= 130000) || \ 807 (CRYPTOPP_GCC_VERSION >= 40800) || (CRYPTOPP_CLANG_VERSION >= 70000) 808 # define CRYPTOPP_POWER8_AVAILABLE 1 813 #if !defined(CRYPTOPP_POWER9_AVAILABLE) && !defined(CRYPTOPP_DISABLE_POWER9) && defined(CRYPTOPP_POWER8_AVAILABLE) 814 # if defined(_ARCH_PWR9) || (CRYPTOPP_XLC_VERSION >= 130200) || \ 815 (CRYPTOPP_GCC_VERSION >= 70000) || (CRYPTOPP_CLANG_VERSION >= 80000) 816 # define CRYPTOPP_POWER9_AVAILABLE 1 820 #if !defined(CRYPTOPP_POWER8_AES_AVAILABLE) && !defined(CRYPTOPP_DISABLE_POWER8_AES) && defined(CRYPTOPP_POWER8_AVAILABLE) 821 # if defined(__CRYPTO__) || defined(_ARCH_PWR8) || (CRYPTOPP_XLC_VERSION >= 130000) || \ 822 (CRYPTOPP_GCC_VERSION >= 40800) || (CRYPTOPP_CLANG_VERSION >= 70000) 824 # define CRYPTOPP_POWER8_AES_AVAILABLE 1 825 # define CRYPTOPP_POWER8_VMULL_AVAILABLE 1 826 # define CRYPTOPP_POWER8_SHA_AVAILABLE 1 830 #endif // PPC32, PPC64 835 #if (CRYPTOPP_BOOL_X86 || CRYPTOPP_BOOL_X32 || CRYPTOPP_BOOL_X64 || CRYPTOPP_BOOL_PPC32 || CRYPTOPP_BOOL_PPC64) && !defined(CRYPTOPP_DISABLE_ASM) 836 #define CRYPTOPP_BOOL_ALIGN16 1 838 #define CRYPTOPP_BOOL_ALIGN16 0 843 #if defined(_MSC_VER) 844 #define CRYPTOPP_MM_MALLOC_AVAILABLE 845 #elif defined(__linux__) || defined(__sun__) || defined(__CYGWIN__) 846 #define CRYPTOPP_MEMALIGN_AVAILABLE 847 #elif defined(__APPLE__) || defined(__NetBSD__) || defined(__OpenBSD__) || defined(__DragonFly__) 848 #define CRYPTOPP_MALLOC_ALIGNMENT_IS_16 849 #elif (defined(_GNU_SOURCE) || ((_XOPEN_SOURCE + 0) >= 600)) && (_POSIX_ADVISORY_INFO > 0) 850 #define CRYPTOPP_POSIX_MEMALIGN_AVAILABLE 852 #define CRYPTOPP_NO_ALIGNED_ALLOC 856 #if defined(_MSC_VER) 857 # define CRYPTOPP_NOINLINE_DOTDOTDOT 858 # define CRYPTOPP_NOINLINE __declspec(noinline) 859 #elif defined(__xlc__) || defined(__xlC__) || defined(__ibmxl__) 860 # define CRYPTOPP_NOINLINE_DOTDOTDOT ... 861 # define CRYPTOPP_NOINLINE __attribute__((noinline)) 862 #elif defined(__GNUC__) 863 # define CRYPTOPP_NOINLINE_DOTDOTDOT 864 # define CRYPTOPP_NOINLINE __attribute__((noinline)) 866 # define CRYPTOPP_NOINLINE_DOTDOTDOT ... 867 # define CRYPTOPP_NOINLINE 871 #if defined(CRYPTOPP_DOXYGEN_PROCESSING) || defined(__BORLANDC__) 872 # define CRYPTOPP_CONSTANT(x) static const int x; 874 # define CRYPTOPP_CONSTANT(x) enum {x}; 885 #if defined(__APPLE__) 886 # define CRYPTOPP_NO_CPU_FEATURE_PROBES 1 898 #ifndef CRYPTOPP_INIT_PRIORITY 899 # define CRYPTOPP_INIT_PRIORITY 250 905 #ifndef CRYPTOPP_USER_PRIORITY 906 # define CRYPTOPP_USER_PRIORITY (CRYPTOPP_INIT_PRIORITY+101) 910 #if (CRYPTOPP_INIT_PRIORITY > 0) && !(defined(NO_OS_DEPENDENCE) || defined(__APPLE__) || defined(__sun__)) 911 # if (CRYPTOPP_GCC_VERSION >= 30000) || (CRYPTOPP_LLVM_CLANG_VERSION >= 20900) || (_INTEL_COMPILER >= 800) 912 # define HAVE_GCC_INIT_PRIORITY 1 913 # elif (CRYPTOPP_MSC_VERSION >= 1310) 914 # define HAVE_MSC_INIT_PRIORITY 1 915 # elif defined(__xlc__) || defined(__xlC__) || defined(__ibmxl__) 916 # define HAVE_XLC_INIT_PRIORITY 1 918 #endif // CRYPTOPP_INIT_PRIORITY, NO_OS_DEPENDENCE, Apple, Sun 922 #ifndef NO_OS_DEPENDENCE 924 #if defined(_WIN32) || defined(__CYGWIN__) 925 #define CRYPTOPP_WIN32_AVAILABLE 928 #if defined(__unix__) || defined(__MACH__) || defined(__NetBSD__) || defined(__sun) 929 #define CRYPTOPP_UNIX_AVAILABLE 932 #if defined(__FreeBSD__) || defined(__NetBSD__) || defined(__OpenBSD__) || defined(__DragonFly__) 933 #define CRYPTOPP_BSD_AVAILABLE 936 #if defined(CRYPTOPP_WIN32_AVAILABLE) || defined(CRYPTOPP_UNIX_AVAILABLE) 937 # define HIGHRES_TIMER_AVAILABLE 940 #ifdef CRYPTOPP_WIN32_AVAILABLE 941 # if !defined(WINAPI_FAMILY) 942 # define THREAD_TIMER_AVAILABLE 943 # elif defined(WINAPI_FAMILY) 944 # if (WINAPI_FAMILY_PARTITION(WINAPI_PARTITION_DESKTOP)) 945 # define THREAD_TIMER_AVAILABLE 950 #if defined(CRYPTOPP_UNIX_AVAILABLE) || defined(CRYPTOPP_DOXYGEN_PROCESSING) 951 # define NONBLOCKING_RNG_AVAILABLE 952 # define BLOCKING_RNG_AVAILABLE 953 # define OS_RNG_AVAILABLE 957 #if defined(CRYPTOPP_UNIX_AVAILABLE) 958 # define UNIX_SIGNALS_AVAILABLE 1 961 #ifdef CRYPTOPP_WIN32_AVAILABLE 962 # if !defined(WINAPI_FAMILY) 963 # define NONBLOCKING_RNG_AVAILABLE 964 # define OS_RNG_AVAILABLE 965 # elif defined(WINAPI_FAMILY) 966 # if (WINAPI_FAMILY_PARTITION(WINAPI_PARTITION_DESKTOP)) 967 # define NONBLOCKING_RNG_AVAILABLE 968 # define OS_RNG_AVAILABLE 969 # elif !(WINAPI_FAMILY_PARTITION(WINAPI_PARTITION_DESKTOP)) 970 # if ((WINVER >= 0x0A00 ) || (_WIN32_WINNT >= 0x0A00 )) 971 # define NONBLOCKING_RNG_AVAILABLE 972 # define OS_RNG_AVAILABLE 978 #endif // NO_OS_DEPENDENCE 982 #if defined(CRYPTOPP_WIN32_AVAILABLE) && !defined(CRYPTOPP_DOXYGEN_PROCESSING) 984 #ifdef CRYPTOPP_EXPORTS 985 #define CRYPTOPP_IS_DLL 986 #define CRYPTOPP_DLL __declspec(dllexport) 987 #elif defined(CRYPTOPP_IMPORTS) 988 #define CRYPTOPP_IS_DLL 989 #define CRYPTOPP_DLL __declspec(dllimport) 995 #define CRYPTOPP_TABLE extern 996 #define CRYPTOPP_API __cdecl 998 #else // not CRYPTOPP_WIN32_AVAILABLE 1001 #define CRYPTOPP_TABLE extern 1002 #define CRYPTOPP_DLL 1003 #define CRYPTOPP_API 1005 #endif // CRYPTOPP_WIN32_AVAILABLE 1007 #if defined(__MWERKS__) 1008 #define CRYPTOPP_EXTERN_DLL_TEMPLATE_CLASS extern class CRYPTOPP_DLL 1009 #elif defined(__BORLANDC__) || defined(__SUNPRO_CC) 1010 #define CRYPTOPP_EXTERN_DLL_TEMPLATE_CLASS template class CRYPTOPP_DLL 1012 #define CRYPTOPP_EXTERN_DLL_TEMPLATE_CLASS extern template class CRYPTOPP_DLL 1015 #if defined(CRYPTOPP_MANUALLY_INSTANTIATE_TEMPLATES) && !defined(CRYPTOPP_IMPORTS) 1016 #define CRYPTOPP_DLL_TEMPLATE_CLASS template class CRYPTOPP_DLL 1018 #define CRYPTOPP_DLL_TEMPLATE_CLASS CRYPTOPP_EXTERN_DLL_TEMPLATE_CLASS 1021 #if defined(__MWERKS__) 1022 #define CRYPTOPP_EXTERN_STATIC_TEMPLATE_CLASS extern class 1023 #elif defined(__BORLANDC__) || defined(__SUNPRO_CC) 1024 #define CRYPTOPP_EXTERN_STATIC_TEMPLATE_CLASS template class 1026 #define CRYPTOPP_EXTERN_STATIC_TEMPLATE_CLASS extern template class 1029 #if defined(CRYPTOPP_MANUALLY_INSTANTIATE_TEMPLATES) && !defined(CRYPTOPP_EXPORTS) 1030 #define CRYPTOPP_STATIC_TEMPLATE_CLASS template class 1032 #define CRYPTOPP_STATIC_TEMPLATE_CLASS CRYPTOPP_EXTERN_STATIC_TEMPLATE_CLASS 1039 #define CRYPTOPP_UNUSED(x) ((void)(x)) 1043 #if (CRYPTOPP_GCC_VERSION >= 40500) || (CRYPTOPP_LLVM_CLANG_VERSION >= 20800) || (CRYPTOPP_APPLE_CLANG_VERSION >= 40200) 1044 # define CRYPTOPP_DEPRECATED(msg) __attribute__((deprecated (msg))) 1045 #elif (CRYPTOPP_GCC_VERSION) 1046 # define CRYPTOPP_DEPRECATED(msg) __attribute__((deprecated)) 1048 # define CRYPTOPP_DEPRECATED(msg) 1060 #ifndef __has_feature 1061 # define __has_feature(x) 0 1064 #if !defined(CRYPTOPP_NO_CXX11) 1065 # if ((_MSC_VER >= 1600) || (__cplusplus >= 201103L)) && !defined(_STLPORT_VERSION) 1066 # define CRYPTOPP_CXX11 1 1075 #if defined(__APPLE__) && defined(__clang__) 1076 # if !(defined(__has_include) && __has_include(<forward_list>)) 1077 # undef CRYPTOPP_CXX11 1082 #if defined(CRYPTOPP_CXX11) 1085 #if (CRYPTOPP_MSC_VERSION >= 1700) || __has_feature(cxx_atomic) || \ 1086 (__INTEL_COMPILER >= 1300) || (CRYPTOPP_GCC_VERSION >= 40400) || (__SUNPRO_CC >= 0x5140) 1087 # define CRYPTOPP_CXX11_ATOMICS 1 1092 #if (CRYPTOPP_MSC_VERSION >= 1700) || (CRYPTOPP_LLVM_CLANG_VERSION >= 30300) || \ 1093 (CRYPTOPP_APPLE_CLANG_VERSION >= 50000) || (__INTEL_COMPILER >= 1200) || \ 1094 (CRYPTOPP_GCC_VERSION >= 40400) || (__SUNPRO_CC >= 0x5130) 1101 # if !defined(__GLIBCXX__) || defined(_GLIBCXX_HAS_GTHREADS) 1102 # define CRYPTOPP_CXX11_SYNCHRONIZATION 1 1104 #endif // synchronization 1110 #if (CRYPTOPP_MSC_VERSION >= 1900) && ((WINVER >= 0x0600) || (_WIN32_WINNT >= 0x0600)) || \ 1111 (CRYPTOPP_LLVM_CLANG_VERSION >= 20900) || (CRYPTOPP_APPLE_CLANG_VERSION >= 40000) || \ 1112 (__INTEL_COMPILER >= 1110) || (CRYPTOPP_GCC_VERSION >= 40300) || (__SUNPRO_CC >= 0x5130) 1113 # define CRYPTOPP_CXX11_DYNAMIC_INIT 1 1114 #endif // Dynamic Initialization compilers 1117 #if (CRYPTOPP_MSC_VERSION >= 1900) || __has_feature(cxx_alignas) || \ 1118 (__INTEL_COMPILER >= 1500) || (CRYPTOPP_GCC_VERSION >= 40800) || (__SUNPRO_CC >= 0x5130) 1119 # define CRYPTOPP_CXX11_ALIGNAS 1 1123 #if (CRYPTOPP_MSC_VERSION >= 1900) || __has_feature(cxx_alignof) || \ 1124 (__INTEL_COMPILER >= 1500) || (CRYPTOPP_GCC_VERSION >= 40500) || (__SUNPRO_CC >= 0x5130) 1125 # define CRYPTOPP_CXX11_ALIGNOF 1 1129 #if (CRYPTOPP_MSC_VERSION >= 1700) || __has_feature(cxx_lambdas) || \ 1130 (__INTEL_COMPILER >= 1200) || (CRYPTOPP_GCC_VERSION >= 40900) || (__SUNPRO_CC >= 0x5140) 1131 # define CRYPTOPP_CXX11_LAMBDA 1 1135 #if (CRYPTOPP_MSC_VERSION >= 1900) || __has_feature(cxx_noexcept) || \ 1136 (__INTEL_COMPILER >= 1400) || (CRYPTOPP_GCC_VERSION >= 40600) || (__SUNPRO_CC >= 0x5130) 1137 # define CRYPTOPP_CXX11_NOEXCEPT 1 1138 #endif // noexcept compilers 1141 #if (CRYPTOPP_MSC_VERSION >= 1800) || __has_feature(cxx_variadic_templates) || \ 1142 (__INTEL_COMPILER >= 1210) || (CRYPTOPP_GCC_VERSION >= 40300) || (__SUNPRO_CC >= 0x5130) 1143 # define CRYPTOPP_CXX11_VARIADIC_TEMPLATES 1 1144 #endif // variadic templates 1148 #if (CRYPTOPP_MSC_VERSION >= 1900) || __has_feature(cxx_constexpr) || \ 1149 (__INTEL_COMPILER >= 1600) || (CRYPTOPP_GCC_VERSION >= 40600) || (__SUNPRO_CC >= 0x5130) 1150 # define CRYPTOPP_CXX11_CONSTEXPR 1 1151 #endif // constexpr compilers 1155 #if (CRYPTOPP_MSC_VERSION >= 1700) || __has_feature(cxx_strong_enums) || \ 1156 (__INTEL_COMPILER >= 1400) || (CRYPTOPP_GCC_VERSION >= 40400) || (__SUNPRO_CC >= 0x5120) 1157 # define CRYPTOPP_CXX11_ENUM 1 1158 #endif // constexpr compilers 1161 #if (CRYPTOPP_MSC_VERSION >= 1600) || __has_feature(cxx_nullptr) || \ 1162 (__INTEL_COMPILER >= 1000) || (CRYPTOPP_GCC_VERSION >= 40600) || \ 1163 (__SUNPRO_CC >= 0x5130) || defined(__IBMCPP_NULLPTR) 1164 # define CRYPTOPP_CXX11_NULLPTR 1 1165 #endif // nullptr_t compilers 1167 #endif // CRYPTOPP_CXX11 1172 #if defined(CRYPTOPP_CXX11) && !defined(CRYPTOPP_NO_CXX17) 1173 # if ((_MSC_VER >= 1900) || (__cplusplus >= 201703L)) && !defined(_STLPORT_VERSION) 1174 # define CRYPTOPP_CXX17 1 1179 #if defined(CRYPTOPP_CXX17) 1183 #if defined(__clang__) 1184 # if __EXCEPTIONS && __has_feature(cxx_exceptions) 1185 # if __cpp_lib_uncaught_exceptions 1186 # define CRYPTOPP_CXX17_EXCEPTIONS 1 1189 #elif (CRYPTOPP_MSC_VERSION >= 1900) || (__INTEL_COMPILER >= 1800) || (CRYPTOPP_GCC_VERSION >= 60000) || (__cpp_lib_uncaught_exceptions) 1190 # define CRYPTOPP_CXX17_EXCEPTIONS 1 1191 #endif // uncaught_exceptions compilers 1193 #endif // CRYPTOPP_CXX17 1197 #if defined(CRYPTOPP_CXX11_NOEXCEPT) 1198 # define CRYPTOPP_THROW noexcept(false) 1199 # define CRYPTOPP_NO_THROW noexcept(true) 1201 # define CRYPTOPP_THROW 1202 # define CRYPTOPP_NO_THROW 1203 #endif // CRYPTOPP_CXX11_NOEXCEPT 1206 #if defined(CRYPTOPP_CXX11_CONSTEXPR) 1207 # define CRYPTOPP_STATIC_CONSTEXPR static constexpr 1208 # define CRYPTOPP_CONSTEXPR constexpr 1210 # define CRYPTOPP_STATIC_CONSTEXPR static 1211 # define CRYPTOPP_CONSTEXPR 1212 #endif // CRYPTOPP_CXX11_CONSTEXPR 1215 #if defined(CRYPTOPP_CXX11_ALIGNAS) 1216 # undef CRYPTOPP_ALIGN_DATA 1217 # define CRYPTOPP_ALIGN_DATA(x) alignas(x) 1218 #endif // CRYPTOPP_CXX11_ALIGNAS 1229 #if defined(CRYPTOPP_CXX11_ENUM) 1230 # undef CRYPTOPP_CONSTANT 1231 # define CRYPTOPP_CONSTANT(x) enum : int { x }; 1232 #elif defined(CRYPTOPP_CXX11_CONSTEXPR) 1233 # undef CRYPTOPP_CONSTANT 1234 # define CRYPTOPP_CONSTANT(x) constexpr static int x; 1238 #if defined(CRYPTOPP_CXX11_NULLPTR) && !defined(NULLPTR) 1239 # define NULLPTR nullptr 1240 #elif !defined(NULLPTR) 1241 # define NULLPTR NULL 1242 #endif // CRYPTOPP_CXX11_NULLPTR 1246 #if (defined(__cplusplus) && (__cplusplus >= 199711L) && (__cplusplus < 201402L)) && !defined(CRYPTOPP_UNCAUGHT_EXCEPTION_AVAILABLE) 1247 # error "std::uncaught_exception is not available. This is likely a configuration error." 1250 #endif // CRYPTOPP_CONFIG_H Crypto++ library namespace.