2022-02-22 13:27:21 +01:00
|
|
|
#ifndef LINUX_DEVICES_PLPCDUHANDLER_H_
|
|
|
|
#define LINUX_DEVICES_PLPCDUHANDLER_H_
|
|
|
|
|
|
|
|
#include <fsfw/devicehandlers/DeviceHandlerBase.h>
|
|
|
|
#include <fsfw/globalfunctions/PeriodicOperationDivider.h>
|
|
|
|
#include <fsfw/timemanager/Countdown.h>
|
|
|
|
|
2022-02-24 12:44:50 +01:00
|
|
|
#include "events/subsystemIdRanges.h"
|
2022-02-22 19:28:04 +01:00
|
|
|
#include "fsfw/FSFW.h"
|
2022-02-22 13:27:21 +01:00
|
|
|
#include "fsfw_hal/common/gpio/GpioIF.h"
|
2022-02-22 16:51:26 +01:00
|
|
|
#include "mission/devices/devicedefinitions/payloadPcduDefinitions.h"
|
2022-02-25 16:33:22 +01:00
|
|
|
#include "mission/memory/SdCardMountedIF.h"
|
2022-02-22 16:51:26 +01:00
|
|
|
|
2022-02-22 19:28:04 +01:00
|
|
|
#ifdef FSFW_OSAL_LINUX
|
2022-02-22 16:51:26 +01:00
|
|
|
class SpiComIF;
|
|
|
|
class SpiCookie;
|
2022-02-22 19:28:04 +01:00
|
|
|
#endif
|
2022-02-22 13:27:21 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Device handler for the EIVE Payload PCDU
|
|
|
|
* @details
|
|
|
|
* Documentation:
|
|
|
|
* https://egit.irs.uni-stuttgart.de/eive/eive_dokumente/src/branch/master/400_Raumsegment/412_PayloaPCDUDocumentation/release/EIVE-D-421-001_PLPCDU_Documentation.pdf
|
|
|
|
*
|
|
|
|
* Important components:
|
|
|
|
* - SSR - Solid State Relay: Decouples voltages from battery
|
|
|
|
* - DRO - Dielectric Resonsant Oscillator: Generates modulation signal
|
|
|
|
* - X8: Frequency X8 Multiplicator
|
|
|
|
* - TX: Transmitter/Sender module. Modulates data onto carrier signal
|
|
|
|
* - MPA - Medium Power Amplifier
|
|
|
|
* - HPA - High Power Amplifier
|
|
|
|
*/
|
|
|
|
class PayloadPcduHandler : public DeviceHandlerBase {
|
|
|
|
public:
|
2022-02-24 12:44:50 +01:00
|
|
|
static constexpr uint8_t SUBSYSTEM_ID = SUBSYSTEM_ID::PL_PCDU_HANDLER;
|
2022-02-25 20:14:59 +01:00
|
|
|
//! [EXPORT] : [COMMENT] Could not transition properly and went back to ALL OFF
|
2022-02-25 11:16:04 +01:00
|
|
|
static constexpr Event TRANSITION_BACK_TO_OFF =
|
|
|
|
event::makeEvent(SUBSYSTEM_ID, 0, severity::MEDIUM);
|
2022-02-25 16:33:22 +01:00
|
|
|
//! [EXPORT] : [COMMENT] P1: 0 -> too low, 1 -> too high P2: Float value
|
|
|
|
static constexpr Event NEG_V_OUT_OF_BOUNDS = event::makeEvent(SUBSYSTEM_ID, 1, severity::MEDIUM);
|
|
|
|
//! [EXPORT] : [COMMENT] P1: 0 -> too low, 1 -> too high P2: Float value
|
|
|
|
static constexpr Event U_DRO_OUT_OF_BOUNDS = event::makeEvent(SUBSYSTEM_ID, 2, severity::MEDIUM);
|
|
|
|
//! [EXPORT] : [COMMENT] P1: 0 -> too low, 1 -> too high P2: Float value
|
|
|
|
static constexpr Event I_DRO_OUT_OF_BOUNDS = event::makeEvent(SUBSYSTEM_ID, 3, severity::MEDIUM);
|
|
|
|
//! [EXPORT] : [COMMENT] P1: 0 -> too low, 1 -> too high P2: Float value
|
|
|
|
static constexpr Event U_X8_OUT_OF_BOUNDS = event::makeEvent(SUBSYSTEM_ID, 4, severity::MEDIUM);
|
|
|
|
//! [EXPORT] : [COMMENT] P1: 0 -> too low, 1 -> too high P2: Float value
|
|
|
|
static constexpr Event I_X8_OUT_OF_BOUNDS = event::makeEvent(SUBSYSTEM_ID, 5, severity::MEDIUM);
|
|
|
|
//! [EXPORT] : [COMMENT] P1: 0 -> too low, 1 -> too high P2: Float value
|
|
|
|
static constexpr Event U_TX_OUT_OF_BOUNDS = event::makeEvent(SUBSYSTEM_ID, 6, severity::MEDIUM);
|
|
|
|
//! [EXPORT] : [COMMENT] P1: 0 -> too low, 1 -> too high P2: Float value
|
|
|
|
static constexpr Event I_TX_OUT_OF_BOUNDS = event::makeEvent(SUBSYSTEM_ID, 7, severity::MEDIUM);
|
|
|
|
//! [EXPORT] : [COMMENT] P1: 0 -> too low, 1 -> too high P2: Float value
|
|
|
|
static constexpr Event U_MPA_OUT_OF_BOUNDS = event::makeEvent(SUBSYSTEM_ID, 8, severity::MEDIUM);
|
|
|
|
//! [EXPORT] : [COMMENT] P1: 0 -> too low, 1 -> too high P2: Float value
|
|
|
|
static constexpr Event I_MPA_OUT_OF_BOUNDS = event::makeEvent(SUBSYSTEM_ID, 9, severity::MEDIUM);
|
|
|
|
//! [EXPORT] : [COMMENT] P1: 0 -> too low, 1 -> too high P2: Float value
|
|
|
|
static constexpr Event U_HPA_OUT_OF_BOUNDS = event::makeEvent(SUBSYSTEM_ID, 10, severity::MEDIUM);
|
|
|
|
//! [EXPORT] : [COMMENT] P1: 0 -> too low, 1 -> too high P2: Float value
|
|
|
|
static constexpr Event I_HPA_OUT_OF_BOUNDS = event::makeEvent(SUBSYSTEM_ID, 11, severity::MEDIUM);
|
2022-02-24 12:44:50 +01:00
|
|
|
|
2022-02-22 13:27:21 +01:00
|
|
|
PayloadPcduHandler(object_id_t objectId, object_id_t comIF, CookieIF* cookie, GpioIF* gpioIF,
|
2022-02-25 16:33:22 +01:00
|
|
|
SdCardMountedIF* sdcMan, bool periodicPrintout);
|
2022-02-22 13:27:21 +01:00
|
|
|
|
|
|
|
void setToGoToNormalModeImmediately(bool enable);
|
|
|
|
void enablePeriodicPrintout(bool enable, uint8_t divider);
|
|
|
|
|
2022-02-22 16:51:26 +01:00
|
|
|
static ReturnValue_t extConvAsTwoCallback(SpiComIF* comIf, SpiCookie* cookie,
|
|
|
|
const uint8_t* sendData, size_t sendLen, void* args);
|
2022-02-22 19:28:04 +01:00
|
|
|
|
|
|
|
#ifdef FSFW_OSAL_LINUX
|
2022-02-22 16:51:26 +01:00
|
|
|
static ReturnValue_t transferAsTwo(SpiComIF* comIf, SpiCookie* cookie, const uint8_t* sendData,
|
|
|
|
size_t sendLen, bool tempOnly);
|
2022-02-22 19:28:04 +01:00
|
|
|
#endif
|
2022-02-22 16:51:26 +01:00
|
|
|
|
2022-02-22 13:27:21 +01:00
|
|
|
private:
|
2022-02-25 11:16:04 +01:00
|
|
|
enum class States : uint8_t {
|
2022-02-22 13:27:21 +01:00
|
|
|
PCDU_OFF,
|
|
|
|
// Solid State Relay, enable battery voltages VBAT0 and VBAT1. This will also switch on
|
|
|
|
// the ADC
|
|
|
|
ON_TRANS_SSR,
|
|
|
|
ON_TRANS_ADC_CLOSE_ZERO,
|
|
|
|
// Enable Dielectric Resonant Oscillator and start monitoring voltages as
|
|
|
|
// soon as DRO voltage reaches 6V
|
|
|
|
ON_TRANS_DRO,
|
|
|
|
// Switch on X8 compoennt and monitor voltages for 5 seconds
|
|
|
|
ON_TRANS_X8,
|
|
|
|
// Switch on TX component and monitor voltages for 5 seconds
|
|
|
|
ON_TRANS_TX,
|
|
|
|
// Switch on MPA component and monitor voltages for 5 seconds
|
|
|
|
ON_TRANS_MPA,
|
|
|
|
// Switch on HPA component and monitor voltages for 5 seconds
|
|
|
|
ON_TRANS_HPA,
|
|
|
|
// All components of the experiment are on
|
|
|
|
PCDU_ON,
|
|
|
|
} state = States::PCDU_OFF;
|
|
|
|
|
2022-02-22 16:51:26 +01:00
|
|
|
enum class AdcMode { EXT_CONV, INT_CONV } adcMode = AdcMode::INT_CONV;
|
|
|
|
|
2022-02-22 13:27:21 +01:00
|
|
|
enum class MonitoringMode { NONE, CLOSE_TO_ZERO, NEGATIVE } monMode = MonitoringMode::NONE;
|
|
|
|
|
|
|
|
enum class AdcStates { OFF, BOOT_DELAY, SEND_SETUP, NORMAL } adcState = AdcStates::OFF;
|
|
|
|
|
|
|
|
bool goToNormalMode = false;
|
|
|
|
plpcdu::PlPcduAdcSet adcSet;
|
|
|
|
std::array<uint8_t, plpcdu::MAX_ADC_REPLY_SIZE> cmdBuf = {};
|
|
|
|
// This variable is tied to DRO +6 V voltage. Voltages, currents are monitored and the experiment
|
|
|
|
// is shut down immediately if there is a negative voltage.
|
|
|
|
bool transitionOk = false;
|
|
|
|
bool commandExecuted = false;
|
|
|
|
bool adcCmdExecuted = false;
|
|
|
|
bool periodicPrintout = false;
|
2022-02-25 17:29:06 +01:00
|
|
|
bool jsonFileInitComplete = false;
|
2022-02-22 13:27:21 +01:00
|
|
|
PeriodicOperationDivider opDivider = PeriodicOperationDivider(5);
|
|
|
|
uint8_t tempReadDivisor = 1;
|
|
|
|
Countdown countdown = Countdown(5000);
|
|
|
|
Countdown adcCountdown = Countdown(50);
|
|
|
|
GpioIF* gpioIF;
|
2022-02-25 16:33:22 +01:00
|
|
|
SdCardMountedIF* sdcMan;
|
2022-02-25 17:29:06 +01:00
|
|
|
plpcdu::PlPcduParameter params;
|
2022-02-22 13:27:21 +01:00
|
|
|
|
|
|
|
PoolEntry<uint16_t> channelValues = PoolEntry<uint16_t>({0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0});
|
2022-02-25 15:28:59 +01:00
|
|
|
PoolEntry<float> processedValues =
|
|
|
|
PoolEntry<float>({0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0});
|
2022-02-22 13:27:21 +01:00
|
|
|
PoolEntry<float> tempC = PoolEntry<float>({0.0});
|
|
|
|
|
|
|
|
void doTransition(Mode_t modeFrom, Submode_t subModeFrom) override;
|
|
|
|
void doStartUp() override;
|
|
|
|
void doShutDown() override;
|
2022-02-24 12:44:50 +01:00
|
|
|
// Main FDIR function which goes from any PL PCDU state back to all off
|
|
|
|
void transitionBackToOff();
|
2022-02-22 13:27:21 +01:00
|
|
|
ReturnValue_t buildNormalDeviceCommand(DeviceCommandId_t* id) override;
|
|
|
|
ReturnValue_t buildTransitionDeviceCommand(DeviceCommandId_t* id) override;
|
|
|
|
void fillCommandAndReplyMap() override;
|
|
|
|
ReturnValue_t buildCommandFromCommand(DeviceCommandId_t deviceCommand, const uint8_t* commandData,
|
|
|
|
size_t commandDataLen) override;
|
|
|
|
ReturnValue_t scanForReply(const uint8_t* start, size_t remainingSize, DeviceCommandId_t* foundId,
|
|
|
|
size_t* foundLen) override;
|
|
|
|
ReturnValue_t interpretDeviceReply(DeviceCommandId_t id, const uint8_t* packet) override;
|
|
|
|
uint32_t getTransitionDelayMs(Mode_t modeFrom, Mode_t modeTo) override;
|
|
|
|
ReturnValue_t initializeLocalDataPool(localpool::DataPool& localDataPoolMap,
|
|
|
|
LocalDataPoolManager& poolManager) override;
|
2022-02-25 20:14:59 +01:00
|
|
|
ReturnValue_t isModeCombinationValid(Mode_t mode, Submode_t submode) override;
|
|
|
|
|
2022-02-22 13:27:21 +01:00
|
|
|
void handleExtConvRead(const uint8_t* bufStart);
|
|
|
|
void handlePrintout();
|
2022-02-25 15:28:59 +01:00
|
|
|
void checkAdcValues();
|
2022-02-25 17:29:06 +01:00
|
|
|
void checkJsonFileInit();
|
2022-02-22 13:27:21 +01:00
|
|
|
void stateMachineToNormal();
|
2022-02-25 19:07:47 +01:00
|
|
|
bool checkVoltage(float val, float lowerBound, float upperBound, Event event);
|
|
|
|
bool checkCurrent(float val, float upperBound, Event event);
|
|
|
|
ReturnValue_t serializeFloat(uint32_t& param, float val);
|
2022-02-22 13:27:21 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif /* LINUX_DEVICES_PLPCDUHANDLER_H_ */
|