1
0
mirror of https://github.com/veracrypt/VeraCrypt.git synced 2025-11-13 03:48:26 -06:00

Use properly aligned memory in code using Streebog hash implementation that uses SSE.

This commit is contained in:
Mounir IDRASSI
2016-09-28 00:14:05 +02:00
parent 3e029b0dde
commit 57ce7aab7b
7 changed files with 65 additions and 23 deletions

View File

@@ -15,13 +15,13 @@
namespace VeraCrypt
{
Buffer::Buffer () : DataPtr (nullptr), DataSize (0)
Buffer::Buffer () : DataPtr (nullptr), DataSize (0), DataAlignment (0)
{
}
Buffer::Buffer (size_t size) : DataPtr (nullptr), DataSize (0)
Buffer::Buffer (size_t size, size_t alignment) : DataPtr (nullptr), DataSize (0), DataAlignment (0)
{
Allocate (size);
Allocate (size, alignment);
}
Buffer::~Buffer ()
@@ -30,37 +30,42 @@ namespace VeraCrypt
Free ();
}
void Buffer::Allocate (size_t size)
void Buffer::Allocate (size_t size, size_t alignment)
{
if (size < 1)
throw ParameterIncorrect (SRC_POS);
if (DataPtr != nullptr)
{
if (DataSize == size)
if ((DataSize == size) && (DataAlignment == alignment))
return;
Free();
}
try
{
DataPtr = static_cast<byte *> (Memory::Allocate (size));
DataPtr = static_cast<byte *> ((alignment > 0)? Memory::AllocateAligned (size, alignment) : Memory::Allocate (size));
DataSize = size;
DataAlignment = alignment;
}
catch (...)
{
DataPtr = nullptr;
DataSize = 0;
DataAlignment = 0;
throw;
}
}
void Buffer::CopyFrom (const ConstBufferPtr &bufferPtr)
void Buffer::CopyFrom (const ConstBufferPtr &bufferPtr, size_t alignment)
{
if (!IsAllocated ())
if (!IsAllocated () || ((bufferPtr.Size()) && (DataAlignment != alignment)))
{
if (IsAllocated ())
Free ();
if (bufferPtr.Size())
Allocate (bufferPtr.Size());
Allocate (bufferPtr.Size(), alignment);
}
else if (bufferPtr.Size() > DataSize)
throw ParameterTooLarge (SRC_POS);
@@ -80,9 +85,13 @@ namespace VeraCrypt
if (DataPtr == nullptr)
throw NotInitialized (SRC_POS);
Memory::Free (DataPtr);
if (DataAlignment > 0)
Memory::FreeAligned (DataPtr);
else
Memory::Free (DataPtr);
DataPtr = nullptr;
DataSize = 0;
DataAlignment = 0;
}
BufferPtr Buffer::GetRange (size_t offset, size_t size) const
@@ -99,9 +108,9 @@ namespace VeraCrypt
Memory::Zero (DataPtr, DataSize);
}
SecureBuffer::SecureBuffer (size_t size)
SecureBuffer::SecureBuffer (size_t size, size_t alignment)
{
Allocate (size);
Allocate (size, alignment);
}
SecureBuffer::~SecureBuffer ()
@@ -110,9 +119,9 @@ namespace VeraCrypt
Free ();
}
void SecureBuffer::Allocate (size_t size)
void SecureBuffer::Allocate (size_t size, size_t alignment)
{
Buffer::Allocate (size);
Buffer::Allocate (size, alignment);
}
void SecureBuffer::Free ()