Clean up some buffer allocations
While investigating some memory corruption, I found two bugs: the
backing store the SMBIOS data gets loaded into was left uninitialized,
and the buffer used for the version check was allocated using a pointer
where a size should have been used instead.
Tested: While I can not say for sure this solves the corruption, it
seems to make it much less frequent, during my testing. I am not saying
it is gone, but I can no longer reproduce it.
Change-Id: Ic5d28a0d55cfb179c1bd73e95df2a6bf119f6d8c
Signed-off-by: Josh Lehan <krellan@google.com>
diff --git a/include/mdrv2.hpp b/include/mdrv2.hpp
index 4e431f4..5516fac 100644
--- a/include/mdrv2.hpp
+++ b/include/mdrv2.hpp
@@ -177,7 +177,7 @@
const std::array<uint8_t, 16> smbiosTableId{
40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 0x42};
- uint8_t smbiosTableStorage[smbiosTableStorageSize];
+ uint8_t smbiosTableStorage[smbiosTableStorageSize] = {};
bool smbiosIsUpdating(uint8_t index);
bool smbiosIsAvailForUpdate(uint8_t index);
diff --git a/src/mdrv2.cpp b/src/mdrv2.cpp
index 73cc306..383709b 100644
--- a/src/mdrv2.cpp
+++ b/src/mdrv2.cpp
@@ -697,7 +697,8 @@
{
const std::string anchorString21 = "_SM_";
const std::string anchorString30 = "_SM3_";
- std::string buffer(dataIn, dataIn + smbiosTableStorageSize);
+ std::string buffer(reinterpret_cast<const char*>(dataIn),
+ smbiosTableStorageSize);
auto it = std::search(std::begin(buffer), std::end(buffer),
std::begin(anchorString21), std::end(anchorString21));