fifo tweaks, pus parser fixes
This commit is contained in:
parent
fd1e612ea5
commit
cb691db807
@ -19,10 +19,8 @@ namespace fsfw {
|
||||
template<typename T>
|
||||
class FIFO: public FIFOBase<T> {
|
||||
public:
|
||||
FIFO(size_t maxCapacity): FIFOBase<T>(values.data(), maxCapacity) {
|
||||
values.reserve(maxCapacity);
|
||||
values.resize(maxCapacity);
|
||||
};
|
||||
FIFO(size_t maxCapacity): FIFOBase<T>(values.data(), maxCapacity),
|
||||
values(maxCapacity) {};
|
||||
|
||||
private:
|
||||
std::vector<T> values;
|
||||
|
@ -45,9 +45,11 @@ public:
|
||||
bool full();
|
||||
size_t size();
|
||||
|
||||
size_t getMaxCapacity() const;
|
||||
|
||||
private:
|
||||
T* values;
|
||||
size_t maxCapacity;
|
||||
size_t maxCapacity = 0;
|
||||
|
||||
size_t readIndex = 0;
|
||||
size_t writeIndex = 0;
|
||||
|
@ -73,4 +73,9 @@ inline size_t FIFOBase<T>::next(size_t current) {
|
||||
return current;
|
||||
}
|
||||
|
||||
template<typename T>
|
||||
inline size_t FIFOBase<T>::getMaxCapacity() const {
|
||||
return maxCapacity;
|
||||
}
|
||||
|
||||
#endif
|
||||
|
@ -45,12 +45,10 @@ ReturnValue_t PusParser::parsePusPackets(const uint8_t *frame,
|
||||
{
|
||||
indexSizePairFIFO.insert(indexSizePair(0, packetSize));
|
||||
if(packetSize == frameSize) {
|
||||
sif::info << "test2" << std::endl;
|
||||
return HasReturnvaluesIF::RETURN_OK;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
// packet size is smaller than frame size, parse for more packets.
|
||||
return readMultiplePackets(frame, frameSize, packetSize);
|
||||
}
|
||||
@ -58,7 +56,6 @@ ReturnValue_t PusParser::parsePusPackets(const uint8_t *frame,
|
||||
ReturnValue_t PusParser::readMultiplePackets(const uint8_t *frame,
|
||||
size_t frameSize, size_t startIndex) {
|
||||
while (startIndex < frameSize) {
|
||||
sif::info << "test" << std::endl;
|
||||
ReturnValue_t result = readNextPacket(frame, frameSize, startIndex);
|
||||
if(result != HasReturnvaluesIF::RETURN_OK) {
|
||||
return result;
|
||||
|
Loading…
Reference in New Issue
Block a user