From 74bf831716e9b4badd354b482b15115809c89927 Mon Sep 17 00:00:00 2001 From: msieben <4319079+msieben@users.noreply.github.com> Date: Mon, 1 Jul 2024 20:18:25 +0000 Subject: [PATCH 1/8] [Tests/unit/core] : Update expectations --- Tests/unit/core/test_dataelement.cpp | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/Tests/unit/core/test_dataelement.cpp b/Tests/unit/core/test_dataelement.cpp index c9f63f979..9907d4c7e 100644 --- a/Tests/unit/core/test_dataelement.cpp +++ b/Tests/unit/core/test_dataelement.cpp @@ -38,7 +38,7 @@ namespace Core { obj1.Copy(arr,len,off); uint32_t size = 1024; EXPECT_EQ(obj1.Size(),size); - obj1.Size(1025); + ASSERT_EQ(obj1.Size(), 1024); EXPECT_EQ(*obj1.Buffer(),10); uint8_t arr1[] = {10,20,30,40,50,60,70,80,90,100}; @@ -64,7 +64,7 @@ namespace Core { uint64_t GetNumber = 10; EXPECT_EQ((obj2.GetNumber(2)),GetNumber); - obj2.Search(2,arr2,5); + EXPECT_EQ(obj2.Search(2,arr2,5), obj2.Size()); // Unable to find pattern obj2.SetBitNumber(2,5,8,10); uint64_t GetBitNumber = 10; EXPECT_EQ(obj2.GetBitNumber(2,5,8),GetBitNumber); @@ -80,15 +80,15 @@ namespace Core { uint32_t ob_size = 10; EXPECT_EQ(obj3.Size(),ob_size); - EXPECT_FALSE(obj3.Expand(0,0)); - EXPECT_TRUE(obj3.Shrink(0,0)); + ASSERT_FALSE(obj3.Expand(0,0)); + ASSERT_TRUE(obj3.Shrink(0,0)); EXPECT_FALSE(obj3.Copy(obj2)); } TEST(test_linkeddata, simple_linkeddata) { uint8_t arr[] = {10,20,30,40,50,60,70,80,90,100}; - uint8_t arr1[] ={}; + uint8_t arr1[sizeof(arr)] = {}; const uint64_t offset= 0; ::Thunder::Core::DataElement objt1(10,arr); ::Thunder::Core::LinkedDataElement ob1; @@ -103,7 +103,7 @@ namespace Core { EXPECT_EQ(ob4.Copy(offset,ob2), unsigned(10)); EXPECT_EQ(ob2.Copy(offset,ob3), unsigned(10)); - ob1.Enclosed(); + EXPECT_EQ(ob1.Enclosed(), nullptr); EXPECT_EQ(ob2.LinkedSize(), unsigned(10)); EXPECT_EQ(ob2.LinkedElements(),unsigned(1)); } From 72279fbb18fc493a372d51ace3a2b05d5bcd2315 Mon Sep 17 00:00:00 2001 From: msieben <4319079+msieben@users.noreply.github.com> Date: Mon, 1 Jul 2024 21:36:18 +0000 Subject: [PATCH 2/8] [Tests/unit/core] : Add test to 'test_dataelement' --- Tests/unit/core/test_dataelement.cpp | 12 +++++++++--- 1 file changed, 9 insertions(+), 3 deletions(-) diff --git a/Tests/unit/core/test_dataelement.cpp b/Tests/unit/core/test_dataelement.cpp index 9907d4c7e..c680ae636 100644 --- a/Tests/unit/core/test_dataelement.cpp +++ b/Tests/unit/core/test_dataelement.cpp @@ -80,9 +80,15 @@ namespace Core { uint32_t ob_size = 10; EXPECT_EQ(obj3.Size(),ob_size); - ASSERT_FALSE(obj3.Expand(0,0)); - ASSERT_TRUE(obj3.Shrink(0,0)); - EXPECT_FALSE(obj3.Copy(obj2)); +// ASSERT_FALSE(obj3.Expand(0,0)); +// ASSERT_TRUE(obj3.Shrink(0,0)); +// EXPECT_FALSE(obj3.Copy(obj2)); + + ASSERT_TRUE(obj3.Shrink(obj3.AllocatedSize()-obj3.Size()+1,obj3.Size()-1)); +// ASSERT_FALSE(obj3.Expand(obj3.AllocatedSize()-obj3.Size()-1,obj3.Size()+1)); // No internal storage, not the owner of the buffer +// ASSERT_TRUE(obj3.Expand(obj3.AllocatedSize()-obj3.Size()-1,obj3.Size())); // No internal storage, but also no actual change in size +// ASSERT_TRUE(obj3.Expand(obj3.AllocatedSize()-obj3.Size()-1,obj3.AllocatedSize())); +// EXPECT_TRUE(obj3.Copy(obj2)); } TEST(test_linkeddata, simple_linkeddata) From a7538950ab7be9e97ade70f3a18b8ec85bd9fcb9 Mon Sep 17 00:00:00 2001 From: msieben <4319079+msieben@users.noreply.github.com> Date: Wed, 3 Jul 2024 08:24:18 +0000 Subject: [PATCH 3/8] [core/DataElement] : Improve 'Shrink' and 'Expand' --- Source/core/DataElement.h | 31 ++++++++++++++++++++----------- 1 file changed, 20 insertions(+), 11 deletions(-) diff --git a/Source/core/DataElement.h b/Source/core/DataElement.h index 41251319b..bc6dbbb72 100644 --- a/Source/core/DataElement.h +++ b/Source/core/DataElement.h @@ -369,15 +369,19 @@ namespace Core { bool expanded = false; - // Make sure we are not shrinking beyond the size boundary - ASSERT(offset <= m_Size); + // Make sure we are not expanding beyond the size boundary + ASSERT(size <= (m_MaxSize - m_Size)); + + if ((expanded = Size(size)) == true) { + ASSERT(m_Offset < m_Size); + ASSERT((offset - m_Offset) < (m_MaxSize - m_Size)); - if (Size(size) == true) { // Shift all data back the beginning in.. - ::memmove(&m_Buffer[static_cast(offset)], &m_Buffer[static_cast(offset) + size], static_cast(m_Size - offset)); + ::memmove(&m_Buffer[static_cast(offset)], &m_Buffer[static_cast(m_Offset)], static_cast(m_Size - m_Offset)); - // Now the total size is smaller, adjust - m_Size += size; + // Now the total size is larger, adjust + expanded = (size != m_Size) || (offset != m_Offset); + m_Offset = offset; } return (expanded); @@ -387,16 +391,21 @@ namespace Core { { ASSERT(IsValid()); + bool shrunken = false; + // Make sure we are not shrinking beyond the size boundary - ASSERT(m_Size >= (offset + size)); + ASSERT(size <= m_Size); + ASSERT(offset < (m_Size - size)); + ASSERT(m_Offset < (m_Size - size)); + + // Shift all data back the beginning in.. + ::memmove(&m_Buffer[static_cast(offset)], &m_Buffer[static_cast(m_Offset)], static_cast(m_Size - offset)); // Now the toal size is smaller, adjust + shrunken = (size != m_Size) || (offset != m_Offset); m_Size -= size; - // Shift all data back the beginning in.. - ::memmove(&m_Buffer[static_cast(offset)], &m_Buffer[static_cast(offset) + size], static_cast(m_Size - offset)); - - return (true); + return (shrunken); } bool Copy(const DataElement& RHS, const uint64_t offset = 0) From 7c3adac075cb7b49a4a86ea3fc307ce042d71c9d Mon Sep 17 00:00:00 2001 From: msieben <4319079+msieben@users.noreply.github.com> Date: Wed, 3 Jul 2024 08:24:58 +0000 Subject: [PATCH 4/8] [Tests/unit/core] : 'Improve 'test_dataelement' --- Tests/unit/core/test_dataelement.cpp | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/Tests/unit/core/test_dataelement.cpp b/Tests/unit/core/test_dataelement.cpp index c680ae636..c57736e8f 100644 --- a/Tests/unit/core/test_dataelement.cpp +++ b/Tests/unit/core/test_dataelement.cpp @@ -84,8 +84,8 @@ namespace Core { // ASSERT_TRUE(obj3.Shrink(0,0)); // EXPECT_FALSE(obj3.Copy(obj2)); - ASSERT_TRUE(obj3.Shrink(obj3.AllocatedSize()-obj3.Size()+1,obj3.Size()-1)); -// ASSERT_FALSE(obj3.Expand(obj3.AllocatedSize()-obj3.Size()-1,obj3.Size()+1)); // No internal storage, not the owner of the buffer + ASSERT_TRUE(obj3.Shrink(0, 1)); // Shrink by one elements + ASSERT_TRUE(obj3.Expand(1, 1)); // Expand by one element // ASSERT_TRUE(obj3.Expand(obj3.AllocatedSize()-obj3.Size()-1,obj3.Size())); // No internal storage, but also no actual change in size // ASSERT_TRUE(obj3.Expand(obj3.AllocatedSize()-obj3.Size()-1,obj3.AllocatedSize())); // EXPECT_TRUE(obj3.Copy(obj2)); From 5273de4f48adebbd5f57e2e77a1634f5b22ae1c5 Mon Sep 17 00:00:00 2001 From: msieben <4319079+msieben@users.noreply.github.com> Date: Wed, 3 Jul 2024 11:38:48 +0000 Subject: [PATCH 5/8] [core/DataElement] : improve some conditions --- Source/core/DataElement.h | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/Source/core/DataElement.h b/Source/core/DataElement.h index bc6dbbb72..83064c17d 100644 --- a/Source/core/DataElement.h +++ b/Source/core/DataElement.h @@ -372,9 +372,9 @@ namespace Core { // Make sure we are not expanding beyond the size boundary ASSERT(size <= (m_MaxSize - m_Size)); - if ((expanded = Size(size)) == true) { + if ((expanded = Size(m_Size + size)) == true) { ASSERT(m_Offset < m_Size); - ASSERT((offset - m_Offset) < (m_MaxSize - m_Size)); + ASSERT((offset - m_Offset) <= (m_MaxSize - m_Size)); // Shift all data back the beginning in.. ::memmove(&m_Buffer[static_cast(offset)], &m_Buffer[static_cast(m_Offset)], static_cast(m_Size - m_Offset)); @@ -404,6 +404,7 @@ namespace Core { // Now the toal size is smaller, adjust shrunken = (size != m_Size) || (offset != m_Offset); m_Size -= size; + m_Offset = offset; return (shrunken); } @@ -752,7 +753,7 @@ namespace Core { if (size == NUMBER_MAX_UNSIGNED(uint64_t)) { // Reset the size to the maxSize... m_Size = m_MaxSize - m_Offset; - } else if ((size + m_Offset) < m_MaxSize) { + } else if ((size + m_Offset) <= m_MaxSize) { // It fits the allocated buffer, accept and reduce.. m_Size = size; } else { From fc4dd32320715e39a6abe2aaa2a4ec98b948aeed Mon Sep 17 00:00:00 2001 From: msieben <4319079+msieben@users.noreply.github.com> Date: Wed, 3 Jul 2024 11:39:32 +0000 Subject: [PATCH 6/8] [Tests/unit/core] : Add tests to 'test_dataelement' --- Tests/unit/core/test_dataelement.cpp | 23 ++++++++++++++--------- 1 file changed, 14 insertions(+), 9 deletions(-) diff --git a/Tests/unit/core/test_dataelement.cpp b/Tests/unit/core/test_dataelement.cpp index c57736e8f..682a074d7 100644 --- a/Tests/unit/core/test_dataelement.cpp +++ b/Tests/unit/core/test_dataelement.cpp @@ -80,15 +80,20 @@ namespace Core { uint32_t ob_size = 10; EXPECT_EQ(obj3.Size(),ob_size); -// ASSERT_FALSE(obj3.Expand(0,0)); -// ASSERT_TRUE(obj3.Shrink(0,0)); -// EXPECT_FALSE(obj3.Copy(obj2)); - - ASSERT_TRUE(obj3.Shrink(0, 1)); // Shrink by one elements - ASSERT_TRUE(obj3.Expand(1, 1)); // Expand by one element -// ASSERT_TRUE(obj3.Expand(obj3.AllocatedSize()-obj3.Size()-1,obj3.Size())); // No internal storage, but also no actual change in size -// ASSERT_TRUE(obj3.Expand(obj3.AllocatedSize()-obj3.Size()-1,obj3.AllocatedSize())); -// EXPECT_TRUE(obj3.Copy(obj2)); + + ASSERT_TRUE(obj3.Shrink(0, 1)); // Shrink by one element + EXPECT_EQ(obj3.Size(),ob_size - 1); + ASSERT_TRUE(obj3.Expand(0, 1)); // Expand by one element + EXPECT_EQ(obj3.Size(),ob_size); + ASSERT_TRUE(obj3.Shrink(1, 1)); + EXPECT_EQ(obj3.Size(),ob_size - 1); + ASSERT_FALSE(obj3.Expand(1, 1)); // Not the owner of the underlying storage + EXPECT_EQ(obj3.Size(),ob_size - 1); + ASSERT_TRUE(obj3.Shrink(0, 0)); // Offset only + EXPECT_EQ(obj3.Size(),ob_size - 1); + ASSERT_TRUE(obj3.Expand(0, 1)); + EXPECT_EQ(obj3.Size(),ob_size); + EXPECT_TRUE(obj3.Copy(obj2)); } TEST(test_linkeddata, simple_linkeddata) From 6b7a2ffaa9fa69577caf9f5ac612a3ea32c8e024 Mon Sep 17 00:00:00 2001 From: msieben <4319079+msieben@users.noreply.github.com> Date: Wed, 3 Jul 2024 13:23:42 +0000 Subject: [PATCH 7/8] [core/DataElement] : various improvements --- Source/core/DataElement.cpp | 4 + Source/core/DataElement.h | 179 ++++++++++++++++++++++++++++++------ 2 files changed, 154 insertions(+), 29 deletions(-) diff --git a/Source/core/DataElement.cpp b/Source/core/DataElement.cpp index f7bfd1544..f2f686299 100644 --- a/Source/core/DataElement.cpp +++ b/Source/core/DataElement.cpp @@ -94,6 +94,7 @@ namespace Core { { ASSERT(IsValid()); ASSERT(buffer != nullptr); + ASSERT(std::numeric_limits::max() - size >= offset); // Check if we cross a boundary for the read.. if ((offset + size) <= Size()) { @@ -101,6 +102,7 @@ namespace Core { ::memmove(buffer, &(Buffer()[offset]), size); } else { // If we want to read more than 4Gb ASSERT !! + ASSERT(Size() >= offset); ASSERT(Size() - offset < 0xFFFFFFFF); // oops partial read untill we got it all @@ -119,6 +121,7 @@ namespace Core { { ASSERT(IsValid()); ASSERT(buffer != nullptr); + ASSERT(std::numeric_limits::max() - size >= offset); // Check if we cross a boundary for the write.. if ((offset + size) <= Size()) { @@ -126,6 +129,7 @@ namespace Core { ::memmove(&(Buffer()[offset]), buffer, size); } else { // If we want to write more than 4Gb ASSERT !! + ASSERT(Size() >= offset); ASSERT(Size() - offset < 0xFFFFFFFF); // oops partial read untill we got it all diff --git a/Source/core/DataElement.h b/Source/core/DataElement.h index 83064c17d..5dc48a83d 100644 --- a/Source/core/DataElement.h +++ b/Source/core/DataElement.h @@ -76,12 +76,15 @@ namespace Core { inline void Copy(const uint8_t data[], const uint16_t length, const uint16_t offset = 0) { ASSERT(_buffer != nullptr); + ASSERT( !offset + || offset < _size + ); + ASSERT(length < _size); - ASSERT(offset < _size); if (offset < _size) { - ASSERT(static_cast(offset + length) <= _size); + ASSERT(static_cast(offset < (_size - length))); - uint32_t count(static_cast(offset + length) <= _size ? length : _size - offset); + uint32_t count(static_cast(offset < (_size - length) ? length : _size - offset)); ::memcpy(&(_buffer[offset]), data, count); } @@ -119,6 +122,10 @@ namespace Core { void UpdateCache(const uint64_t offset, uint8_t* buffer, const uint64_t size, const uint64_t maxSize) { ASSERT(buffer != nullptr); + ASSERT( !offset + || offset < maxSize + ); + ASSERT(size <= maxSize); // Update the cache... m_Offset = offset; @@ -129,7 +136,16 @@ namespace Core { void UpdateCache(const Core::DataElement& data, const uint64_t offset, const uint64_t size) { ASSERT(data.IsValid()); - ASSERT((offset + size) <= data.Size()); + ASSERT( !offset + || offset < data.m_MaxSize + ); + ASSERT(size <= data.m_MaxSize); + ASSERT( !offset + || offset < (data.Size() - size) + ); + ASSERT( std::numeric_limits::max() / 2 > offset + && std::numeric_limits::max() / 2 > data.m_Offset + ); // Update the cache... m_Offset = data.m_Offset + offset; @@ -155,6 +171,7 @@ namespace Core { , m_Size(size) , m_MaxSize(size) { + ASSERT(buffer != nullptr); } inline DataElement(const ProxyType& buffer) : m_Storage(buffer) @@ -167,12 +184,22 @@ namespace Core { } inline DataElement(const ProxyType& buffer, const uint64_t offset, const uint64_t size = 0) : m_Storage(buffer) - , m_Buffer(&(buffer->Buffer())[offset]) + , m_Buffer(buffer->Size() > offset ? &(buffer->Buffer())[offset] : nullptr) , m_Offset(offset) - , m_Size(buffer->Size() - offset) + , m_Size(buffer->Size() > offset ? buffer->Size() - offset : 0) , m_MaxSize(buffer->Size()) { ASSERT(buffer.IsValid()); + ASSERT(m_Buffer != nullptr); + ASSERT( !offset + || offset < buffer->Size() + ); + ASSERT( !offset + || offset < size + ); + ASSERT( !offset + || offset < (m_MaxSize - size) + ); // We only allow a smaller size... if (size != 0) { @@ -206,30 +233,59 @@ namespace Core { inline DataElement(const DataElement& RHS, const uint64_t offset, const uint64_t size = 0) : m_Storage(RHS.m_Storage) - , m_Buffer(&(RHS.m_Buffer[offset])) + , m_Buffer(RHS.Size() > offset ? &(RHS.m_Buffer[offset]) : nullptr) , m_Offset(RHS.m_Offset + offset) , m_Size(RHS.m_Size - offset) , m_MaxSize(RHS.m_MaxSize) { + ASSERT(RHS.IsValid()); + ASSERT(m_Buffer != nullptr); + ASSERT(RHS.m_MaxSize <= m_MaxSize); + ASSERT( !offset + || offset < size + ); + ASSERT( !offset + || offset < RHS.Size() + ); + ASSERT(m_Size <= m_MaxSize); + ASSERT( !m_Offset + || m_Offset < m_Size + ); + ASSERT(m_Size <= m_MaxSize); + ASSERT( std::numeric_limits::max() / 2 > offset + && std::numeric_limits::max() / 2 > RHS.m_Offset + ); + if (size != 0) { m_Size = size; } - - ASSERT(offset + size <= RHS.m_Size); } inline DataElement(DataElement&& move, const uint64_t offset, const uint64_t size = 0) : m_Storage(std::move(move.m_Storage)) - , m_Buffer(&(move.m_Buffer[offset])) + , m_Buffer(move.m_Size > offset ? &(move.m_Buffer[offset]) : nullptr) , m_Offset(move.m_Offset + offset) , m_Size(move.m_Size - offset) , m_MaxSize(move.m_MaxSize) { ASSERT(this != &move); + ASSERT(move.m_MaxSize <= m_MaxSize); + ASSERT( !offset + || offset < move.m_Size + ); + ASSERT( !offset + || offset < size + ); + ASSERT( !m_Offset + || m_Offset < m_Size + ); + ASSERT(m_Size <= m_MaxSize); + ASSERT( std::numeric_limits::max() / 2 > offset + && std::numeric_limits::max() / 2 > move.m_Offset + ); if (size != 0) { m_Size = size; } - ASSERT(offset + size <= move.m_Size); move.m_Buffer = nullptr; move.m_Offset = 0; @@ -279,6 +335,7 @@ namespace Core { { if (m_Buffer != nullptr) { uint8_t* newPointer = reinterpret_cast(Alignment(sizeof(TYPE), m_Buffer)); + ASSERT(newPointer >= m_Buffer); uint8_t adjust(static_cast(newPointer - m_Buffer)); m_Buffer = newPointer; m_Size = (adjust < m_Size ? (m_Size - adjust) : 0); @@ -355,10 +412,20 @@ namespace Core { { ASSERT(IsValid()); - ASSERT((size == NUMBER_MAX_UNSIGNED(uint64_t)) || ((offset + size) < m_Size)); if (size == NUMBER_MAX_UNSIGNED(uint64_t)) { + ASSERT( !offset + || offset < m_Size + ); + ASSERT(m_Size <= m_MaxSize); + ::memset(&m_Buffer[offset], value, static_cast(m_Size - offset)); } else { + ASSERT(size < m_Size); + ASSERT( !offset + || offset < size + ); + ASSERT(size <= m_MaxSize); + ::memset(&m_Buffer[offset], value, static_cast(size)); } } @@ -413,11 +480,18 @@ namespace Core { { ASSERT(IsValid()); ASSERT(RHS.IsValid()); + ASSERT(RHS.m_Size <= m_MaxSize); + ASSERT( !offset + || offset < m_Size + ); + ASSERT( std::numeric_limits::max() / 2 > offset + && std::numeric_limits::max() / 2 > RHS.m_Size + ); bool copied = false; // see if we need to resize - if ((RHS.Size() + offset) > m_Size) { + if (RHS.Size() > (m_Size - offset)) { if ((this != &RHS) && (Size(offset + RHS.m_Size) == true)) { ::memcpy(&(m_Buffer[offset]), RHS.m_Buffer, static_cast(RHS.m_Size)); m_Size = offset + RHS.m_Size; @@ -444,7 +518,11 @@ namespace Core { uint64_t index = offset; // Only on package level allowed to pass the boundaries!!! - ASSERT(offset < m_Size); + ASSERT(size <= m_Size); + ASSERT(size >= 1); + ASSERT( !offset + || offset < m_Size + ); // If the search object is larger than the buffer, we will not find it ;-) while ((found == false) && ((index + size) < m_Size)) { @@ -520,7 +598,9 @@ namespace Core { inline TYPENAME GetNumber(const uint64_t offset) const { // Only on package level allowed to pass the boundaries!!! - ASSERT((offset + sizeof(TYPENAME)) <= m_Size); + ASSERT( !offset + || offset <= (m_Size - sizeof(TYPENAME)) + ); TYPENAME result; @@ -585,7 +665,7 @@ namespace Core { { // Bit numbers are not allowed over package boundaries. Make sure it fits in // this element. - ASSERT((offset + ((bitIndex + count) / 8)) <= m_Size); + ASSERT(offset < (m_Size - ((bitIndex + count) / 8))); // Make sure that no more bits are requetsed than fit... ASSERT(count <= (sizeof(TYPENAME) << 3)); @@ -622,17 +702,22 @@ namespace Core { ASSERT(buffer != nullptr); // Check if we cross a boundary for the read.. - ASSERT((offset + size) <= m_Size); + ASSERT(size <= m_Size); + ASSERT( !offset + || offset < size + ); // Nope, one plain copy !!! - ::memcpy(buffer, &m_Buffer[offset], size); + ::memmove(buffer, &m_Buffer[offset], size); } template void SetNumber(const uint64_t offset, const TYPENAME number) { // Only on package level allowed to pass the boundaries!!! - ASSERT((offset + sizeof(TYPENAME)) <= m_Size); + ASSERT( !offset + || offset <= (m_Size - sizeof(TYPENAME)) + ); if (sizeof(TYPENAME) == 1) { m_Buffer[offset] = static_cast(number); @@ -693,7 +778,7 @@ namespace Core { { // Bit numbers are not allowed over package boundaries. Make sure it fits in // this element. - ASSERT((offset + ((bitIndex + count) / 8)) <= m_Size); + ASSERT(offset < (m_Size - ((bitIndex + count) / 8))); // Make sure that no more bits are requetsed than fit... ASSERT(count <= (sizeof(TYPENAME) << 3)); @@ -742,7 +827,10 @@ namespace Core { ASSERT(buffer != nullptr); // Check if we cross a boundary for the write.. - ASSERT((offset + size) <= m_Size); + ASSERT(size <= m_Size); + ASSERT( !offset + || offset < size + ); // Nope, one plain copy !!! ::memmove(&m_Buffer[offset], buffer, size); @@ -753,10 +841,14 @@ namespace Core { if (size == NUMBER_MAX_UNSIGNED(uint64_t)) { // Reset the size to the maxSize... m_Size = m_MaxSize - m_Offset; - } else if ((size + m_Offset) <= m_MaxSize) { + } else if (m_Offset <= (m_MaxSize - size)) { // It fits the allocated buffer, accept and reduce.. m_Size = size; } else { + ASSERT( std::numeric_limits::max() / 2 > size + && std::numeric_limits::max() / 2 > m_Offset + ); + Reallocation(size + m_Offset); } @@ -809,13 +901,27 @@ namespace Core { { // Don't set the size bigger than the cummulated one!!! ASSERT(offset + size < RHS.LinkedSize()); + ASSERT(size <= RHS.LinkedSize()); + ASSERT( !offset + || offset < (RHS.LinkedSize() - size) + ); + ASSERT( std::numeric_limits::max() / 2 > offset + && std::numeric_limits::max() / 2 > size + ); } inline LinkedDataElement(LinkedDataElement&& move, const uint64_t offset = 0, const uint64_t size = 0) noexcept : DataElement(move, offset, (offset + size > move.Size() ? 0 : size)) , m_Next(move.m_Next) { + ASSERT(size <= move.LinkedSize()); + ASSERT( !offset + || offset < (move.LinkedSize() - size) + ); + ASSERT( std::numeric_limits::max() / 2 > offset + && std::numeric_limits::max() / 2 > size + ); + // Don't set the size bigger than the cummulated one!!! - ASSERT(offset + size < move.LinkedSize()); move.m_Next = nullptr; } inline LinkedDataElement(const uint64_t Size, uint8_t* Buffer, LinkedDataElement* Enclosure) @@ -884,6 +990,7 @@ namespace Core { if ((result == NUMBER_MAX_UNSIGNED(uint64_t)) && (m_Next != nullptr)) { bool found = false; + ASSERT(sizeof(TYPENAME) <= m_Size); result = m_Size - sizeof(TYPENAME) + 1; uint64_t index = offset; @@ -900,7 +1007,10 @@ namespace Core { inline TYPENAME GetNumber(const uint64_t offset) const { // Only on package level allowed to pass the boundaries!!! - ASSERT(offset + sizeof(TYPENAME) < m_Size); + ASSERT(sizeof(TYPENAME) <= m_Size); + ASSERT( !offset + || offset < m_Size + ); TYPENAME result; @@ -919,7 +1029,10 @@ namespace Core { inline void SetNumber(const uint64_t offset, const TYPENAME number) { // Only on package level allowed to pass the boundaries!!! - ASSERT(offset + sizeof(TYPENAME) < m_Size); + ASSERT(sizeof(TYPENAME) <= m_Size); + ASSERT( !offset + || offset < m_Size + ); if (sizeof(TYPENAME) == 1) { m_Buffer[offset] = number; @@ -961,11 +1074,13 @@ namespace Core { inline uint64_t Size() const { + ASSERT(m_Offset < m_Buffer.Size()); return (m_Offset - m_Buffer.Size()); } inline void SkipBytes(const unsigned int bytes) { + ASSERT((std::numeric_limits::max() - bytes) >= m_Offset); m_Offset += bytes; } @@ -982,10 +1097,12 @@ namespace Core { inline TYPENAME GetNumber() const { // Only on element level allowed to extract !! - ASSERT((m_Offset + sizeof(TYPENAME)) < m_Buffer.Size()); + ASSERT(sizeof(TYPENAME) <= m_Buffer.Size()); + ASSERT(m_Offset < (m_Buffer.Size() - sizeof(TYPENAME))); TYPENAME result = m_Buffer.GetNumber(m_Offset); + ASSERT((std::numeric_limits::max() - sizeof(TYPENAME)) >= m_Offset); m_Offset += sizeof(TYPENAME); return (result); @@ -994,10 +1111,12 @@ namespace Core { void GetBuffer(const unsigned int size, uint8_t* buffer) const { // Only on element level allowed to extract !! - ASSERT((m_Offset + size) < m_Buffer.Size()); + ASSERT(size <= m_Buffer.Size()); + ASSERT(m_Offset < (m_Buffer.Size() - size)); m_Buffer.GetBuffer(m_Offset, size, buffer); + ASSERT((std::numeric_limits::max() - size) >= m_Offset); m_Offset += size; } @@ -1005,7 +1124,8 @@ namespace Core { inline void SetNumber(const TYPENAME number) { // Only on element level allowed to set !! - ASSERT((m_Offset + sizeof(TYPENAME)) < m_Buffer.Size()); + ASSERT(sizeof(TYPENAME) <= m_Buffer.Size()); + ASSERT(m_Offset < (m_Buffer.Size() - sizeof(TYPENAME))); m_Buffer.SetNumber(m_Offset, number); m_Offset += sizeof(TYPENAME); @@ -1014,7 +1134,8 @@ namespace Core { void SetBuffer(const unsigned int size, const uint8_t* buffer) { // Only on element level allowed to set !! - ASSERT((m_Offset + size) < m_Buffer.Size()); + ASSERT(size <= m_Buffer.Size()); + ASSERT(m_Offset < (m_Buffer.Size() - size)); m_Buffer.SetBuffer(m_Offset, size, buffer); From f94444d21fc30079000cbe99c3d3a709846854f8 Mon Sep 17 00:00:00 2001 From: msieben <4319079+msieben@users.noreply.github.com> Date: Mon, 8 Jul 2024 09:25:50 +0000 Subject: [PATCH 8/8] [core/DataElement] : requested review changes --- Source/core/DataElement.h | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/Source/core/DataElement.h b/Source/core/DataElement.h index 3f33bb2f3..4714dbbcc 100644 --- a/Source/core/DataElement.h +++ b/Source/core/DataElement.h @@ -184,9 +184,9 @@ namespace Core { } inline DataElement(const ProxyType& buffer, const uint64_t offset, const uint64_t size = 0) : m_Storage(buffer) - , m_Buffer(buffer->Size() > offset ? &(buffer->Buffer())[offset] : nullptr) + , m_Buffer(&(buffer->Buffer())[offset]) , m_Offset(offset) - , m_Size(buffer->Size() > offset ? buffer->Size() - offset : 0) + , m_Size(buffer->Size() - offset) , m_MaxSize(buffer->Size()) { ASSERT(buffer.IsValid()); @@ -233,7 +233,7 @@ namespace Core { inline DataElement(const DataElement& RHS, const uint64_t offset, const uint64_t size = 0) : m_Storage(RHS.m_Storage) - , m_Buffer(RHS.Size() > offset ? &(RHS.m_Buffer[offset]) : nullptr) + , m_Buffer(&(RHS.m_Buffer[offset])) , m_Offset(RHS.m_Offset + offset) , m_Size(RHS.m_Size - offset) , m_MaxSize(RHS.m_MaxSize) @@ -262,7 +262,7 @@ namespace Core { } inline DataElement(DataElement&& move, const uint64_t offset, const uint64_t size = 0) : m_Storage(std::move(move.m_Storage)) - , m_Buffer(move.m_Size > offset ? &(move.m_Buffer[offset]) : nullptr) + , m_Buffer(&(move.m_Buffer[offset])) , m_Offset(move.m_Offset + offset) , m_Size(move.m_Size - offset) , m_MaxSize(move.m_MaxSize)