diff options
author | Mounir IDRASSI <mounir.idrassi@idrix.fr> | 2017-01-10 05:25:49 +0100 |
---|---|---|
committer | Mounir IDRASSI <mounir.idrassi@idrix.fr> | 2017-01-12 09:42:54 +0100 |
commit | e831198b3b0afbcd21cb9a4b1aef90fa8b198d69 (patch) | |
tree | 5be0a3402375068ef37ce2d5b6b084c5b01d2521 | |
parent | e3d5077939898f691dcecc965e77b81a3443b662 (diff) | |
download | VeraCrypt-e831198b3b0afbcd21cb9a4b1aef90fa8b198d69.tar.gz VeraCrypt-e831198b3b0afbcd21cb9a4b1aef90fa8b198d69.zip |
Windows: Fix Streebog not recognized by /hash command line switch but making hash names matching more generic.
-rw-r--r-- | src/Common/Crypto.c | 5 | ||||
-rw-r--r-- | src/Common/Crypto.h | 4 | ||||
-rw-r--r-- | src/Format/Tcformat.c | 18 | ||||
-rw-r--r-- | src/Mount/Mount.c | 18 |
4 files changed, 26 insertions, 19 deletions
diff --git a/src/Common/Crypto.c b/src/Common/Crypto.c index 808c8af7..6c2b2e84 100644 --- a/src/Common/Crypto.c +++ b/src/Common/Crypto.c | |||
@@ -762,16 +762,17 @@ Hash *HashGet (int id) | |||
762 | return 0; | 762 | return 0; |
763 | } | 763 | } |
764 | 764 | ||
765 | 765 | #ifdef _WIN32 | |
766 | int HashGetIdByName (wchar_t *name) | 766 | int HashGetIdByName (wchar_t *name) |
767 | { | 767 | { |
768 | int i; | 768 | int i; |
769 | for (i = 0; Hashes[i].Id != 0; i++) | 769 | for (i = 0; Hashes[i].Id != 0; i++) |
770 | if (wcscmp (Hashes[i].Name, name) == 0) | 770 | if (_wcsicmp (Hashes[i].Name, name) == 0) |
771 | return Hashes[i].Id; | 771 | return Hashes[i].Id; |
772 | 772 | ||
773 | return 0; | 773 | return 0; |
774 | } | 774 | } |
775 | #endif | ||
775 | 776 | ||
776 | const wchar_t *HashGetName (int hashId) | 777 | const wchar_t *HashGetName (int hashId) |
777 | { | 778 | { |
diff --git a/src/Common/Crypto.h b/src/Common/Crypto.h index 8e8bace7..9aba0eae 100644 --- a/src/Common/Crypto.h +++ b/src/Common/Crypto.h | |||
@@ -363,7 +363,9 @@ BOOL EAIsModeSupported (int ea, int testedMode); | |||
363 | 363 | ||
364 | #ifndef TC_WINDOWS_BOOT | 364 | #ifndef TC_WINDOWS_BOOT |
365 | const wchar_t *HashGetName (int hash_algo_id); | 365 | const wchar_t *HashGetName (int hash_algo_id); |
366 | 366 | #ifdef _WIN32 | |
367 | int HashGetIdByName (wchar_t *name); | ||
368 | #endif | ||
367 | Hash *HashGet (int id); | 369 | Hash *HashGet (int id); |
368 | void HashGetName2 (wchar_t *buf, int hashId); | 370 | void HashGetName2 (wchar_t *buf, int hashId); |
369 | BOOL HashIsDeprecated (int hashId); | 371 | BOOL HashIsDeprecated (int hashId); |
diff --git a/src/Format/Tcformat.c b/src/Format/Tcformat.c index d83d9f49..02210b15 100644 --- a/src/Format/Tcformat.c +++ b/src/Format/Tcformat.c | |||
@@ -9000,20 +9000,22 @@ void ExtractCommandLine (HWND hwndDlg, wchar_t *lpszCommandLine) | |||
9000 | if (HAS_ARGUMENT == GetArgumentValue (lpszCommandLineArgs, | 9000 | if (HAS_ARGUMENT == GetArgumentValue (lpszCommandLineArgs, |
9001 | &i, nNoCommandLineArgs, szTmp, ARRAYSIZE (szTmp))) | 9001 | &i, nNoCommandLineArgs, szTmp, ARRAYSIZE (szTmp))) |
9002 | { | 9002 | { |
9003 | if (_wcsicmp(szTmp, L"sha512") == 0 || _wcsicmp(szTmp, L"sha-512") == 0) | 9003 | /* match against special names first */ |
9004 | if (_wcsicmp(szTmp, L"sha512") == 0) | ||
9004 | CmdVolumePkcs5 = SHA512; | 9005 | CmdVolumePkcs5 = SHA512; |
9005 | else if (_wcsicmp(szTmp, L"whirlpool") == 0) | 9006 | else if (_wcsicmp(szTmp, L"sha256") == 0) |
9006 | CmdVolumePkcs5 = WHIRLPOOL; | ||
9007 | else if (_wcsicmp(szTmp, L"sha256") == 0 || _wcsicmp(szTmp, L"sha-256") == 0) | ||
9008 | CmdVolumePkcs5 = SHA256; | 9007 | CmdVolumePkcs5 = SHA256; |
9009 | else if (_wcsicmp(szTmp, L"ripemd160") == 0 || _wcsicmp(szTmp, L"ripemd-160") == 0) | 9008 | else if (_wcsicmp(szTmp, L"ripemd160") == 0) |
9010 | CmdVolumePkcs5 = RIPEMD160; | 9009 | CmdVolumePkcs5 = RIPEMD160; |
9011 | else | 9010 | else |
9012 | { | 9011 | { |
9013 | CmdVolumePkcs5 = 0; | 9012 | /* match using internal hash names */ |
9014 | AbortProcess ("COMMAND_LINE_ERROR"); | 9013 | CmdVolumePkcs5 = HashGetIdByName (szTmp); |
9014 | if (0 == CmdVolumePkcs5) | ||
9015 | { | ||
9016 | AbortProcess ("COMMAND_LINE_ERROR"); | ||
9017 | } | ||
9015 | } | 9018 | } |
9016 | |||
9017 | } | 9019 | } |
9018 | else | 9020 | else |
9019 | AbortProcess ("COMMAND_LINE_ERROR"); | 9021 | AbortProcess ("COMMAND_LINE_ERROR"); |
diff --git a/src/Mount/Mount.c b/src/Mount/Mount.c index 28a43acf..e90a0571 100644 --- a/src/Mount/Mount.c +++ b/src/Mount/Mount.c | |||
@@ -8836,20 +8836,22 @@ void ExtractCommandLine (HWND hwndDlg, wchar_t *lpszCommandLine) | |||
8836 | if (HAS_ARGUMENT == GetArgumentValue (lpszCommandLineArgs, | 8836 | if (HAS_ARGUMENT == GetArgumentValue (lpszCommandLineArgs, |
8837 | &i, nNoCommandLineArgs, szTmp, ARRAYSIZE (szTmp))) | 8837 | &i, nNoCommandLineArgs, szTmp, ARRAYSIZE (szTmp))) |
8838 | { | 8838 | { |
8839 | if (_wcsicmp(szTmp, L"sha512") == 0 || _wcsicmp(szTmp, L"sha-512") == 0) | 8839 | /* match against special names first */ |
8840 | if (_wcsicmp(szTmp, L"sha512") == 0) | ||
8840 | CmdVolumePkcs5 = SHA512; | 8841 | CmdVolumePkcs5 = SHA512; |
8841 | else if (_wcsicmp(szTmp, L"whirlpool") == 0) | 8842 | else if (_wcsicmp(szTmp, L"sha256") == 0) |
8842 | CmdVolumePkcs5 = WHIRLPOOL; | ||
8843 | else if (_wcsicmp(szTmp, L"sha256") == 0 || _wcsicmp(szTmp, L"sha-256") == 0) | ||
8844 | CmdVolumePkcs5 = SHA256; | 8843 | CmdVolumePkcs5 = SHA256; |
8845 | else if (_wcsicmp(szTmp, L"ripemd160") == 0 || _wcsicmp(szTmp, L"ripemd-160") == 0) | 8844 | else if (_wcsicmp(szTmp, L"ripemd160") == 0) |
8846 | CmdVolumePkcs5 = RIPEMD160; | 8845 | CmdVolumePkcs5 = RIPEMD160; |
8847 | else | 8846 | else |
8848 | { | 8847 | { |
8849 | CmdVolumePkcs5 = 0; | 8848 | /* match using internal hash names */ |
8850 | AbortProcess ("COMMAND_LINE_ERROR"); | 8849 | CmdVolumePkcs5 = HashGetIdByName (szTmp); |
8850 | if (0 == CmdVolumePkcs5) | ||
8851 | { | ||
8852 | AbortProcess ("COMMAND_LINE_ERROR"); | ||
8853 | } | ||
8851 | } | 8854 | } |
8852 | |||
8853 | } | 8855 | } |
8854 | else | 8856 | else |
8855 | AbortProcess ("COMMAND_LINE_ERROR"); | 8857 | AbortProcess ("COMMAND_LINE_ERROR"); |