Robin Mueller
9f600a24ff
All checks were successful
EIVE/eive-obsw/pipeline/pr-main This commit looks good
66 lines
2.0 KiB
C++
66 lines
2.0 KiB
C++
#include "VirtualChannel.h"
|
|
|
|
#include <fsfw/tasks/TaskFactory.h>
|
|
|
|
VirtualChannel::VirtualChannel(object_id_t objectId, uint8_t vcId, const char* vcName, PtmeIF& ptme,
|
|
const std::atomic_bool& txOn)
|
|
: SystemObject(objectId), ptme(ptme), vcId(vcId), vcName(vcName), txOn(txOn) {}
|
|
|
|
ReturnValue_t VirtualChannel::initialize() { return returnvalue::OK; }
|
|
|
|
ReturnValue_t VirtualChannel::sendNextTm(const uint8_t* data, size_t size, size_t& writtenSize) {
|
|
return write(data, size, writtenSize);
|
|
}
|
|
|
|
ReturnValue_t VirtualChannel::write(const uint8_t* data, size_t size, size_t& writtenSize) {
|
|
if (!ptme.containsVc(vcId)) {
|
|
return CHANNEL_DOES_NOT_EXIST;
|
|
}
|
|
return ptme.getVirtChannel(vcId)->write(data, size, writtenSize);
|
|
}
|
|
|
|
uint8_t VirtualChannel::getVcid() const { return vcId; }
|
|
|
|
ReturnValue_t VirtualChannel::finishWrite(const uint8_t* data, size_t start, size_t remainingSize) {
|
|
if (!ptme.containsVc(vcId)) {
|
|
return CHANNEL_DOES_NOT_EXIST;
|
|
}
|
|
return ptme.getVirtChannel(vcId)->finishWrite(data, start, remainingSize);
|
|
}
|
|
|
|
const char* VirtualChannel::getName() const { return vcName.c_str(); }
|
|
|
|
bool VirtualChannel::isBusy() const {
|
|
if (!ptme.containsVc(vcId)) {
|
|
return CHANNEL_DOES_NOT_EXIST;
|
|
}
|
|
return ptme.getVirtChannel(vcId)->isBusy();
|
|
}
|
|
|
|
void VirtualChannel::cancelTransfer() {
|
|
if (!ptme.containsVc(vcId)) {
|
|
return;
|
|
}
|
|
ptme.getVirtChannel(vcId)->cancelTransfer();
|
|
}
|
|
|
|
bool VirtualChannel::isTxOn() const { return txOn; }
|
|
|
|
ReturnValue_t VirtualChannel::handleLastWriteSynchronously(const uint8_t* data, size_t start,
|
|
size_t remLen, unsigned maxDelayMs) {
|
|
unsigned delayMs = 0;
|
|
while (true) {
|
|
if (isBusy()) {
|
|
if (delayMs >= maxDelayMs) {
|
|
break;
|
|
}
|
|
TaskFactory::delayTask(10);
|
|
delayMs += 10;
|
|
continue;
|
|
}
|
|
sif::debug << "last write after" << delayMs << std::endl;
|
|
return finishWrite(data, start, remLen);
|
|
}
|
|
return returnvalue::FAILED;
|
|
}
|