VeraCrypt
aboutsummaryrefslogtreecommitdiff
path: root/src/Common/Tests.h
blob: 6aff505f6d47f0bacab97b07ea849bd85ae635fd (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
/*
 Legal Notice: Some portions of the source code contained in this file were
 derived from the source code of TrueCrypt 7.1a, which is
 Copyright (c) 2003-2012 TrueCrypt Developers Association and which is
 governed by the TrueCrypt License 3.0, also from the source code of
 Encryption for the Masses 2.02a, which is Copyright (c) 1998-2000 Paul Le Roux
 and which is governed by the 'License Agreement for Encryption for the Masses'
 Modifications and additions to the original source code (contained in this file)
 and all other portions of this file are Copyright (c) 2013-2017 IDRIX
 and are governed by the Apache License 2.0 the full text of which is
 contained in the file License.txt included in VeraCrypt binary and source
 code distribution packages. */

#ifdef __cplusplus
extern "C" {
#endif

extern unsigned char ks_tmp[MAX_EXPANDED_KEY];

void CipherInit2(int cipher, void* key, void* ks, int key_len);
BOOL test_hmac_sha512 (void);
BOOL test_hmac_ripemd160 (void);
BOOL test_hmac_whirlpool (void);
BOOL test_pkcs5 (void);
BOOL TestSectorBufEncryption ();
BOOL TestLegacySectorBufEncryption ();
BOOL AutoTestAlgorithms (void);

#ifdef __cplusplus
}
#endif
#define MAX_HOST_PARTITION_NUMBER 32 #define VOLUME_ID_SIZE SHA256_DIGESTSIZE typedef enum { // IMPORTANT: If you add a new item here, update IsOSVersionAtLeast(). WIN_UNKNOWN = 0, WIN_31, WIN_95, WIN_98, WIN_ME, WIN_NT3, WIN_NT4, WIN_2000, WIN_XP, WIN_XP64, WIN_SERVER_2003, WIN_VISTA, WIN_SERVER_2008, WIN_7, WIN_SERVER_2008_R2, WIN_8, WIN_SERVER_2012, WIN_8_1, WIN_SERVER_2012_R2, WIN_10, WIN_SERVER_2016 } OSVersionEnum; /* Volume types */ enum { TC_VOLUME_TYPE_NORMAL = 0, TC_VOLUME_TYPE_HIDDEN, TC_VOLUME_TYPE_COUNT }; /* Prop volume types */ enum { PROP_VOL_TYPE_NORMAL = 0, PROP_VOL_TYPE_HIDDEN, PROP_VOL_TYPE_OUTER, /* Outer/normal (hidden volume protected) */ PROP_VOL_TYPE_OUTER_VOL_WRITE_PREVENTED, /* Outer/normal (hidden volume protected AND write already prevented) */ PROP_VOL_TYPE_SYSTEM, PROP_NBR_VOLUME_TYPES }; /* Hidden volume protection status */ enum { HIDVOL_PROT_STATUS_NONE = 0, HIDVOL_PROT_STATUS_ACTIVE, HIDVOL_PROT_STATUS_ACTION_TAKEN /* Active + action taken (write operation has already been denied) */ }; typedef struct { BOOL ReadOnly; BOOL Removable; BOOL ProtectHiddenVolume; BOOL PreserveTimestamp; BOOL PartitionInInactiveSysEncScope; /* If TRUE, we are to attempt to mount a partition located on an encrypted system drive without pre-boot authentication. */ Password ProtectedHidVolPassword; /* Password of hidden volume to protect against overwriting */ BOOL UseBackupHeader; BOOL RecoveryMode; int ProtectedHidVolPkcs5Prf; int ProtectedHidVolPim; wchar_t Label[33]; /* maximum label length is 32 for NTFS and 11 for FAT32 */ } MountOptions; #endif