updated datapool files
This commit is contained in:
parent
8d3ac33b0e
commit
9fd5ef0194
@ -31,22 +31,16 @@ ReturnValue_t DataSetBase::registerVariable(
|
|||||||
return HasReturnvaluesIF::RETURN_OK;
|
return HasReturnvaluesIF::RETURN_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
ReturnValue_t DataSetBase::read() {
|
ReturnValue_t DataSetBase::read(uint32_t lockTimeout) {
|
||||||
ReturnValue_t result = HasReturnvaluesIF::RETURN_OK;
|
ReturnValue_t result = HasReturnvaluesIF::RETURN_OK;
|
||||||
if (state == States::DATA_SET_UNINITIALISED) {
|
if (state == States::DATA_SET_UNINITIALISED) {
|
||||||
lockDataPool();
|
lockDataPool(lockTimeout);
|
||||||
for (uint16_t count = 0; count < fillCount; count++) {
|
for (uint16_t count = 0; count < fillCount; count++) {
|
||||||
if (registeredVariables[count]->getReadWriteMode()
|
ReturnValue_t result = readVariable(count);
|
||||||
!= PoolVariableIF::VAR_WRITE
|
if(result != RETURN_OK) {
|
||||||
&& registeredVariables[count]->getDataPoolId()
|
|
||||||
!= PoolVariableIF::NO_PARAMETER) {
|
|
||||||
ReturnValue_t status = registeredVariables[count]->read();
|
|
||||||
if (status != HasReturnvaluesIF::RETURN_OK) {
|
|
||||||
result = INVALID_PARAMETER_DEFINITION;
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
state = States::DATA_SET_WAS_READ;
|
state = States::DATA_SET_WAS_READ;
|
||||||
unlockDataPool();
|
unlockDataPool();
|
||||||
}
|
}
|
||||||
@ -58,47 +52,53 @@ ReturnValue_t DataSetBase::read() {
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
ReturnValue_t DataSetBase::commit() {
|
ReturnValue_t DataSetBase::readVariable(uint16_t count) {
|
||||||
|
ReturnValue_t result = DataSetIF::INVALID_PARAMETER_DEFINITION;
|
||||||
|
// These checks are often performed by the respective
|
||||||
|
// variable implementation too, but I guess a double check does not hurt.
|
||||||
|
if (registeredVariables[count]->getReadWriteMode() !=
|
||||||
|
PoolVariableIF::VAR_WRITE and
|
||||||
|
registeredVariables[count]->getDataPoolId()
|
||||||
|
!= PoolVariableIF::NO_PARAMETER)
|
||||||
|
{
|
||||||
|
result = registeredVariables[count]->readWithoutLock();
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
ReturnValue_t DataSetBase::commit(uint32_t lockTimeout) {
|
||||||
if (state == States::DATA_SET_WAS_READ) {
|
if (state == States::DATA_SET_WAS_READ) {
|
||||||
handleAlreadyReadDatasetCommit();
|
handleAlreadyReadDatasetCommit(lockTimeout);
|
||||||
return HasReturnvaluesIF::RETURN_OK;
|
return HasReturnvaluesIF::RETURN_OK;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
return handleUnreadDatasetCommit();
|
return handleUnreadDatasetCommit(lockTimeout);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
ReturnValue_t DataSetBase::lockDataPool() {
|
void DataSetBase::handleAlreadyReadDatasetCommit(uint32_t lockTimeout) {
|
||||||
return HasReturnvaluesIF::RETURN_OK;
|
lockDataPool(lockTimeout);
|
||||||
}
|
|
||||||
|
|
||||||
ReturnValue_t DataSetBase::unlockDataPool() {
|
|
||||||
return HasReturnvaluesIF::RETURN_FAILED;
|
|
||||||
}
|
|
||||||
|
|
||||||
void DataSetBase::handleAlreadyReadDatasetCommit() {
|
|
||||||
lockDataPool();
|
|
||||||
for (uint16_t count = 0; count < fillCount; count++) {
|
for (uint16_t count = 0; count < fillCount; count++) {
|
||||||
if (registeredVariables[count]->getReadWriteMode()
|
if (registeredVariables[count]->getReadWriteMode()
|
||||||
!= PoolVariableIF::VAR_READ
|
!= PoolVariableIF::VAR_READ
|
||||||
&& registeredVariables[count]->getDataPoolId()
|
&& registeredVariables[count]->getDataPoolId()
|
||||||
!= PoolVariableIF::NO_PARAMETER) {
|
!= PoolVariableIF::NO_PARAMETER) {
|
||||||
registeredVariables[count]->commit();
|
registeredVariables[count]->commitWithoutLock();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
state = States::DATA_SET_UNINITIALISED;
|
state = States::DATA_SET_UNINITIALISED;
|
||||||
unlockDataPool();
|
unlockDataPool();
|
||||||
}
|
}
|
||||||
|
|
||||||
ReturnValue_t DataSetBase::handleUnreadDatasetCommit() {
|
ReturnValue_t DataSetBase::handleUnreadDatasetCommit(uint32_t lockTimeout) {
|
||||||
ReturnValue_t result = HasReturnvaluesIF::RETURN_OK;
|
ReturnValue_t result = HasReturnvaluesIF::RETURN_OK;
|
||||||
lockDataPool();
|
lockDataPool(lockTimeout);
|
||||||
for (uint16_t count = 0; count < fillCount; count++) {
|
for (uint16_t count = 0; count < fillCount; count++) {
|
||||||
if (registeredVariables[count]->getReadWriteMode()
|
if (registeredVariables[count]->getReadWriteMode()
|
||||||
== PoolVariableIF::VAR_WRITE
|
== PoolVariableIF::VAR_WRITE
|
||||||
&& registeredVariables[count]->getDataPoolId()
|
&& registeredVariables[count]->getDataPoolId()
|
||||||
!= PoolVariableIF::NO_PARAMETER) {
|
!= PoolVariableIF::NO_PARAMETER) {
|
||||||
registeredVariables[count]->commit();
|
registeredVariables[count]->commitWithoutLock();
|
||||||
} else if (registeredVariables[count]->getDataPoolId()
|
} else if (registeredVariables[count]->getDataPoolId()
|
||||||
!= PoolVariableIF::NO_PARAMETER) {
|
!= PoolVariableIF::NO_PARAMETER) {
|
||||||
if (result != COMMITING_WITHOUT_READING) {
|
if (result != COMMITING_WITHOUT_READING) {
|
||||||
@ -113,6 +113,15 @@ ReturnValue_t DataSetBase::handleUnreadDatasetCommit() {
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
ReturnValue_t DataSetBase::lockDataPool(uint32_t timeoutMs) {
|
||||||
|
return HasReturnvaluesIF::RETURN_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
ReturnValue_t DataSetBase::unlockDataPool() {
|
||||||
|
return HasReturnvaluesIF::RETURN_OK;
|
||||||
|
}
|
||||||
|
|
||||||
ReturnValue_t DataSetBase::serialize(uint8_t** buffer, size_t* size,
|
ReturnValue_t DataSetBase::serialize(uint8_t** buffer, size_t* size,
|
||||||
const size_t maxSize, bool bigEndian) const {
|
const size_t maxSize, bool bigEndian) const {
|
||||||
ReturnValue_t result = HasReturnvaluesIF::RETURN_FAILED;
|
ReturnValue_t result = HasReturnvaluesIF::RETURN_FAILED;
|
||||||
|
@ -2,6 +2,7 @@
|
|||||||
#define FRAMEWORK_DATAPOOL_DATASETBASE_H_
|
#define FRAMEWORK_DATAPOOL_DATASETBASE_H_
|
||||||
#include <framework/datapool/DataSetIF.h>
|
#include <framework/datapool/DataSetIF.h>
|
||||||
#include <framework/datapool/PoolVariableIF.h>
|
#include <framework/datapool/PoolVariableIF.h>
|
||||||
|
#include <framework/ipc/MutexIF.h>
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief The DataSetBase class manages a set of locally checked out variables.
|
* @brief The DataSetBase class manages a set of locally checked out variables.
|
||||||
@ -21,7 +22,8 @@
|
|||||||
* of the set, the DataSet class automatically sets the valid flag in the
|
* of the set, the DataSet class automatically sets the valid flag in the
|
||||||
* data pool to invalid (without) changing the variable's value.
|
* data pool to invalid (without) changing the variable's value.
|
||||||
*
|
*
|
||||||
* The base class lockDataPo
|
* The base class lockDataPool und unlockDataPool implementation are empty
|
||||||
|
* and should be implemented to protect the underlying pool type.
|
||||||
* @author Bastian Baetz
|
* @author Bastian Baetz
|
||||||
* @ingroup data_pool
|
* @ingroup data_pool
|
||||||
*/
|
*/
|
||||||
@ -49,14 +51,15 @@ public:
|
|||||||
*
|
*
|
||||||
* The data pool is locked during the whole read operation and
|
* The data pool is locked during the whole read operation and
|
||||||
* freed afterwards.The state changes to "was written" after this operation.
|
* freed afterwards.The state changes to "was written" after this operation.
|
||||||
* @return - @c RETURN_OK if all variables were read successfully.
|
* @return
|
||||||
|
* - @c RETURN_OK if all variables were read successfully.
|
||||||
* - @c INVALID_PARAMETER_DEFINITION if PID, size or type of the
|
* - @c INVALID_PARAMETER_DEFINITION if PID, size or type of the
|
||||||
* requested variable is invalid.
|
* requested variable is invalid.
|
||||||
* - @c SET_WAS_ALREADY_READ if read() is called twice without calling
|
* - @c SET_WAS_ALREADY_READ if read() is called twice without calling
|
||||||
* commit() in between
|
* commit() in between
|
||||||
*/
|
*/
|
||||||
virtual ReturnValue_t read();
|
virtual ReturnValue_t read(uint32_t lockTimeout =
|
||||||
|
MutexIF::BLOCKING) override;
|
||||||
/**
|
/**
|
||||||
* @brief The commit call initializes writing back the registered variables.
|
* @brief The commit call initializes writing back the registered variables.
|
||||||
* @details
|
* @details
|
||||||
@ -67,23 +70,30 @@ public:
|
|||||||
* The data pool is locked during the whole commit operation and
|
* The data pool is locked during the whole commit operation and
|
||||||
* freed afterwards. The state changes to "was committed" after this operation.
|
* freed afterwards. The state changes to "was committed" after this operation.
|
||||||
*
|
*
|
||||||
* If the set does contain at least one variable which is not write-only commit()
|
* If the set does contain at least one variable which is not write-only
|
||||||
* can only be called after read(). If the set only contains variables which are
|
* commit() can only be called after read(). If the set only contains
|
||||||
* write only, commit() can be called without a preceding read() call.
|
* variables which are write only, commit() can be called without a
|
||||||
|
* preceding read() call.
|
||||||
* @return - @c RETURN_OK if all variables were read successfully.
|
* @return - @c RETURN_OK if all variables were read successfully.
|
||||||
* - @c COMMITING_WITHOUT_READING if set was not read yet and
|
* - @c COMMITING_WITHOUT_READING if set was not read yet and
|
||||||
* contains non write-only variables
|
* contains non write-only variables
|
||||||
*/
|
*/
|
||||||
virtual ReturnValue_t commit();
|
virtual ReturnValue_t commit(uint32_t lockTimeout =
|
||||||
|
MutexIF::BLOCKING) override;
|
||||||
|
|
||||||
/* DataSetIF implementation */
|
/**
|
||||||
|
* Register the passed pool variable instance into the data set.
|
||||||
|
* @param variable
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
virtual ReturnValue_t registerVariable( PoolVariableIF* variable) override;
|
virtual ReturnValue_t registerVariable( PoolVariableIF* variable) override;
|
||||||
/**
|
/**
|
||||||
* Provides the means to lock the underlying data structure to ensure
|
* Provides the means to lock the underlying data structure to ensure
|
||||||
* thread-safety. Default implementation is empty
|
* thread-safety. Default implementation is empty
|
||||||
* @return Always returns -@c RETURN_OK
|
* @return Always returns -@c RETURN_OK
|
||||||
*/
|
*/
|
||||||
virtual ReturnValue_t lockDataPool() override;
|
virtual ReturnValue_t lockDataPool(uint32_t timeoutMs =
|
||||||
|
MutexIF::BLOCKING) override;
|
||||||
/**
|
/**
|
||||||
* Provides the means to unlock the underlying data structure to ensure
|
* Provides the means to unlock the underlying data structure to ensure
|
||||||
* thread-safety. Default implementation is empty
|
* thread-safety. Default implementation is empty
|
||||||
@ -102,8 +112,8 @@ public:
|
|||||||
//!< This definition sets the maximum number of variables to
|
//!< This definition sets the maximum number of variables to
|
||||||
//! register in one DataSet.
|
//! register in one DataSet.
|
||||||
static const uint8_t DATA_SET_MAX_SIZE = 63;
|
static const uint8_t DATA_SET_MAX_SIZE = 63;
|
||||||
protected:
|
|
||||||
|
|
||||||
|
protected:
|
||||||
/**
|
/**
|
||||||
* @brief The fill_count attribute ensures that the variables
|
* @brief The fill_count attribute ensures that the variables
|
||||||
* register in the correct array position and that the maximum
|
* register in the correct array position and that the maximum
|
||||||
@ -128,8 +138,10 @@ protected:
|
|||||||
*/
|
*/
|
||||||
PoolVariableIF* registeredVariables[DATA_SET_MAX_SIZE] = { };
|
PoolVariableIF* registeredVariables[DATA_SET_MAX_SIZE] = { };
|
||||||
|
|
||||||
void handleAlreadyReadDatasetCommit();
|
private:
|
||||||
ReturnValue_t handleUnreadDatasetCommit();
|
ReturnValue_t readVariable(uint16_t count);
|
||||||
|
void handleAlreadyReadDatasetCommit(uint32_t lockTimeout);
|
||||||
|
ReturnValue_t handleUnreadDatasetCommit(uint32_t lockTimeout);
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif /* FRAMEWORK_DATAPOOL_DATASETBASE_H_ */
|
#endif /* FRAMEWORK_DATAPOOL_DATASETBASE_H_ */
|
||||||
|
@ -2,6 +2,7 @@
|
|||||||
#define DATASETIF_H_
|
#define DATASETIF_H_
|
||||||
|
|
||||||
#include <framework/returnvalues/HasReturnvaluesIF.h>
|
#include <framework/returnvalues/HasReturnvaluesIF.h>
|
||||||
|
#include <framework/timemanager/Clock.h>
|
||||||
class PoolVariableIF;
|
class PoolVariableIF;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -33,6 +34,8 @@ public:
|
|||||||
*/
|
*/
|
||||||
virtual ~DataSetIF() {}
|
virtual ~DataSetIF() {}
|
||||||
|
|
||||||
|
virtual ReturnValue_t read(uint32_t lockTimeout) = 0;
|
||||||
|
virtual ReturnValue_t commit(uint32_t lockTimeout) = 0;
|
||||||
/**
|
/**
|
||||||
* @brief This operation provides a method to register local data pool
|
* @brief This operation provides a method to register local data pool
|
||||||
* variables to register in a data set by passing itself
|
* variables to register in a data set by passing itself
|
||||||
@ -40,13 +43,14 @@ public:
|
|||||||
*/
|
*/
|
||||||
virtual ReturnValue_t registerVariable(PoolVariableIF* variable) = 0;
|
virtual ReturnValue_t registerVariable(PoolVariableIF* variable) = 0;
|
||||||
|
|
||||||
|
private:
|
||||||
/**
|
/**
|
||||||
* @brief Most underlying data structures will have a pool like structure
|
* @brief Most underlying data structures will have a pool like structure
|
||||||
* and will require a lock and unlock mechanism to ensure
|
* and will require a lock and unlock mechanism to ensure
|
||||||
* thread-safety
|
* thread-safety
|
||||||
* @return Lock operation result
|
* @return Lock operation result
|
||||||
*/
|
*/
|
||||||
virtual ReturnValue_t lockDataPool() = 0;
|
virtual ReturnValue_t lockDataPool(uint32_t timeoutMs) = 0;
|
||||||
/**
|
/**
|
||||||
* @brief Unlock call corresponding to the lock call.
|
* @brief Unlock call corresponding to the lock call.
|
||||||
* @return Unlock operation result
|
* @return Unlock operation result
|
||||||
|
@ -21,18 +21,10 @@ class PoolVariableIF : public SerializeIF {
|
|||||||
friend class DataSetBase;
|
friend class DataSetBase;
|
||||||
friend class GlobDataSet;
|
friend class GlobDataSet;
|
||||||
friend class LocalDataSet;
|
friend class LocalDataSet;
|
||||||
protected:
|
|
||||||
/**
|
|
||||||
* @brief The commit call shall write back a newly calculated local
|
|
||||||
* value to the data pool.
|
|
||||||
*/
|
|
||||||
virtual ReturnValue_t commit() = 0;
|
|
||||||
/**
|
|
||||||
* @brief The read call shall read the value of this parameter from
|
|
||||||
* the data pool and store the content locally.
|
|
||||||
*/
|
|
||||||
virtual ReturnValue_t read() = 0;
|
|
||||||
public:
|
public:
|
||||||
|
static constexpr uint8_t INTERFACE_ID = CLASS_ID::POOL_VARIABLE_IF;
|
||||||
|
static constexpr ReturnValue_t INVALID_READ_WRITE_MODE = MAKE_RETURN_CODE(0xA0);
|
||||||
|
|
||||||
static constexpr bool VALID = 1;
|
static constexpr bool VALID = 1;
|
||||||
static constexpr bool INVALID = 0;
|
static constexpr bool INVALID = 0;
|
||||||
static constexpr uint32_t NO_PARAMETER = 0;
|
static constexpr uint32_t NO_PARAMETER = 0;
|
||||||
@ -61,9 +53,43 @@ public:
|
|||||||
/**
|
/**
|
||||||
* @brief With this call, the valid information of the variable is set.
|
* @brief With this call, the valid information of the variable is set.
|
||||||
*/
|
*/
|
||||||
// why not just use a boolean here?
|
virtual void setValid(bool validity) = 0;
|
||||||
virtual void setValid(uint8_t validity) = 0;
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief The commit call shall write back a newly calculated local
|
||||||
|
* value to the data pool.
|
||||||
|
* @details
|
||||||
|
* It is assumed that these calls are implemented in a thread-safe manner!
|
||||||
|
*/
|
||||||
|
virtual ReturnValue_t commit(uint32_t lockTimeout) = 0;
|
||||||
|
/**
|
||||||
|
* @brief The read call shall read the value of this parameter from
|
||||||
|
* the data pool and store the content locally.
|
||||||
|
* @details
|
||||||
|
* It is assumbed that these calls are implemented in a thread-safe manner!
|
||||||
|
*/
|
||||||
|
virtual ReturnValue_t read(uint32_t lockTimeout) = 0;
|
||||||
|
|
||||||
|
protected:
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Same as commit with the difference that comitting will be
|
||||||
|
* performed without a lock
|
||||||
|
* @return
|
||||||
|
* This can be used if the lock protection is handled externally
|
||||||
|
* to avoid the overhead of locking and unlocking consecutively.
|
||||||
|
* Declared protected to avoid free public usage.
|
||||||
|
*/
|
||||||
|
virtual ReturnValue_t readWithoutLock() = 0;
|
||||||
|
/**
|
||||||
|
* @brief Same as commit with the difference that comitting will be
|
||||||
|
* performed without a lock
|
||||||
|
* @return
|
||||||
|
* This can be used if the lock protection is handled externally
|
||||||
|
* to avoid the overhead of locking and unlocking consecutively.
|
||||||
|
* Declared protected to avoid free public usage.
|
||||||
|
*/
|
||||||
|
virtual ReturnValue_t commitWithoutLock() = 0;
|
||||||
};
|
};
|
||||||
|
|
||||||
using pool_rwm_t = PoolVariableIF::ReadWriteMode_t;
|
using pool_rwm_t = PoolVariableIF::ReadWriteMode_t;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user