fsfw-example-common/example/utility/TmFunnel.cpp

123 lines
4.1 KiB
C++
Raw Normal View History

2021-10-17 23:21:38 +02:00
#include "TmFunnel.h"
2021-06-08 13:29:49 +02:00
#include <fsfw/ipc/QueueFactory.h>
#include <fsfw/objectmanager/ObjectManager.h>
#include <fsfw/serviceinterface/ServiceInterface.h>
2022-05-05 20:55:28 +02:00
#include <fsfw/tmtcpacket/pus/tm.h>
2021-06-08 13:29:49 +02:00
2022-08-08 12:32:06 +02:00
#include "fsfw/tmtcpacket/pus/tm.h"
2021-06-08 13:29:49 +02:00
object_id_t TmFunnel::downlinkDestination = objects::NO_OBJECT;
object_id_t TmFunnel::storageDestination = objects::NO_OBJECT;
2022-08-08 12:32:06 +02:00
TmFunnel::TmFunnel(TimeReaderIF &timeReader, object_id_t objectId, uint32_t messageDepth)
2022-07-27 17:57:22 +02:00
: SystemObject(objectId), timeReader(timeReader), messageDepth(messageDepth) {
2022-08-08 12:32:06 +02:00
tmQueue = QueueFactory::instance()->createMessageQueue(messageDepth,
MessageQueueMessage::MAX_MESSAGE_SIZE);
2022-05-05 20:55:28 +02:00
storageQueue = QueueFactory::instance()->createMessageQueue(
messageDepth, MessageQueueMessage::MAX_MESSAGE_SIZE);
2021-06-08 13:29:49 +02:00
}
2022-07-27 17:00:57 +02:00
TmFunnel::~TmFunnel() = default;
2021-06-08 13:29:49 +02:00
MessageQueueId_t TmFunnel::getReportReceptionQueue(uint8_t virtualChannel) {
2022-05-05 20:55:28 +02:00
return tmQueue->getId();
2021-06-08 13:29:49 +02:00
}
ReturnValue_t TmFunnel::performOperation(uint8_t operationCode) {
2022-05-05 20:55:28 +02:00
TmTcMessage currentMessage;
ReturnValue_t status = tmQueue->receiveMessage(&currentMessage);
2022-09-07 17:40:06 +02:00
while (status == returnvalue::OK) {
2022-05-05 20:55:28 +02:00
status = handlePacket(&currentMessage);
2022-09-07 17:40:06 +02:00
if (status != returnvalue::OK) {
2022-07-27 17:57:22 +02:00
sif::warning << "TmFunnel packet handling failed" << std::endl;
2022-05-05 20:55:28 +02:00
break;
2021-06-08 13:29:49 +02:00
}
2022-05-05 20:55:28 +02:00
status = tmQueue->receiveMessage(&currentMessage);
}
if (status == MessageQueueIF::EMPTY) {
2022-09-07 17:40:06 +02:00
return returnvalue::OK;
2022-05-05 20:55:28 +02:00
} else {
return status;
}
2021-06-08 13:29:49 +02:00
}
2022-05-22 15:30:08 +02:00
ReturnValue_t TmFunnel::handlePacket(TmTcMessage *message) {
uint8_t *packetData = nullptr;
2022-05-05 20:55:28 +02:00
size_t size = 0;
2022-08-08 12:32:06 +02:00
ReturnValue_t result = tmPool->modifyData(message->getStorageId(), &packetData, &size);
2022-09-07 17:40:06 +02:00
if (result != returnvalue::OK) {
2022-05-05 20:55:28 +02:00
return result;
}
2022-07-28 15:24:32 +02:00
PusTmZeroCopyWriter packet(timeReader, packetData, size);
2022-07-27 11:33:40 +02:00
result = packet.parseDataWithoutCrcCheck();
2022-09-07 17:40:06 +02:00
if (result != returnvalue::OK) {
2022-07-27 11:33:40 +02:00
return result;
}
packet.setSequenceCount(sourceSequenceCount++);
sourceSequenceCount = sourceSequenceCount % ccsds::LIMIT_SEQUENCE_COUNT;
packet.updateErrorControl();
2022-05-05 20:55:28 +02:00
result = tmQueue->sendToDefault(message);
2022-09-07 17:40:06 +02:00
if (result != returnvalue::OK) {
2022-05-05 20:55:28 +02:00
tmPool->deleteData(message->getStorageId());
2021-06-08 13:29:49 +02:00
#if FSFW_CPP_OSTREAM_ENABLED == 1
2022-07-27 17:57:22 +02:00
sif::error << "TmFunnel::handlePacket: Error sending TM to downlink handler" << std::endl;
2021-06-08 13:29:49 +02:00
#endif
2022-05-05 20:55:28 +02:00
return result;
}
2021-06-08 13:29:49 +02:00
2022-05-05 20:55:28 +02:00
if (storageDestination != objects::NO_OBJECT) {
result = storageQueue->sendToDefault(message);
2022-09-07 17:40:06 +02:00
if (result != returnvalue::OK) {
2022-05-05 20:55:28 +02:00
tmPool->deleteData(message->getStorageId());
2021-06-08 13:29:49 +02:00
#if FSFW_CPP_OSTREAM_ENABLED == 1
2022-08-08 12:32:06 +02:00
sif::error << "TmFunnel::handlePacket: Error sending to storage handler" << std::endl;
2021-06-08 13:29:49 +02:00
#endif
2022-05-05 20:55:28 +02:00
return result;
2021-06-08 13:29:49 +02:00
}
2022-05-05 20:55:28 +02:00
}
return result;
2021-06-08 13:29:49 +02:00
}
ReturnValue_t TmFunnel::initialize() {
2022-05-05 20:55:28 +02:00
tmPool = ObjectManager::instance()->get<StorageManagerIF>(objects::TM_STORE);
if (tmPool == nullptr) {
2021-06-08 13:29:49 +02:00
#if FSFW_CPP_OSTREAM_ENABLED == 1
2022-05-05 20:55:28 +02:00
sif::error << "TmFunnel::initialize: TM store not set." << std::endl;
2022-05-22 15:30:08 +02:00
sif::error << "Make sure the tm store is set up properly and implements "
"StorageManagerIF"
2022-05-05 20:55:28 +02:00
<< std::endl;
2021-06-08 13:29:49 +02:00
#endif
2022-05-05 20:55:28 +02:00
return ObjectManagerIF::CHILD_INIT_FAILED;
}
2021-06-08 13:29:49 +02:00
2022-09-07 17:40:06 +02:00
auto *tmTarget = ObjectManager::instance()->get<AcceptsTelemetryIF>(downlinkDestination);
2022-05-05 20:55:28 +02:00
if (tmTarget == nullptr) {
2021-06-08 13:29:49 +02:00
#if FSFW_CPP_OSTREAM_ENABLED == 1
2022-08-08 12:32:06 +02:00
sif::error << "TmFunnel::initialize: Downlink Destination not set." << std::endl;
2022-05-22 15:30:08 +02:00
sif::error << "Make sure the downlink destination object is set up "
"properly and implements "
2022-05-05 20:55:28 +02:00
"AcceptsTelemetryIF"
<< std::endl;
2021-06-08 13:29:49 +02:00
#endif
2022-05-05 20:55:28 +02:00
return ObjectManagerIF::CHILD_INIT_FAILED;
}
tmQueue->setDefaultDestination(tmTarget->getReportReceptionQueue());
2021-06-08 13:29:49 +02:00
2022-05-05 20:55:28 +02:00
// Storage destination is optional.
if (storageDestination == objects::NO_OBJECT) {
return SystemObject::initialize();
}
2021-06-08 13:29:49 +02:00
2022-08-08 12:32:06 +02:00
auto *storageTarget = ObjectManager::instance()->get<AcceptsTelemetryIF>(storageDestination);
2022-05-05 20:55:28 +02:00
if (storageTarget != nullptr) {
2022-08-08 12:32:06 +02:00
storageQueue->setDefaultDestination(storageTarget->getReportReceptionQueue());
2022-05-05 20:55:28 +02:00
}
2021-06-08 13:29:49 +02:00
2022-05-05 20:55:28 +02:00
return SystemObject::initialize();
2021-06-08 13:29:49 +02:00
}
2022-08-08 12:32:06 +02:00
const char *TmFunnel::getName() const { return "TM Funnel"; }