2020-10-01 13:23:06 +02:00
|
|
|
#ifndef FSFW_TCDISTRIBUTION_TCPACKETCHECK_H_
|
|
|
|
#define FSFW_TCDISTRIBUTION_TCPACKETCHECK_H_
|
2016-06-15 23:48:41 +02:00
|
|
|
|
2021-06-14 11:44:39 +02:00
|
|
|
#include "../FSFW.h"
|
2020-08-13 20:53:35 +02:00
|
|
|
#include "../returnvalues/HasReturnvaluesIF.h"
|
|
|
|
#include "../tmtcservices/PusVerificationReport.h"
|
2020-10-01 13:23:06 +02:00
|
|
|
|
2021-06-13 16:29:13 +02:00
|
|
|
class TcPacketStoredBase;
|
|
|
|
|
2016-06-15 23:48:41 +02:00
|
|
|
/**
|
|
|
|
* This class performs a formal packet check for incoming PUS Telecommand Packets.
|
|
|
|
* Currently, it only checks if the APID and CRC are correct.
|
2020-10-01 13:23:06 +02:00
|
|
|
* @ingroup tc_distribution
|
2016-06-15 23:48:41 +02:00
|
|
|
*/
|
|
|
|
class TcPacketCheck : public HasReturnvaluesIF {
|
|
|
|
protected:
|
2021-06-13 16:29:13 +02:00
|
|
|
/**
|
|
|
|
* Describes the version number a packet must have to pass.
|
|
|
|
*/
|
|
|
|
static constexpr uint8_t CCSDS_VERSION_NUMBER = 0;
|
|
|
|
/**
|
|
|
|
* Describes the secondary header a packet must have to pass.
|
|
|
|
*/
|
|
|
|
static constexpr uint8_t CCSDS_SECONDARY_HEADER_FLAG = 0;
|
|
|
|
/**
|
|
|
|
* Describes the TC Packet PUS Version Number a packet must have to pass.
|
|
|
|
*/
|
2021-06-14 11:44:39 +02:00
|
|
|
#if FSFW_USE_PUS_C_TELECOMMANDS == 1
|
|
|
|
static constexpr uint8_t PUS_VERSION_NUMBER = 2;
|
|
|
|
#else
|
2021-06-13 16:29:13 +02:00
|
|
|
static constexpr uint8_t PUS_VERSION_NUMBER = 1;
|
2021-06-14 11:44:39 +02:00
|
|
|
#endif
|
|
|
|
|
2021-06-13 16:29:13 +02:00
|
|
|
/**
|
|
|
|
* The packet id each correct packet should have.
|
|
|
|
* It is composed of the APID and some static fields.
|
|
|
|
*/
|
|
|
|
uint16_t apid;
|
2016-06-15 23:48:41 +02:00
|
|
|
public:
|
2021-06-13 16:29:13 +02:00
|
|
|
static const uint8_t INTERFACE_ID = CLASS_ID::TC_PACKET_CHECK;
|
|
|
|
static const ReturnValue_t ILLEGAL_APID = MAKE_RETURN_CODE( 0 );
|
|
|
|
static const ReturnValue_t INCOMPLETE_PACKET = MAKE_RETURN_CODE( 1 );
|
|
|
|
static const ReturnValue_t INCORRECT_CHECKSUM = MAKE_RETURN_CODE( 2 );
|
|
|
|
static const ReturnValue_t ILLEGAL_PACKET_TYPE = MAKE_RETURN_CODE( 3 );
|
|
|
|
static const ReturnValue_t ILLEGAL_PACKET_SUBTYPE = MAKE_RETURN_CODE( 4 );
|
|
|
|
static const ReturnValue_t INCORRECT_PRIMARY_HEADER = MAKE_RETURN_CODE( 5 );
|
|
|
|
static const ReturnValue_t INCORRECT_SECONDARY_HEADER = MAKE_RETURN_CODE( 6 );
|
|
|
|
/**
|
|
|
|
* The constructor only sets the APID attribute.
|
|
|
|
* @param set_apid The APID to set.
|
|
|
|
*/
|
|
|
|
TcPacketCheck(uint16_t setApid);
|
|
|
|
/**
|
|
|
|
* This is the actual method to formally check a certain Telecommand Packet.
|
|
|
|
* The packet's Application Data can not be checked here.
|
|
|
|
* @param current_packet The packt to check
|
|
|
|
* @return - @c RETURN_OK on success.
|
|
|
|
* - @c INCORRECT_CHECKSUM if checksum is invalid.
|
|
|
|
* - @c ILLEGAL_APID if APID does not match.
|
|
|
|
*/
|
|
|
|
ReturnValue_t checkPacket(TcPacketStoredBase* currentPacket);
|
2016-06-15 23:48:41 +02:00
|
|
|
|
2021-06-13 16:29:13 +02:00
|
|
|
uint16_t getApid() const;
|
2016-06-15 23:48:41 +02:00
|
|
|
};
|
|
|
|
|
2020-10-01 13:23:06 +02:00
|
|
|
#endif /* FSFW_TCDISTRIBUTION_TCPACKETCHECK_H_ */
|