fsfw/src/fsfw/cfdp/handler/SourceHandler.cpp

103 lines
3.3 KiB
C++
Raw Normal View History

2022-09-14 19:29:43 +02:00
#include "SourceHandler.h"
2023-06-30 11:36:19 +02:00
2023-07-17 09:53:23 +02:00
#include <etl/crc32.h>
2023-07-17 11:37:20 +02:00
2023-07-17 09:53:23 +02:00
#include <array>
2023-07-17 11:37:20 +02:00
#include "fsfw/filesystem/HasFileSystemIF.h"
2023-07-17 09:53:23 +02:00
using namespace returnvalue;
2023-07-17 10:25:09 +02:00
cfdp::SourceHandler::SourceHandler(SourceHandlerParams params, FsfwParams fsfwParams)
2023-07-17 10:15:06 +02:00
: transactionParams(params.maxFilePathSize),
sourceParams(std::move(params)),
fsfwParams(fsfwParams) {}
2023-07-17 09:53:23 +02:00
void cfdp::SourceHandler::fsmNacked() {
2023-07-14 15:56:38 +02:00
if (step == TransactionStep::IDLE) {
step = TransactionStep::TRANSACTION_START;
}
if (step == TransactionStep::TRANSACTION_START) {
// TODO: Use put request information to start the transaction
step = TransactionStep::CRC_PROCEDURE;
}
if (step == TransactionStep::CRC_PROCEDURE) {
2023-07-17 09:53:23 +02:00
ReturnValue_t result = checksumGeneration();
if (result != OK) {
// TODO: Some error handling
}
2023-07-14 15:56:38 +02:00
}
if (step == TransactionStep::SENDING_METADATA) {
// TODO: Prepare and send metadata PDU
}
if (step == TransactionStep::SENDING_FILE_DATA) {
// TODO: Prepare and send file data PDUs
}
if (step == TransactionStep::SENDING_EOF) {
// TODO: Send EOF PDU
}
if (step == TransactionStep::WAIT_FOR_FINISH) {
// TODO: In case this is a request with closure, wait for finish.
}
if (step == TransactionStep::NOTICE_OF_COMPLETION) {
// TODO: Notice of completion
}
}
2023-07-17 09:53:23 +02:00
void cfdp::SourceHandler::stateMachine() {
2023-07-14 15:56:38 +02:00
if (state == cfdp::CfdpState::IDLE) {
return;
}
if (state == cfdp::CfdpState::BUSY_CLASS_1_NACKED) {
return fsmNacked();
}
}
2023-07-17 09:53:23 +02:00
ReturnValue_t cfdp::SourceHandler::checksumGeneration() {
std::array<uint8_t, 1024> buf{};
etl::crc32 crcCalc;
uint64_t currentOffset = 0;
FileOpParams params(transactionParams.destName.data(), transactionParams.fileSize.value());
while (currentOffset < transactionParams.fileSize.value()) {
uint64_t readLen;
if (currentOffset + buf.size() > transactionParams.fileSize.value()) {
readLen = transactionParams.fileSize.value() - currentOffset;
} else {
readLen = buf.size();
}
if (readLen > 0) {
params.offset = currentOffset;
params.size = readLen;
auto result = sourceParams.user.vfs.readFromFile(params, buf.data(), buf.size());
if (result != OK) {
// TODO: I think this is a case for a filestore rejection, but it might sense to print
// a warning or trigger an event because this should generally not happen
return FAILED;
}
crcCalc.add(buf.begin(), buf.begin() + readLen);
}
currentOffset += readLen;
}
transactionParams.crc = crcCalc.value();
return OK;
}
2023-07-17 10:15:06 +02:00
2023-07-17 13:43:48 +02:00
ReturnValue_t cfdp::SourceHandler::putRequest(PutRequestFull& putRequest, RemoteEntityCfg& cfg) {
transactionParams.closureRequested = putRequest.closureRequested;
transactionParams.destId = putRequest.destId;
transactionParams.transmissionMode = putRequest.transmissionMode;
if (transactionParams.transmissionMode == TransmissionMode::ACKNOWLEDGED) {
}
if (putRequest.sourceNameSize > transactionParams.sourceName.size()) {
return FAILED;
}
std::memcpy(transactionParams.sourceName.data(), putRequest.sourceName,
putRequest.sourceNameSize);
if (putRequest.destNameSize > transactionParams.destName.size()) {
return FAILED;
}
std::memcpy(transactionParams.destName.data(), putRequest.destName, putRequest.destNameSize);
2023-07-17 14:54:45 +02:00
currentRemoteCfg = cfg;
return OK;
2023-07-17 13:43:48 +02:00
}