--- truecrypt/common/endian.h 2018/04/24 16:46:30 1.1.1.10 +++ truecrypt/common/endian.h 2018/04/24 16:48:28 1.1.1.12 @@ -1,16 +1,22 @@ /* - Legal Notice: The source code contained in this file has been derived from - the source code of Encryption for the Masses 2.02a, which is Copyright (c) - Paul Le Roux and which is covered by the 'License Agreement for Encryption - for the Masses'. Modifications and additions to that source code contained - in this file are Copyright (c) TrueCrypt Foundation and are covered by the - TrueCrypt License 2.2 the full text of which is contained in the file - License.txt included in TrueCrypt binary and source code distribution + Legal Notice: Some portions of the source code contained in this file were + derived 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) 2003-2008 TrueCrypt Foundation and are governed + by the TrueCrypt License 2.4 the full text of which is contained in the + file License.txt included in TrueCrypt binary and source code distribution packages. */ #ifndef TC_ENDIAN_H #define TC_ENDIAN_H +#if defined(__cplusplus) +extern "C" +{ +#endif + #ifdef _WIN32 # ifndef LITTLE_ENDIAN @@ -40,7 +46,13 @@ # error Byte order cannot be determined - kernel source not prepared for building of modules # endif # else -# include +# ifdef TC_MACOSX +# include +# elif defined (TC_BSD) +# include +# else +# include +# endif # ifndef BYTE_ORDER # ifndef __BYTE_ORDER @@ -131,7 +143,13 @@ unsigned __int16 MirrorBytes16 (unsigned __int16 x); unsigned __int32 MirrorBytes32 (unsigned __int32 x); +#ifndef TC_NO_COMPILER_INT64 unsigned __int64 MirrorBytes64 (unsigned __int64 x); +#endif void LongReverse ( unsigned __int32 *buffer , unsigned byteCount ); +#if defined(__cplusplus) +} +#endif + #endif /* TC_ENDIAN_H */