continued tcs board assembly
All checks were successful
EIVE/eive-obsw/pipeline/head This commit looks good
All checks were successful
EIVE/eive-obsw/pipeline/head This commit looks good
This commit is contained in:
parent
e95d25db66
commit
14d9efce1f
@ -94,7 +94,8 @@ enum commonObjects: uint32_t {
|
|||||||
|
|
||||||
// 0x73 ('s') for assemblies and system/subsystem components
|
// 0x73 ('s') for assemblies and system/subsystem components
|
||||||
ACS_BOARD_ASS = 0x73000001,
|
ACS_BOARD_ASS = 0x73000001,
|
||||||
SUS_BOARD_ASS = 0x73000002
|
SUS_BOARD_ASS = 0x73000002,
|
||||||
|
TCS_BOARD_ASS = 0x73000003
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2,14 +2,14 @@ target_sources(${LIB_EIVE_MISSION} PRIVATE
|
|||||||
AcsBoardAssembly.cpp
|
AcsBoardAssembly.cpp
|
||||||
SusAssembly.cpp
|
SusAssembly.cpp
|
||||||
AcsSubsystem.cpp
|
AcsSubsystem.cpp
|
||||||
TcsSubsystem.cpp
|
|
||||||
EiveSystem.cpp
|
EiveSystem.cpp
|
||||||
ComSubsystem.cpp
|
ComSubsystem.cpp
|
||||||
TcsSubsystem.cpp
|
|
||||||
DualLanePowerStateMachine.cpp
|
DualLanePowerStateMachine.cpp
|
||||||
PowerStateMachineBase.cpp
|
PowerStateMachineBase.cpp
|
||||||
DualLaneAssemblyBase.cpp
|
DualLaneAssemblyBase.cpp
|
||||||
|
TcsBoardAssembly.cpp
|
||||||
|
|
||||||
AcsBoardFdir.cpp
|
AcsBoardFdir.cpp
|
||||||
SusFdir.cpp
|
SusFdir.cpp
|
||||||
|
RtdFdir.cpp
|
||||||
)
|
)
|
@ -69,7 +69,7 @@ class DualLaneAssemblyBase : public AssemblyBase, public ConfirmsFailuresIF {
|
|||||||
virtual void startTransition(Mode_t mode, Submode_t submode) override;
|
virtual void startTransition(Mode_t mode, Submode_t submode) override;
|
||||||
virtual void handleChildrenLostMode(ReturnValue_t result) override;
|
virtual void handleChildrenLostMode(ReturnValue_t result) override;
|
||||||
virtual void handleModeTransitionFailed(ReturnValue_t result) override;
|
virtual void handleModeTransitionFailed(ReturnValue_t result) override;
|
||||||
virtual void handleModeReached();
|
virtual void handleModeReached() override;
|
||||||
|
|
||||||
MessageQueueId_t getEventReceptionQueue() override;
|
MessageQueueId_t getEventReceptionQueue() override;
|
||||||
|
|
||||||
|
6
mission/system/RtdFdir.cpp
Normal file
6
mission/system/RtdFdir.cpp
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
#include "RtdFdir.h"
|
||||||
|
|
||||||
|
#include <common/config/commonObjects.h>
|
||||||
|
|
||||||
|
RtdFdir::RtdFdir(object_id_t sensorId)
|
||||||
|
: DeviceHandlerFailureIsolation(sensorId, objects::TCS_BOARD_ASS) {}
|
11
mission/system/RtdFdir.h
Normal file
11
mission/system/RtdFdir.h
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
#ifndef MISSION_SYSTEM_RTDFDIR_H_
|
||||||
|
#define MISSION_SYSTEM_RTDFDIR_H_
|
||||||
|
|
||||||
|
#include <fsfw/devicehandlers/DeviceHandlerFailureIsolation.h>
|
||||||
|
|
||||||
|
class RtdFdir : public DeviceHandlerFailureIsolation {
|
||||||
|
public:
|
||||||
|
RtdFdir(object_id_t sensorId);
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif /* MISSION_SYSTEM_RTDFDIR_H_ */
|
158
mission/system/TcsBoardAssembly.cpp
Normal file
158
mission/system/TcsBoardAssembly.cpp
Normal file
@ -0,0 +1,158 @@
|
|||||||
|
#include "TcsBoardAssembly.h"
|
||||||
|
|
||||||
|
#include <fsfw/devicehandlers/DeviceHandlerIF.h>
|
||||||
|
#include <fsfw/ipc/QueueFactory.h>
|
||||||
|
|
||||||
|
TcsBoardAssembly::TcsBoardAssembly(object_id_t objectId, object_id_t parentId,
|
||||||
|
PowerSwitchIF* pwrSwitcher, power::Switch_t theSwitch,
|
||||||
|
TcsBoardHelper helper)
|
||||||
|
: AssemblyBase(objectId, parentId, 24), switcher(pwrSwitcher, theSwitch), helper(helper) {
|
||||||
|
eventQueue = QueueFactory::instance()->createMessageQueue(24);
|
||||||
|
}
|
||||||
|
|
||||||
|
void TcsBoardAssembly::performChildOperation() {
|
||||||
|
auto state = switcher.getState();
|
||||||
|
if (state != PowerSwitcher::WAIT_OFF and state != PowerSwitcher::WAIT_ON) {
|
||||||
|
AssemblyBase::performChildOperation();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
switcher.doStateMachine();
|
||||||
|
if (state == PowerSwitcher::WAIT_OFF and switcher.getState() == PowerSwitcher::SWITCH_IS_OFF) {
|
||||||
|
// Indicator that a transition to off is finished
|
||||||
|
AssemblyBase::handleModeReached();
|
||||||
|
} else if (state == PowerSwitcher::WAIT_ON and
|
||||||
|
switcher.getState() == PowerSwitcher::SWITCH_IS_ON) {
|
||||||
|
// Indicator that mode commanding can be performed now
|
||||||
|
AssemblyBase::performChildOperation();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
ReturnValue_t TcsBoardAssembly::commandChildren(Mode_t mode, Submode_t submode) {
|
||||||
|
ReturnValue_t result = RETURN_OK;
|
||||||
|
// Initialize the mode table to ensure all devices are in a defined state
|
||||||
|
for (uint8_t idx = 0; idx < NUMBER_RTDS; idx++) {
|
||||||
|
modeTable[idx].setMode(MODE_OFF);
|
||||||
|
modeTable[idx].setSubmode(SUBMODE_NONE);
|
||||||
|
}
|
||||||
|
if (recoveryState != RecoveryState::RECOVERY_STARTED) {
|
||||||
|
if (mode == DeviceHandlerIF::MODE_NORMAL or mode == MODE_ON) {
|
||||||
|
result = handleNormalOrOnModeCmd(mode, submode);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
HybridIterator<ModeListEntry> tableIter(modeTable.begin(), modeTable.end());
|
||||||
|
executeTable(tableIter);
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
ReturnValue_t TcsBoardAssembly::checkChildrenStateOn(Mode_t wantedMode, Submode_t wantedSubmode) {
|
||||||
|
uint8_t devsInWrongMode = 0;
|
||||||
|
for (uint8_t idx = 0; idx < NUMBER_RTDS; idx++) {
|
||||||
|
if (childrenMap[idx].mode != wantedMode) {
|
||||||
|
devsInWrongMode++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// TODO: Can't really do something other than power cycling if devices in wrong mode.
|
||||||
|
// Might attempt one power-cycle. In any case, trigger an event
|
||||||
|
return RETURN_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
ReturnValue_t TcsBoardAssembly::isModeCombinationValid(Mode_t mode, Submode_t submode) {
|
||||||
|
if (mode == MODE_ON or mode == MODE_OFF or mode == DeviceHandlerIF::MODE_NORMAL) {
|
||||||
|
return RETURN_OK;
|
||||||
|
}
|
||||||
|
return HasModesIF::INVALID_MODE;
|
||||||
|
}
|
||||||
|
|
||||||
|
ReturnValue_t TcsBoardAssembly::initialize() {
|
||||||
|
ReturnValue_t result = RETURN_OK;
|
||||||
|
for (const auto& obj : helper.rtdIds) {
|
||||||
|
result = registerChild(obj);
|
||||||
|
if (result != HasReturnvaluesIF::RETURN_OK) {
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return SubsystemBase::initialize();
|
||||||
|
}
|
||||||
|
|
||||||
|
void TcsBoardAssembly::startTransition(Mode_t mode, Submode_t submode) {
|
||||||
|
if (mode != MODE_OFF) {
|
||||||
|
switcher.turnOn();
|
||||||
|
switcher.doStateMachine();
|
||||||
|
if (switcher.getState() == PowerSwitcher::SWITCH_IS_ON) {
|
||||||
|
AssemblyBase::startTransition(mode, submode);
|
||||||
|
} else {
|
||||||
|
// Need to wait with mode commanding until power switcher is done
|
||||||
|
targetMode = mode;
|
||||||
|
targetSubmode = submode;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
AssemblyBase::startTransition(mode, submode);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
ReturnValue_t TcsBoardAssembly::handleNormalOrOnModeCmd(Mode_t mode, Submode_t submode) {
|
||||||
|
ReturnValue_t result = RETURN_OK;
|
||||||
|
bool needsSecondStep = false;
|
||||||
|
Mode_t devMode = 0;
|
||||||
|
object_id_t objId = 0;
|
||||||
|
for (uint8_t idx = 0; idx < NUMBER_RTDS; idx++) {
|
||||||
|
devMode = childrenMap[idx].mode;
|
||||||
|
objId = helper.rtdIds[idx];
|
||||||
|
if (mode == devMode) {
|
||||||
|
modeTable[idx].setMode(mode);
|
||||||
|
} else if (mode == DeviceHandlerIF::MODE_NORMAL) {
|
||||||
|
if (isUseable(objId, devMode)) {
|
||||||
|
if (devMode == MODE_ON) {
|
||||||
|
modeTable[idx].setMode(mode);
|
||||||
|
modeTable[idx].setSubmode(SUBMODE_NONE);
|
||||||
|
} else {
|
||||||
|
modeTable[idx].setMode(MODE_ON);
|
||||||
|
modeTable[idx].setSubmode(SUBMODE_NONE);
|
||||||
|
if (internalState != STATE_SECOND_STEP) {
|
||||||
|
needsSecondStep = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else if (mode == MODE_ON) {
|
||||||
|
if (isUseable(objId, devMode)) {
|
||||||
|
modeTable[idx].setMode(MODE_ON);
|
||||||
|
modeTable[idx].setSubmode(SUBMODE_NONE);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (needsSecondStep) {
|
||||||
|
result = NEED_SECOND_STEP;
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool TcsBoardAssembly::isUseable(object_id_t object, Mode_t mode) {
|
||||||
|
if (healthHelper.healthTable->isFaulty(object)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Check if device is already in target mode
|
||||||
|
if (childrenMap[object].mode == mode) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (healthHelper.healthTable->isCommandable(object)) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
MessageQueueId_t TcsBoardAssembly::getEventReceptionQueue() { return eventQueue->getId(); }
|
||||||
|
|
||||||
|
void TcsBoardAssembly::handleModeReached() {
|
||||||
|
if (targetMode == MODE_OFF) {
|
||||||
|
switcher.turnOff();
|
||||||
|
switcher.doStateMachine();
|
||||||
|
// Need to wait with call to AssemblyBase::handleModeReached until power switcher is done
|
||||||
|
if (switcher.getState() == PowerSwitcher::SWITCH_IS_OFF) {
|
||||||
|
AssemblyBase::handleModeReached();
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
AssemblyBase::handleModeReached();
|
||||||
|
}
|
||||||
|
}
|
@ -11,10 +11,10 @@ struct TcsBoardHelper {
|
|||||||
std::array<object_id_t, 16> rtdIds = {};
|
std::array<object_id_t, 16> rtdIds = {};
|
||||||
};
|
};
|
||||||
|
|
||||||
class TcsSubsystem : public AssemblyBase {
|
class TcsBoardAssembly : public AssemblyBase, public ConfirmsFailuresIF {
|
||||||
public:
|
public:
|
||||||
TcsSubsystem(object_id_t objectId, object_id_t parentId, PowerSwitchIF* pwrSwitcher,
|
TcsBoardAssembly(object_id_t objectId, object_id_t parentId, PowerSwitchIF* pwrSwitcher,
|
||||||
power::Switch_t switcher, TcsBoardHelper helper);
|
power::Switch_t switcher, TcsBoardHelper helper);
|
||||||
|
|
||||||
ReturnValue_t initialize() override;
|
ReturnValue_t initialize() override;
|
||||||
|
|
||||||
@ -25,12 +25,26 @@ class TcsSubsystem : public AssemblyBase {
|
|||||||
PowerSwitcher switcher;
|
PowerSwitcher switcher;
|
||||||
TcsBoardHelper helper;
|
TcsBoardHelper helper;
|
||||||
FixedArrayList<ModeListEntry, NUMBER_RTDS> modeTable;
|
FixedArrayList<ModeListEntry, NUMBER_RTDS> modeTable;
|
||||||
|
MessageQueueIF* eventQueue = nullptr;
|
||||||
|
|
||||||
|
ReturnValue_t handleNormalOrOnModeCmd(Mode_t mode, Submode_t submode);
|
||||||
|
/**
|
||||||
|
* Check whether it makes sense to send mode commands to the device
|
||||||
|
* @param object
|
||||||
|
* @param mode
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
bool isUseable(object_id_t object, Mode_t mode);
|
||||||
|
|
||||||
|
// ConfirmFailureIF implementation
|
||||||
|
MessageQueueId_t getEventReceptionQueue() override;
|
||||||
|
|
||||||
|
// AssemblyBase implementation
|
||||||
ReturnValue_t commandChildren(Mode_t mode, Submode_t submode) override;
|
ReturnValue_t commandChildren(Mode_t mode, Submode_t submode) override;
|
||||||
ReturnValue_t checkChildrenStateOn(Mode_t wantedMode, Submode_t wantedSubmode) override;
|
ReturnValue_t checkChildrenStateOn(Mode_t wantedMode, Submode_t wantedSubmode) override;
|
||||||
ReturnValue_t isModeCombinationValid(Mode_t mode, Submode_t submode) override;
|
ReturnValue_t isModeCombinationValid(Mode_t mode, Submode_t submode) override;
|
||||||
ReturnValue_t checkModeCommand(Mode_t mode, Submode_t submode,
|
void startTransition(Mode_t mode, Submode_t submode) override;
|
||||||
uint32_t* msToReachTheMode) override;
|
void handleModeReached() override;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif /* MISSION_SYSTEM_TCSSUBSYSTEM_H_ */
|
#endif /* MISSION_SYSTEM_TCSSUBSYSTEM_H_ */
|
@ -1,33 +0,0 @@
|
|||||||
#include "TcsSubsystem.h"
|
|
||||||
|
|
||||||
#include <fsfw/devicehandlers/DeviceHandlerIF.h>
|
|
||||||
|
|
||||||
TcsSubsystem::TcsSubsystem(object_id_t objectId, object_id_t parentId, PowerSwitchIF* pwrSwitcher,
|
|
||||||
power::Switch_t theSwitch, TcsBoardHelper helper)
|
|
||||||
: AssemblyBase(objectId, parentId, 24), switcher(pwrSwitcher, theSwitch), helper(helper) {}
|
|
||||||
|
|
||||||
void TcsSubsystem::performChildOperation() {
|
|
||||||
switcher.doStateMachine();
|
|
||||||
if (not switcher.active()) {
|
|
||||||
AssemblyBase::performChildOperation();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
ReturnValue_t TcsSubsystem::checkModeCommand(Mode_t mode, Submode_t submode,
|
|
||||||
uint32_t* msToReachTheMode) {
|
|
||||||
if (mode == MODE_ON or mode == MODE_OFF or mode == DeviceHandlerIF::MODE_NORMAL) {
|
|
||||||
return RETURN_OK;
|
|
||||||
}
|
|
||||||
return HasModesIF::INVALID_MODE;
|
|
||||||
}
|
|
||||||
|
|
||||||
ReturnValue_t TcsSubsystem::initialize() {
|
|
||||||
ReturnValue_t result = RETURN_OK;
|
|
||||||
for (const auto& obj : helper.rtdIds) {
|
|
||||||
result = registerChild(obj);
|
|
||||||
if (result != HasReturnvaluesIF::RETURN_OK) {
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return SubsystemBase::initialize();
|
|
||||||
}
|
|
Loading…
x
Reference in New Issue
Block a user