6 #ifndef CRYPTOPP_IMPORTS
8 #define CRYPTOPP_DEFAULT_NO_DLL
16 #ifdef CRYPTOPP_WIN32_AVAILABLE
17 # if defined(WINAPI_FAMILY)
18 # if !(WINAPI_FAMILY_PARTITION(WINAPI_PARTITION_DESKTOP))
19 # undef CRYPTOPP_WIN32_AVAILABLE
24 #ifdef CRYPTOPP_WIN32_AVAILABLE
26 #define _WIN32_WINNT 0x0400
31 #if defined(_MSC_VER) && _MSC_VER >= 1400
33 #define _CRT_DEBUGGER_HOOK _crt_debugger_hook
35 #define _CRT_DEBUGGER_HOOK __crt_debugger_hook
38 extern "C" {_CRTIMP
void __cdecl _CRT_DEBUGGER_HOOK(
int);}
40 extern "C" {
void __cdecl _CRT_DEBUGGER_HOOK(
int); }
47 #if CRYPTOPP_MSC_VERSION
48 # pragma warning(disable: 4100)
55 unsigned long g_macFileLocation = 0;
61 #ifdef CRYPTOPP_WIN32_AVAILABLE
62 static HMODULE s_hModule = NULL;
65 const byte * CRYPTOPP_API GetActualMacAndLocation(
unsigned int &macSize,
unsigned int &fileLocation)
67 macSize = (
unsigned int)g_actualMac.
size();
68 fileLocation = g_macFileLocation;
83 template <
class CIPHER>
84 void X917RNG_KnownAnswerTest(
87 const char *deterministicTimeVector,
91 CRYPTOPP_UNUSED(dummy);
92 #ifdef OS_RNG_AVAILABLE
93 std::string decodedKey, decodedSeed, decodedDeterministicTimeVector;
99 rng.Reseed((
const byte *)decodedKey.data(), decodedKey.size(), (
const byte *)decodedSeed.data(), (
const byte *)decodedDeterministicTimeVector.data());
100 KnownAnswerTest(rng, output);
120 template <
class CIPHER>
121 void SymmetricEncryptionKnownAnswerTest(
124 const char *plaintext,
130 CIPHER *dummy = NULL)
132 CRYPTOPP_UNUSED(dummy);
133 std::string decodedKey;
136 typename CIPHER::Encryption encryption((
const byte *)decodedKey.data(), decodedKey.size());
137 typename CIPHER::Decryption decryption((
const byte *)decodedKey.data(), decodedKey.size());
154 void KnownAnswerTest(
HashTransformation &hash,
const char *message,
const char *digest)
164 template <
class HASH>
165 void SecureHashKnownAnswerTest(
const char *message,
const char *digest, HASH *dummy = NULL)
167 CRYPTOPP_UNUSED(dummy);
169 KnownAnswerTest(hash, message, digest);
173 void MAC_KnownAnswerTest(
const char *key,
const char *message,
const char *digest, MAC *dummy = NULL)
175 CRYPTOPP_UNUSED(dummy);
176 std::string decodedKey;
179 MAC mac((
const byte *)decodedKey.data(), decodedKey.size());
180 KnownAnswerTest(mac, message, digest);
183 template <
class SCHEME>
184 void SignatureKnownAnswerTest(
const char *key,
const char *message,
const char *signature, SCHEME *dummy = NULL)
187 typename SCHEME::Verifier verifier(signer);
189 CRYPTOPP_UNUSED(dummy);
209 const char *testMessage =
"test message";
210 std::string ciphertext, decrypted;
220 if (ciphertext == testMessage)
231 if (decrypted != testMessage)
261 template <
class SCHEME>
262 void SignaturePairwiseConsistencyTest(
const char *key, SCHEME *dummy = NULL)
265 typename SCHEME::Verifier verifier(signer);
267 CRYPTOPP_UNUSED(dummy);
268 SignaturePairwiseConsistencyTest(signer, verifier);
273 byte key[] = {0x47, 0x1E, 0x33, 0x96, 0x65, 0xB1, 0x6A, 0xED, 0x0B, 0xF8, 0x6B, 0xFD, 0x01, 0x65, 0x05, 0xCC};
283 SecByteBlock &actualMac = pActualMac ? *pActualMac : tempMac;
284 actualMac.
resize(macSize);
286 unsigned long tempLocation = 0;
287 unsigned long &macFileLocation = pMacFileLocation ? *pMacFileLocation : tempLocation;
292 std::ifstream moduleStream;
294 #ifdef CRYPTOPP_WIN32_AVAILABLE
297 char moduleFilenameBuf[MAX_PATH] =
"";
298 if (moduleFilename == NULL)
300 #if (_MSC_VER >= 1400 && !defined(_STLPORT_VERSION)) // ifstream doesn't support wide filename on other compilers
301 wchar_t wideModuleFilename[MAX_PATH];
302 if (GetModuleFileNameW(s_hModule, wideModuleFilename, MAX_PATH) > 0)
304 moduleStream.open(wideModuleFilename, std::ios::in | std::ios::binary);
305 h = GetModuleHandleW(wideModuleFilename);
310 GetModuleFileNameA(s_hModule, moduleFilenameBuf, MAX_PATH);
311 moduleFilename = moduleFilenameBuf;
315 if (moduleFilename != NULL)
317 moduleStream.open(moduleFilename, std::ios::in | std::ios::binary);
318 #ifdef CRYPTOPP_WIN32_AVAILABLE
319 h = GetModuleHandleA(moduleFilename);
320 moduleFilename = NULL;
327 #ifdef CRYPTOPP_WIN32_AVAILABLE
328 OutputDebugString(
"Crypto++ DLL integrity check failed. Cannot open file for reading.");
334 #ifdef CRYPTOPP_WIN32_AVAILABLE
336 const byte *memBase = (
const byte *)h;
337 const IMAGE_DOS_HEADER *ph = (IMAGE_DOS_HEADER *)memBase;
338 const IMAGE_NT_HEADERS *phnt = (IMAGE_NT_HEADERS *)(memBase + ph->e_lfanew);
339 const IMAGE_SECTION_HEADER *phs = IMAGE_FIRST_SECTION(phnt);
340 DWORD nSections = phnt->FileHeader.NumberOfSections;
341 size_t currentFilePos = 0;
343 size_t checksumPos = (
byte *)&phnt->OptionalHeader.CheckSum - memBase;
344 size_t checksumSize =
sizeof(phnt->OptionalHeader.CheckSum);
345 size_t certificateTableDirectoryPos = (
byte *)&phnt->OptionalHeader.DataDirectory[IMAGE_DIRECTORY_ENTRY_SECURITY] - memBase;
346 size_t certificateTableDirectorySize =
sizeof(phnt->OptionalHeader.DataDirectory[IMAGE_DIRECTORY_ENTRY_SECURITY]);
347 size_t certificateTablePos = phnt->OptionalHeader.DataDirectory[IMAGE_DIRECTORY_ENTRY_SECURITY].VirtualAddress;
348 size_t certificateTableSize = phnt->OptionalHeader.DataDirectory[IMAGE_DIRECTORY_ENTRY_SECURITY].Size;
351 verifier.
AddRangeToSkip(0, certificateTableDirectoryPos, certificateTableDirectorySize);
352 verifier.
AddRangeToSkip(0, certificateTablePos, certificateTableSize);
356 switch (phs->Characteristics)
360 case IMAGE_SCN_CNT_CODE | IMAGE_SCN_MEM_EXECUTE | IMAGE_SCN_MEM_READ:
361 case IMAGE_SCN_CNT_INITIALIZED_DATA | IMAGE_SCN_MEM_READ:
362 unsigned int sectionSize =
STDMIN(phs->SizeOfRawData, phs->Misc.VirtualSize);
363 const byte *sectionMemStart = memBase + phs->VirtualAddress;
364 unsigned int sectionFileStart = phs->PointerToRawData;
365 size_t subSectionStart = 0, nextSubSectionStart;
369 const byte *subSectionMemStart = sectionMemStart + subSectionStart;
370 size_t subSectionFileStart = sectionFileStart + subSectionStart;
371 size_t subSectionSize = sectionSize - subSectionStart;
372 nextSubSectionStart = 0;
374 unsigned int entriesToReadFromDisk[] = {IMAGE_DIRECTORY_ENTRY_IMPORT, IMAGE_DIRECTORY_ENTRY_IAT};
375 for (
unsigned int i=0; i<
sizeof(entriesToReadFromDisk)/
sizeof(entriesToReadFromDisk[0]); i++)
377 const IMAGE_DATA_DIRECTORY &entry = phnt->OptionalHeader.DataDirectory[entriesToReadFromDisk[i]];
378 const byte *entryMemStart = memBase + entry.VirtualAddress;
379 if (subSectionMemStart <= entryMemStart && entryMemStart < subSectionMemStart + subSectionSize)
381 subSectionSize = entryMemStart - subSectionMemStart;
382 nextSubSectionStart = entryMemStart - sectionMemStart + entry.Size;
386 #if defined(_MSC_VER) && _MSC_VER >= 1400
388 if (IsDebuggerPresent())
390 if (subSectionMemStart <= (
byte *)&_CRT_DEBUGGER_HOOK && (
byte *)&_CRT_DEBUGGER_HOOK < subSectionMemStart + subSectionSize)
392 subSectionSize = (
byte *)&_CRT_DEBUGGER_HOOK - subSectionMemStart;
393 nextSubSectionStart = (
byte *)&_CRT_DEBUGGER_HOOK - sectionMemStart + 1;
398 if (subSectionMemStart <= expectedModuleMac && expectedModuleMac < subSectionMemStart + subSectionSize)
401 macFileLocation = (
unsigned long)(subSectionFileStart + (expectedModuleMac - subSectionMemStart));
405 file.
TransferTo(verifier, subSectionFileStart - currentFilePos);
406 verifier.
Put(subSectionMemStart, subSectionSize);
407 file.
Skip(subSectionSize);
408 currentFilePos = subSectionFileStart + subSectionSize;
409 subSectionStart = nextSubSectionStart;
410 }
while (nextSubSectionStart != 0);
417 #ifdef CRYPTOPP_WIN32_AVAILABLE
422 OutputDebugString(
"In memory integrity check failed. This may be caused by debug breakpoints or DLL relocation.\n");
423 moduleStream.clear();
424 moduleStream.seekg(0);
428 verifier.
AddRangeToSkip(0, certificateTableDirectoryPos, certificateTableDirectorySize);
429 verifier.
AddRangeToSkip(0, certificateTablePos, certificateTableSize);
438 #ifdef CRYPTOPP_WIN32_AVAILABLE
441 OutputDebugString(((
"Crypto++ DLL integrity check failed. Actual MAC is: " + hexMac) +
"\n").c_str());
449 SetPowerUpSelfTestInProgressOnThisThread(
true);
461 X917RNG_KnownAnswerTest<AES>(
462 "2b7e151628aed2a6abf7158809cf4f3c",
463 "000102030405060708090a0b0c0d0e0f",
464 "00000000000000000000000000000001",
465 "D176EDD27493B0395F4D10546232B0693DC7061C03C3A554F09CECF6F6B46D945A");
467 SymmetricEncryptionKnownAnswerTest<DES_EDE3>(
468 "385D7189A5C3D485E1370AA5D408082B5CCCCB5E19F2D90E",
470 "6E1BD7C6120947A464A6AAB293A0F89A563D8D40D3461B68",
471 "64EAAD4ACBB9CEAD6C7615E7C7E4792FE587D91F20C7D2F4",
472 "6235A461AFD312973E3B4F7AA7D23E34E03371F8E8C376C9",
473 "E26BA806A59B0330DE40CA38E77A3E494BE2B212F6DD624B",
474 "E26BA806A59B03307DE2BCC25A08BA40A8BA335F5D604C62",
475 "E26BA806A59B03303C62C2EFF32D3ACDD5D5F35EBCC53371");
477 SymmetricEncryptionKnownAnswerTest<SKIPJACK>(
478 "1555E5531C3A169B2D65",
480 "00AFA48E9621E52E8CBDA312660184EDDB1F33D9DACDA8DA",
481 "DBEC73562EFCAEB56204EB8AE9557EBF77473FBB52D17CD1",
482 "0C7B0B74E21F99B8F2C8DF37879F6C044967F42A796DCA8B",
483 "79FDDA9724E36CC2E023E9A5C717A8A8A7FDA465CADCBF63",
484 "79FDDA9724E36CC26CACBD83C1ABC06EAF5B249BE5B1E040",
485 "79FDDA9724E36CC211B0AEC607B95A96BCDA318440B82F49");
487 SymmetricEncryptionKnownAnswerTest<AES>(
488 "2b7e151628aed2a6abf7158809cf4f3c",
489 "000102030405060708090a0b0c0d0e0f",
490 "6bc1bee22e409f96e93d7e117393172aae2d8a571e03ac9c9eb76fac45af8e5130c81c46a35ce411e5fbc1191a0a52eff69f2445df4f9b17ad2b417be66c3710",
491 "3ad77bb40d7a3660a89ecaf32466ef97f5d3d58503b9699de785895a96fdbaaf43b1cd7f598ece23881b00e3ed0306887b0c785e27e8ad3f8223207104725dd4",
492 "7649abac8119b246cee98e9b12e9197d5086cb9b507219ee95db113a917678b273bed6b8e3c1743b7116e69e222295163ff1caa1681fac09120eca307586e1a7",
493 "3b3fd92eb72dad20333449f8e83cfb4ac8a64537a0b3a93fcde3cdad9f1ce58b26751f67a3cbb140b1808cf187a4f4dfc04b05357c5d1c0eeac4c66f9ff7f2e6",
494 "3b3fd92eb72dad20333449f8e83cfb4a7789508d16918f03f53c52dac54ed8259740051e9c5fecf64344f7a82260edcc304c6528f659c77866a510d9c1d6ae5e",
497 SymmetricEncryptionKnownAnswerTest<AES>(
498 "2b7e151628aed2a6abf7158809cf4f3c",
499 "f0f1f2f3f4f5f6f7f8f9fafbfcfdfeff",
500 "6bc1bee22e409f96e93d7e117393172aae2d8a571e03ac9c9eb76fac45af8e5130c81c46a35ce411e5fbc1191a0a52eff69f2445df4f9b17ad2b417be66c3710",
505 "874d6191b620e3261bef6864990db6ce9806f66b7970fdff8617187bb9fffdff5ae4df3edbd5d35e5b4f09020db03eab1e031dda2fbe03d1792170a0f3009cee");
508 SecureHashKnownAnswerTest<SHA1>(
510 "A9993E364706816ABA3E25717850C26C9CD0D89D");
512 SecureHashKnownAnswerTest<SHA224>(
514 "23097d223405d8228642a477bda255b32aadbce4bda0b3f7e36c9da7");
516 SecureHashKnownAnswerTest<SHA256>(
518 "ba7816bf8f01cfea414140de5dae2223b00361a396177a9cb410ff61f20015ad");
520 SecureHashKnownAnswerTest<SHA384>(
522 "cb00753f45a35e8bb5a03d699ac65007272c32ab0eded1631a8b605a43ff5bed8086072ba1e7cc2358baeca134c825a7");
524 SecureHashKnownAnswerTest<SHA512>(
526 "ddaf35a193617abacc417349ae20413112e6fa4e89a97ea20a9eeee64b55d39a2192992a274fc1a836ba3c23a3feebbd454d4423643ce80e2a9ac94fa54ca49f");
528 MAC_KnownAnswerTest<HMAC<SHA1> >(
529 "303132333435363738393a3b3c3d3e3f40414243",
531 "0922d3405faa3d194f82a45830737d5cc6c75d24");
533 const char *keyRSA1 =
534 "30820150020100300d06092a864886f70d01010105000482013a3082013602010002400a66791dc6988168de7ab77419bb7fb0"
535 "c001c62710270075142942e19a8d8c51d053b3e3782a1de5dc5af4ebe99468170114a1dfe67cdc9a9af55d655620bbab0203010001"
536 "02400123c5b61ba36edb1d3679904199a89ea80c09b9122e1400c09adcf7784676d01d23356a7d44d6bd8bd50e94bfc723fa"
537 "87d8862b75177691c11d757692df8881022033d48445c859e52340de704bcdda065fbb4058d740bd1d67d29e9c146c11cf61"
538 "0220335e8408866b0fd38dc7002d3f972c67389a65d5d8306566d5c4f2a5aa52628b0220045ec90071525325d3d46db79695e9af"
539 "acc4523964360e02b119baa366316241022015eb327360c7b60d12e5e2d16bdcd97981d17fba6b70db13b20b436e24eada590220"
540 "2ca6366d72781dfa24d34a9a24cbc2ae927a9958af426563ff63fb11658a461d";
542 const char *keyRSA2 =
543 "30820273020100300D06092A864886F70D01010105000482025D3082025902010002818100D40AF9"
544 "A2B713034249E5780056D70FC7DE75D76E44565AA6A6B8ED9646F3C19F9E254D72D7DE6E49DB2264"
545 "0C1D05AB9E2A5F901D8F3FE1F7AE02CEE2ECCE54A40ABAE55A004692752E70725AEEE7CDEA67628A"
546 "82A9239B4AB660C2BC56D9F01E90CBAAB9BF0FC8E17173CEFC5709A29391A7DDF3E0B758691AAF30"
547 "725B292F4F020111027F18C0BA087D082C45D75D3594E0767E4820818EB35612B80CEAB8C880ACA5"
548 "44B6876DFFEF85A576C0D45B551AFAA1FD63209CD745DF75C5A0F0B580296EA466CD0338207E4752"
549 "FF4E7DB724D8AE18CE5CF4153BB94C27869FBB50E64F02546E4B02997A0B8623E64017CC770759C6"
550 "695DB649EEFD829D688D441BCC4E7348F1024100EF86DD7AF3F32CDE8A9F6564E43A559A0C9F8BAD"
551 "36CC25330548B347AC158A345631FA90F7B873C36EFFAE2F7823227A3F580B5DD18304D5932751E7"
552 "43E9234F024100E2A039854B55688740E32A51DF4AF88613D91A371CF8DDD95D780A89D7CF2119A9"
553 "54F1AC0F3DCDB2F6959926E6D9D37D8BC07A4C634DE6F16315BD5F0DAC340102407ECEEDB9903572"
554 "1B76909F174BA6698DCA72953D957B22C0A871C8531EDE3A1BB52984A719BC010D1CA57A555DB83F"
555 "6DE54CBAB932AEC652F38D497A6F3F30CF024100854F30E4FF232E6DADB2CD99926855F484255AB7"
556 "01FBCDCB27EC426F33A7046972AA700ADBCA008763DF87440F52F4E070531AC385B55AAC1C2AE7DD"
557 "8F9278F1024100C313F4AF9E4A9DE1253C21080CE524251560C111550772FD08690F13FBE658342E"
558 "BD2D41C9DCB12374E871B1839E26CAE252E1AE3DAAD5F1EE1F42B4D0EE7581";
560 SignatureKnownAnswerTest<RSASS<PKCS1v15, SHA1> >(
562 "Everyone gets Friday off.",
563 "0610761F95FFD1B8F29DA34212947EC2AA0E358866A722F03CC3C41487ADC604A48FF54F5C6BEDB9FB7BD59F82D6E55D8F3174BA361B2214B2D74E8825E04E81");
565 SignatureKnownAnswerTest<RSASS_ISO<SHA1> >(
568 "32F6BA41C8930DE71EE67F2627172CC539EDE04267FDE03AC295E3C50311F26C3B275D3AF513AC96"
569 "8EE493BAB7DA3A754661D1A7C4A0D1A2B7EE8B313AACD8CB8BFBC5C15EFB0EF15C86A9334A1E87AD"
570 "291EB961B5CA0E84930429B28780816AA94F96FC2367B71E2D2E4866FA966795B147F00600E5207E"
573 SignaturePairwiseConsistencyTest<DSA>(
574 "3082014A0201003082012B06072A8648CE3804013082011E02818100F468699A6F6EBCC0120D3B34C8E007F125EC7D81F763B8D0F33869AE3BD6B9F2ECCC7DF34DF84C0307449E9B85D30D57194BCCEB310F48141914DD13A077AAF9B624A6CBE666BBA1D7EBEA95B5BA6F54417FD5D4E4220C601E071D316A24EA814E8B0122DBF47EE8AEEFD319EBB01DD95683F10DBB4FEB023F8262A07EAEB7FD02150082AD4E034DA6EEACDFDAE68C36F2BAD614F9E53B02818071AAF73361A26081529F7D84078ADAFCA48E031DB54AD57FB1A833ADBD8672328AABAA0C756247998D7A5B10DACA359D231332CE8120B483A784FE07D46EEBFF0D7D374A10691F78653E6DC29E27CCB1B174923960DFE5B959B919B2C3816C19251832AFD8E35D810E598F82877ABF7D40A041565168BD7F0E21E3FE2A8D8C1C0416021426EBA66E846E755169F84A1DA981D86502405DDF");
576 SignaturePairwiseConsistencyTest<ECDSA<EC2N, SHA1> >(
577 "302D020100301006072A8648CE3D020106052B8104000404163014020101040F0070337065E1E196980A9D00E37211");
579 SignaturePairwiseConsistencyTest<ECDSA<ECP, SHA1> >(
580 "3039020100301306072A8648CE3D020106082A8648CE3D030101041F301D02010104182BB8A13C8B867010BD9471D9E81FDB01ABD0538C64D6249A");
582 SignaturePairwiseConsistencyTest<RSASS<PSS, SHA1> >(keyRSA1);
593 SetPowerUpSelfTestInProgressOnThisThread(
false);
597 #ifdef CRYPTOPP_WIN32_AVAILABLE
608 throw NotImplemented(
"DoDllPowerUpSelfTest() only available on Windows");
611 #endif // #ifdef CRYPTOPP_WIN32_AVAILABLE
615 #ifdef CRYPTOPP_WIN32_AVAILABLE
618 BOOL APIENTRY DllMain(HANDLE hModule,
622 if (dwReason == DLL_PROCESS_ATTACH)
624 CryptoPP::s_hModule = (HMODULE)hModule;
630 #endif // #ifdef CRYPTOPP_WIN32_AVAILABLE
632 #endif // #ifndef CRYPTOPP_IMPORTS