FreeRTOS Monotonic Clock #46

Merged
muellerr merged 4 commits from meier/freertos-monotonic-clock into main 2025-01-07 10:33:29 +01:00
Showing only changes of commit d1bf04cc29 - Show all commits

View File

@ -25,6 +25,33 @@ struct DhbConfig {
uint32_t msgQueueDepth = 10; uint32_t msgQueueDepth = 10;
}; };
/**
* @brief
* This is a base class which can be used for handler classes which drive physical devices.
*
* @details
* This class performs some boilerplate tasks to make it compatible to the FSFW ecosystem.
* For example, it adds all required interfaces and helpers which are required for the majority
* of physical devices:
*
* - SystemObject to become globally addressable
* - HasModesIF and the ModeHelper: Expose modes. It is expected that most device handlers
* use the default device handler modes OFF, ON and NORMAL at the very least.
* - HasHealthIF, HealthHelper and a FDIR object: Physical devices can break down or require
* power cycling as the most common FDIR reaction. The FDHB implements the necessary interface
* and is also composed of a FDIR object which can set the health state to FAULTY or
* NEEDS_RECOVERY to cause FDIR reactions.
* - ModeTreeChildIF: Many device handlers are part of a mode tree.
* - HasActionsIF and the ActionHelper: Most device handlers expose executable commands, for example
* to re-configure the physical device or to poll data from the physical device.
* - ReceivesParameterMessagesIF and the ParameterHelper: Most device handlers have tweakable
* parameters.
*
* This class is used to extending it in a concrete device handler class and then implementing
* all abstract methods. The abstract methods provide adaption points for users which were
* deemed sufficient for most use-cases. The behaviour of the base-class can also be further
* configured by implementing other virtual functions.
*/
class FreshDeviceHandlerBase : public SystemObject, class FreshDeviceHandlerBase : public SystemObject,
public DeviceHandlerIF, public DeviceHandlerIF,
public HasModesIF, public HasModesIF,
@ -40,7 +67,20 @@ class FreshDeviceHandlerBase : public SystemObject,
~FreshDeviceHandlerBase() override; ~FreshDeviceHandlerBase() override;
/** /**
* @brief
* Periodic helper executed function, implemented by child class. * Periodic helper executed function, implemented by child class.
*
* @details
* This will be called by the default performOperation call. This is the main adaption point
* for the actual device handling logic. It is expected that the following common tasks are
* performed in this method:
*
* 1. Performing periodic polling of the physical device in NORMAL mode. This is usually required
* to poll housekeeping data from the device periodically.
* 2. Handle on-going mode transitions if the mode transitions can only be handled asynchronously.
* This might also involve communication with the physical device and power switch
* handling/polling for transition to OFF or ON/NORMAL.
* 3. Perform other periodic tasks which always need to be done irrespective of mode.
*/ */
virtual void performDeviceOperation(uint8_t opCode) = 0; virtual void performDeviceOperation(uint8_t opCode) = 0;
@ -92,13 +132,17 @@ class FreshDeviceHandlerBase : public SystemObject,
// Mode Helpers. // Mode Helpers.
virtual void modeChanged(Mode_t mode, Submode_t submode); virtual void modeChanged(Mode_t mode, Submode_t submode);
/** /**
* This method is called when a mode message to set a new mode is received.
*
* The default implementation sets the new mode immediately. If this is not applicable for * The default implementation sets the new mode immediately. If this is not applicable for
* certain modes, the user should provide a custom implementation, which performs roughly * certain modes, the user should provide a custom implementation, which performs roughly
* the same functionality of this function, when all the steps have been taken to reach the * the same functionality of this function, when all the steps have been taken to reach the
* new mode. * new mode.
*/ */
void startTransition(Mode_t mode, Submode_t submode) override; void startTransition(Mode_t mode, Submode_t submode) override;
virtual void setMode(Mode_t newMode, Submode_t newSubmode); virtual void setMode(Mode_t newMode, Submode_t newSubmode);
virtual void setMode(Mode_t newMode); virtual void setMode(Mode_t newMode);
void getMode(Mode_t* mode, Submode_t* submode) override; void getMode(Mode_t* mode, Submode_t* submode) override;
@ -120,15 +164,43 @@ class FreshDeviceHandlerBase : public SystemObject,
ReturnValue_t initializeLocalDataPool(localpool::DataPool& localDataPoolMap, ReturnValue_t initializeLocalDataPool(localpool::DataPool& localDataPoolMap,
LocalDataPoolManager& poolManager) override = 0; LocalDataPoolManager& poolManager) override = 0;
// Mode abstract functions /**
* HasModesIF implementation to check the validity of a mode command.
* @param mode
* @param submode
* @param msToReachTheMode
* @return
*/
ReturnValue_t checkModeCommand(Mode_t mode, Submode_t submode, ReturnValue_t checkModeCommand(Mode_t mode, Submode_t submode,
uint32_t* msToReachTheMode) override = 0; uint32_t* msToReachTheMode) override = 0;
// Health Overrides. // Health Overrides.
ReturnValue_t setHealth(HealthState health) override; ReturnValue_t setHealth(HealthState health) override;
// Action override. Forward to user.
/**
* This is called when an ActionMessage is received to execute it.
* @param actionId
* @param commandedBy
* @param data
* @param size
* @return
*/
ReturnValue_t executeAction(ActionId_t actionId, MessageQueueId_t commandedBy, ReturnValue_t executeAction(ActionId_t actionId, MessageQueueId_t commandedBy,
const uint8_t* data, size_t size) override = 0; const uint8_t* data, size_t size) override = 0;
// Executable overrides. /**
* This is the default periodic operation handler.
*
* Currently, it performs the following tasks:
*
* 1. Handle the message queue and all message types covered by the base class as specified
* in the class documentation. It uses the composed helper classes for this.
* 2. Poll the FDIR instance to check for failures. The FDIR works by checking all events
* received by the FDHB. An FDIR reaction sets the health state of the FDHB, which might
* in turn trigger FDIR reactions.
* 3. Call the performDeviceOperation user hook.
* 4. Handle periodic housekeeping data generation.
* @param opCode
* @return
*/
virtual ReturnValue_t performOperation(uint8_t opCode) override; virtual ReturnValue_t performOperation(uint8_t opCode) override;
ReturnValue_t initializeAfterTaskCreation() override; ReturnValue_t initializeAfterTaskCreation() override;