valid mask bugfixes

This commit is contained in:
Robin Müller 2020-02-16 21:04:17 +01:00
parent 1001c1d48b
commit 6ab07aeb19

View File

@ -6,6 +6,9 @@
*/ */
#include <framework/datapool/PoolRawAccessHelper.h> #include <framework/datapool/PoolRawAccessHelper.h>
#include <cmath>
#include <framework/datapool/DataSet.h> #include <framework/datapool/DataSet.h>
PoolRawAccessHelper::PoolRawAccessHelper(uint32_t * poolIdBuffer_, PoolRawAccessHelper::PoolRawAccessHelper(uint32_t * poolIdBuffer_,
@ -41,7 +44,7 @@ ReturnValue_t PoolRawAccessHelper::serializeWithValidityMask(uint8_t ** buffer,
ReturnValue_t result; ReturnValue_t result;
SerializationArgs argStruct = {buffer, size, max_size, bigEndian}; SerializationArgs argStruct = {buffer, size, max_size, bigEndian};
int32_t remainingParametersSize = numberOfParameters * 4; int32_t remainingParametersSize = numberOfParameters * 4;
uint8_t validityMaskSize = numberOfParameters/8; uint8_t validityMaskSize = ceil((float)numberOfParameters/8.0);
uint8_t validityMask[validityMaskSize]; uint8_t validityMask[validityMaskSize];
memset(validityMask,0, validityMaskSize); memset(validityMask,0, validityMaskSize);
for(uint8_t count = 0; count < numberOfParameters; count++) { for(uint8_t count = 0; count < numberOfParameters; count++) {
@ -55,7 +58,8 @@ ReturnValue_t PoolRawAccessHelper::serializeWithValidityMask(uint8_t ** buffer,
debug << "Pool Raw Access: Remaining parameters size not 0 !" << std::endl; debug << "Pool Raw Access: Remaining parameters size not 0 !" << std::endl;
result = RETURN_FAILED; result = RETURN_FAILED;
} }
memcpy(*buffer + *size, validityMask, validityMaskSize);
memcpy(*argStruct.buffer, validityMask, validityMaskSize);
*size += validityMaskSize; *size += validityMaskSize;
validBufferIndex = 1; validBufferIndex = 1;
validBufferIndexBit = 0; validBufferIndexBit = 0;
@ -114,6 +118,7 @@ ReturnValue_t PoolRawAccessHelper::handlePoolEntrySerialization(uint32_t current
if(currentPoolRawAccess.isValid()) { if(currentPoolRawAccess.isValid()) {
handleMaskModification(validityMask); handleMaskModification(validityMask);
} }
validBufferIndexBit ++;
} }
result = currentDataSet.serialize(argStruct.buffer, argStruct.size, result = currentDataSet.serialize(argStruct.buffer, argStruct.size,
@ -146,7 +151,6 @@ ReturnValue_t PoolRawAccessHelper::checkRemainingSize(PoolRawAccess * currentPoo
void PoolRawAccessHelper::handleMaskModification(uint8_t * validityMask) { void PoolRawAccessHelper::handleMaskModification(uint8_t * validityMask) {
validityMask[validBufferIndex] = validityMask[validBufferIndex] =
bitSetter(validityMask[validBufferIndex], validBufferIndexBit, true); bitSetter(validityMask[validBufferIndex], validBufferIndexBit, true);
validBufferIndexBit ++;
if(validBufferIndexBit == 8) { if(validBufferIndexBit == 8) {
validBufferIndex ++; validBufferIndex ++;
validBufferIndexBit = 1; validBufferIndexBit = 1;
@ -159,6 +163,6 @@ uint8_t PoolRawAccessHelper::bitSetter(uint8_t byte, uint8_t position, bool valu
return byte; return byte;
} }
uint8_t shiftNumber = position + (6 - 2 * (position - 1)); uint8_t shiftNumber = position + (6 - 2 * (position - 1));
byte = (byte | value) << shiftNumber; byte |= 1UL << shiftNumber;
return byte; return byte;
} }