diff options
Diffstat (limited to 'src/Common')
-rw-r--r-- | src/Common/Pkcs5.c | 25 | ||||
-rw-r--r-- | src/Common/Pkcs5.h | 10 |
2 files changed, 35 insertions, 0 deletions
diff --git a/src/Common/Pkcs5.c b/src/Common/Pkcs5.c index 753c49b4..1da5e237 100644 --- a/src/Common/Pkcs5.c +++ b/src/Common/Pkcs5.c @@ -1209,4 +1209,29 @@ int get_pkcs5_iteration_count (int pkcs5_prf_id, int pim, BOOL truecryptMode, BO return 0; } +int is_pkcs5_prf_supported (int pkcs5_prf_id, BOOL truecryptMode, PRF_BOOT_TYPE bootType) +{ + if (pkcs5_prf_id == 0) // auto-detection always supported + return 1; + + if (truecryptMode) + { + if ( (bootType == PRF_BOOT_GPT) + || (bootType == PRF_BOOT_MBR && pkcs5_prf_id != RIPEMD160) + || (bootType == PRF_BOOT_NO && pkcs5_prf_id != SHA512 && pkcs5_prf_id != WHIRLPOOL && pkcs5_prf_id != RIPEMD160) + ) + return 0; + } + else + { + if ( (bootType == PRF_BOOT_MBR && pkcs5_prf_id != RIPEMD160 && pkcs5_prf_id != SHA256) + || (bootType != PRF_BOOT_MBR && (pkcs5_prf_id < FIRST_PRF_ID || pkcs5_prf_id > LAST_PRF_ID)) + ) + return 0; + } + + return 1; + +} + #endif //!TC_WINDOWS_BOOT diff --git a/src/Common/Pkcs5.h b/src/Common/Pkcs5.h index 261df85d..2758bdf6 100644 --- a/src/Common/Pkcs5.h +++ b/src/Common/Pkcs5.h @@ -42,6 +42,16 @@ void derive_key_streebog (char *pwd, int pwd_len, char *salt, int salt_len, uint int get_pkcs5_iteration_count (int pkcs5_prf_id, int pim, BOOL truecryptMode, BOOL bBoot); wchar_t *get_pkcs5_prf_name (int pkcs5_prf_id); + +/* check if given PRF supported.*/ +typedef enum +{ + PRF_BOOT_NO = 0, + PRF_BOOT_MBR, + PRF_BOOT_GPT +} PRF_BOOT_TYPE; + +int is_pkcs5_prf_supported (int pkcs5_prf_id, BOOL truecryptMode, PRF_BOOT_TYPE bootType); #endif #if defined(__cplusplus) |