2022-01-06 18:05:21 +01:00
|
|
|
#ifndef BSP_Q7S_DEVICES_PLOCMPSOCHELPER_H_
|
|
|
|
#define BSP_Q7S_DEVICES_PLOCMPSOCHELPER_H_
|
|
|
|
|
|
|
|
#include <string>
|
|
|
|
#include "fsfw/osal/linux/BinarySemaphore.h"
|
|
|
|
#include "fsfw/returnvalues/HasReturnvaluesIF.h"
|
|
|
|
#include "fsfw/objectmanager/SystemObject.h"
|
|
|
|
#include "fsfw/tasks/ExecutableObjectIF.h"
|
|
|
|
#include "fsfw_hal/linux/uart/UartComIF.h"
|
|
|
|
#include "fsfw/devicehandlers/CookieIF.h"
|
2022-01-11 12:56:02 +01:00
|
|
|
#include "fsfw/tmtcservices/SourceSequenceCounter.h"
|
2022-03-17 14:28:32 +01:00
|
|
|
#include "linux/devices/devicedefinitions/PlocMPSoCDefinitions.h"
|
|
|
|
#ifdef XIPHOS_Q7S
|
|
|
|
#include "bsp_q7s/memory/SdCardManager.h"
|
|
|
|
#endif
|
2022-01-06 18:05:21 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Helper class for MPSoC of PLOC intended to accelerate large data transfers between
|
|
|
|
* MPSoC and OBC.
|
|
|
|
* @author J. Meier
|
|
|
|
*/
|
|
|
|
class PlocMPSoCHelper: public SystemObject, public ExecutableObjectIF, public HasReturnvaluesIF {
|
|
|
|
public:
|
|
|
|
|
|
|
|
static const uint8_t SUBSYSTEM_ID = SUBSYSTEM_ID::PLOC_MPSOC_HELPER;
|
|
|
|
|
|
|
|
//! [EXPORT] : [COMMENT] Flash write fails
|
2022-01-11 17:58:59 +01:00
|
|
|
static const Event MPSOC_FLASH_WRITE_FAILED = MAKE_EVENT(0, severity::LOW);
|
2022-01-06 18:05:21 +01:00
|
|
|
//! [EXPORT] : [COMMENT] Flash write successful
|
2022-01-11 17:58:59 +01:00
|
|
|
static const Event MPSOC_FLASH_WRITE_SUCCESSFUL = MAKE_EVENT(1, severity::LOW);
|
2022-01-06 18:05:21 +01:00
|
|
|
//! [EXPORT] : [COMMENT] Communication interface returned failure when trying to send the command ot the PLOC
|
|
|
|
//!P1: Return value returned by the communication interface sendMessage function
|
|
|
|
//!P2: Internal state of MPSoC helper
|
|
|
|
static const Event SENDING_COMMAND_FAILED = MAKE_EVENT(2, severity::LOW);
|
|
|
|
//! [EXPORT] : [COMMENT] Request receive message of communication interface failed
|
|
|
|
//!P1: Return value returned by the communication interface requestReceiveMessage function
|
|
|
|
//!P2: Internal state of MPSoC helper
|
|
|
|
static const Event MPSOC_HELPER_REQUESTING_REPLY_FAILED = MAKE_EVENT(3, severity::LOW);
|
|
|
|
//! [EXPORT] : [COMMENT] Reading receive message of communication interface failed
|
|
|
|
//!P1: Return value returned by the communication interface readingReceivedMessage function
|
|
|
|
//!P2: Internal state of MPSoC helper
|
2022-01-07 09:50:04 +01:00
|
|
|
static const Event MPSOC_HELPER_READING_REPLY_FAILED = MAKE_EVENT(4, severity::LOW);
|
2022-01-06 18:05:21 +01:00
|
|
|
//! [EXPORT] : [COMMENT] Did not receive acknowledgement report
|
|
|
|
//!P1: Number of bytes missing
|
|
|
|
//!P2: Internal state of MPSoC helper
|
|
|
|
static const Event MISSING_ACK = MAKE_EVENT(5, severity::LOW);
|
|
|
|
//! [EXPORT] : [COMMENT] Did not receive execution report
|
|
|
|
//!P1: Number of bytes missing
|
|
|
|
//!P2: Internal state of MPSoC helper
|
|
|
|
static const Event MISSING_EXE = MAKE_EVENT(6, severity::LOW);
|
|
|
|
//! [EXPORT] : [COMMENT] Received acknowledgement failure report
|
|
|
|
//!P1: Internal state of MPSoC
|
|
|
|
static const Event ACK_FAILURE_REPORT = MAKE_EVENT(7, severity::LOW);
|
|
|
|
//! [EXPORT] : [COMMENT] Received execution failure report
|
|
|
|
//!P1: Internal state of MPSoC
|
|
|
|
static const Event EXE_FAILURE_REPORT = MAKE_EVENT(8, severity::LOW);
|
|
|
|
//! [EXPORT] : [COMMENT] Expected acknowledgement report but received space packet with other apid
|
|
|
|
//!P1: Apid of received space packet
|
|
|
|
//!P2: Internal state of MPSoC
|
|
|
|
static const Event ACK_INVALID_APID = MAKE_EVENT(9, severity::LOW);
|
|
|
|
//! [EXPORT] : [COMMENT] Expected execution report but received space packet with other apid
|
|
|
|
//!P1: Apid of received space packet
|
|
|
|
//!P2: Internal state of MPSoC
|
|
|
|
static const Event EXE_INVALID_APID = MAKE_EVENT(10, severity::LOW);
|
2022-01-10 16:18:18 +01:00
|
|
|
//! [EXPORT] : [COMMENT] Received sequence count does not match expected sequence count
|
|
|
|
//!P1: Expected sequence count
|
|
|
|
//!P2: Received sequence count
|
2022-01-11 17:58:59 +01:00
|
|
|
static const Event MPSOC_HELPER_SEQ_CNT_MISMATCH = MAKE_EVENT(11, severity::LOW);
|
2022-01-06 18:05:21 +01:00
|
|
|
|
|
|
|
PlocMPSoCHelper(object_id_t objectId);
|
|
|
|
virtual ~PlocMPSoCHelper();
|
|
|
|
|
|
|
|
ReturnValue_t initialize() override;
|
|
|
|
ReturnValue_t performOperation(uint8_t operationCode = 0) override;
|
|
|
|
|
|
|
|
ReturnValue_t setComIF(DeviceCommunicationIF* communicationInterface_);
|
|
|
|
void setComCookie(CookieIF* comCookie_);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Starts flash write sequence
|
|
|
|
*
|
|
|
|
* @param file File with data to write
|
|
|
|
*
|
|
|
|
* @return RETURN_OK if successful, otherwise error return value
|
|
|
|
*/
|
|
|
|
ReturnValue_t startFlashWrite(std::string file);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Can be used to interrupt a running data transfer.
|
|
|
|
*/
|
|
|
|
void stopProcess();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Sets the sequence count object responsible for the sequence count handling
|
|
|
|
*/
|
2022-01-11 12:56:02 +01:00
|
|
|
void setSequenceCount(SourceSequenceCounter* sequenceCount_);
|
2022-01-06 18:05:21 +01:00
|
|
|
|
|
|
|
private:
|
|
|
|
|
|
|
|
static const uint8_t INTERFACE_ID = CLASS_ID::PLOC_MPSOC_HELPER;
|
|
|
|
|
|
|
|
// Maximum number of times the communication interface retries polling data from the reply
|
|
|
|
// buffer
|
|
|
|
static const int RETRIES = 3;
|
|
|
|
|
2022-03-16 12:36:05 +01:00
|
|
|
struct FlashWrite {
|
2022-01-10 16:18:18 +01:00
|
|
|
std::string file;
|
2022-01-06 18:05:21 +01:00
|
|
|
};
|
|
|
|
|
2022-03-16 12:36:05 +01:00
|
|
|
struct FlashWrite flashWrite;
|
2022-01-06 18:05:21 +01:00
|
|
|
|
|
|
|
enum class InternalState {
|
|
|
|
IDLE,
|
|
|
|
FLASH_WRITE,
|
|
|
|
FLASH_READ
|
|
|
|
};
|
|
|
|
|
|
|
|
InternalState internalState = InternalState::IDLE;
|
|
|
|
|
|
|
|
BinarySemaphore semaphore;
|
2022-03-17 14:28:32 +01:00
|
|
|
#ifdef XIPHOS_Q7S
|
2022-01-06 18:05:21 +01:00
|
|
|
SdCardManager* sdcMan = nullptr;
|
2022-03-17 14:28:32 +01:00
|
|
|
#endif
|
2022-01-06 18:05:21 +01:00
|
|
|
uint8_t commandBuffer[mpsoc::MAX_COMMAND_SIZE];
|
|
|
|
|
|
|
|
bool terminate = false;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Communication interface of MPSoC responsible for low level access. Must be set by the
|
|
|
|
* MPSoC Handler.
|
|
|
|
*/
|
|
|
|
UartComIF* uartComIF = nullptr;
|
|
|
|
// Communication cookie. Must be set by the MPSoC Handler
|
|
|
|
CookieIF* comCookie = nullptr;
|
|
|
|
// Sequence count, must be set by Ploc MPSoC Handler
|
2022-01-11 12:56:02 +01:00
|
|
|
SourceSequenceCounter* sequenceCount;
|
2022-01-06 18:05:21 +01:00
|
|
|
|
|
|
|
ReturnValue_t performFlashWrite();
|
2022-03-16 09:01:36 +01:00
|
|
|
ReturnValue_t flashfopen();
|
|
|
|
ReturnValue_t flashfclose();
|
2022-01-07 09:50:04 +01:00
|
|
|
ReturnValue_t sendCommand(mpsoc::TcBase* tc);
|
2022-01-06 18:05:21 +01:00
|
|
|
ReturnValue_t receive(uint8_t* data, size_t* readBytes, size_t requestBytes);
|
|
|
|
ReturnValue_t handleAck();
|
|
|
|
ReturnValue_t handleExe();
|
|
|
|
void handleAckApidFailure(uint16_t apid);
|
|
|
|
void handleExeApidFailure(uint16_t apid);
|
2022-01-07 09:50:04 +01:00
|
|
|
ReturnValue_t handleTmReception(mpsoc::TmPacket* tmPacket, size_t remainingBytes);
|
2022-01-06 18:05:21 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif /* BSP_Q7S_DEVICES_PLOCMPSOCHELPER_H_ */
|