v1.9.0 #175
@ -14,6 +14,12 @@
|
|||||||
debugging. */
|
debugging. */
|
||||||
#define OBSW_VEBOSE_LEVEL 1
|
#define OBSW_VEBOSE_LEVEL 1
|
||||||
|
|
||||||
|
#define OBSW_USE_CCSDS_IP_CORE 0
|
||||||
|
// Set to 1 if all telemetry should be sent to the PTME IP Core
|
||||||
|
#define OBSW_TM_TO_PTME 0
|
||||||
|
// Set to 1 if telecommands are received via the PDEC IP Core
|
||||||
|
#define OBSW_TC_FROM_PDEC 0
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
|
|
||||||
#include "objects/systemObjectList.h"
|
#include "objects/systemObjectList.h"
|
||||||
|
@ -1,7 +0,0 @@
|
|||||||
CXXSRC += $(wildcard $(CURRENTPATH)/cdatapool/*.cpp)
|
|
||||||
CXXSRC += $(wildcard $(CURRENTPATH)/ipc/*.cpp)
|
|
||||||
CXXSRC += $(wildcard $(CURRENTPATH)/objects/*.cpp)
|
|
||||||
CXXSRC += $(wildcard $(CURRENTPATH)/pollingsequence/*.cpp)
|
|
||||||
CXXSRC += $(wildcard $(CURRENTPATH)/events/*.cpp)
|
|
||||||
|
|
||||||
INCLUDES += $(CURRENTPATH)
|
|
@ -935,13 +935,13 @@ void ObjectFactory::createCcsdsComponents(LinuxLibgpioIF *gpioComIF) {
|
|||||||
CCSDSHandler* ccsdsHandler = new CCSDSHandler(objects::CCSDS_HANDLER, objects::PTME);
|
CCSDSHandler* ccsdsHandler = new CCSDSHandler(objects::CCSDS_HANDLER, objects::PTME);
|
||||||
|
|
||||||
VirtualChannel* vc = nullptr;
|
VirtualChannel* vc = nullptr;
|
||||||
vc = new VirtualChannel(ccsds::VC0, config::VC0_QUEUE_SIZE);
|
vc = new VirtualChannel(ccsds::VC0, common::VC0_QUEUE_SIZE);
|
||||||
ccsdsHandler->addVirtualChannel(ccsds::VC0, vc);
|
ccsdsHandler->addVirtualChannel(ccsds::VC0, vc);
|
||||||
vc = new VirtualChannel(ccsds::VC1, config::VC1_QUEUE_SIZE);
|
vc = new VirtualChannel(ccsds::VC1, common::VC1_QUEUE_SIZE);
|
||||||
ccsdsHandler->addVirtualChannel(ccsds::VC1, vc);
|
ccsdsHandler->addVirtualChannel(ccsds::VC1, vc);
|
||||||
vc = new VirtualChannel(ccsds::VC2, config::VC2_QUEUE_SIZE);
|
vc = new VirtualChannel(ccsds::VC2, common::VC2_QUEUE_SIZE);
|
||||||
ccsdsHandler->addVirtualChannel(ccsds::VC2, vc);
|
ccsdsHandler->addVirtualChannel(ccsds::VC2, vc);
|
||||||
vc = new VirtualChannel(ccsds::VC3, config::VC3_QUEUE_SIZE);
|
vc = new VirtualChannel(ccsds::VC3, common::VC3_QUEUE_SIZE);
|
||||||
ccsdsHandler->addVirtualChannel(ccsds::VC3, vc);
|
ccsdsHandler->addVirtualChannel(ccsds::VC3, vc);
|
||||||
|
|
||||||
GpioCookie* gpioRS485Chip = new GpioCookie;
|
GpioCookie* gpioRS485Chip = new GpioCookie;
|
||||||
|
@ -7,19 +7,23 @@
|
|||||||
|
|
||||||
// Disable this for mission code. It allows exchanging TMTC packets via the Ethernet port
|
// Disable this for mission code. It allows exchanging TMTC packets via the Ethernet port
|
||||||
#define OBSW_ADD_TCPIP_BRIDGE 1
|
#define OBSW_ADD_TCPIP_BRIDGE 1
|
||||||
|
|
||||||
// Use TCP instead of UDP for the TMTC bridge. This allows using the TMTC client locally
|
// Use TCP instead of UDP for the TMTC bridge. This allows using the TMTC client locally
|
||||||
// because UDP packets are not allowed in the VPN
|
// because UDP packets are not allowed in the VPN
|
||||||
// This will cause the OBSW to initialize the TMTC bridge responsible for exchanging data with the
|
// This will cause the OBSW to initialize the TMTC bridge responsible for exchanging data with the
|
||||||
// CCSDS IP Cores.
|
// CCSDS IP Cores.
|
||||||
#define OBSW_USE_CCSDS_IP_CORE 1
|
|
||||||
// Set to 1 if all telemetry should be sent to the PTME IP Core
|
|
||||||
#define OBSW_TM_TO_PTME 1
|
|
||||||
// Set to 1 if telecommands are received via the PDEC IP Core
|
|
||||||
#define OBSW_TC_FROM_PDEC 0
|
|
||||||
#define OBSW_USE_TCP_BRIDGE 1
|
#define OBSW_USE_TCP_BRIDGE 1
|
||||||
|
|
||||||
namespace common {
|
namespace common {
|
||||||
extern const uint16_t TC_PACKET_ID;
|
extern const uint16_t TC_PACKET_ID;
|
||||||
|
|
||||||
|
static constexpr uint32_t CCSDS_HANDLER_QUEUE_SIZE = 50;
|
||||||
|
static constexpr uint8_t NUMBER_OF_VIRTUAL_CHANNELS = 4;
|
||||||
|
static constexpr uint8_t VC0_QUEUE_SIZE = 50;
|
||||||
|
static constexpr uint8_t VC1_QUEUE_SIZE = 50;
|
||||||
|
static constexpr uint8_t VC2_QUEUE_SIZE = 50;
|
||||||
|
static constexpr uint8_t VC3_QUEUE_SIZE = 50;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif /* COMMON_CONFIG_COMMONCONFIG_H_ */
|
#endif /* COMMON_CONFIG_COMMONCONFIG_H_ */
|
||||||
|
2
fsfw
2
fsfw
@ -1 +1 @@
|
|||||||
Subproject commit b985bf5167be74c0d43bd70c501eb5f9640bd99e
|
Subproject commit ad68802fe4af9af554bd8221c607ba1f4d87185b
|
@ -33,6 +33,12 @@ debugging. */
|
|||||||
//! All of this should be enabled for mission code!
|
//! All of this should be enabled for mission code!
|
||||||
#if defined XIPHOS_Q7S
|
#if defined XIPHOS_Q7S
|
||||||
|
|
||||||
|
#define OBSW_USE_CCSDS_IP_CORE 1
|
||||||
|
// Set to 1 if all telemetry should be sent to the PTME IP Core
|
||||||
|
#define OBSW_TM_TO_PTME 1
|
||||||
|
// Set to 1 if telecommands are received via the PDEC IP Core
|
||||||
|
#define OBSW_TC_FROM_PDEC 0
|
||||||
|
|
||||||
#define OBSW_ENABLE_TIMERS 1
|
#define OBSW_ENABLE_TIMERS 1
|
||||||
#define OBSW_ADD_STAR_TRACKER 0
|
#define OBSW_ADD_STAR_TRACKER 0
|
||||||
#define OBSW_ADD_PLOC_SUPERVISOR 0
|
#define OBSW_ADD_PLOC_SUPERVISOR 0
|
||||||
@ -124,12 +130,6 @@ namespace config {
|
|||||||
/* Add mission configuration flags here */
|
/* Add mission configuration flags here */
|
||||||
static constexpr uint32_t OBSW_FILESYSTEM_HANDLER_QUEUE_SIZE = 50;
|
static constexpr uint32_t OBSW_FILESYSTEM_HANDLER_QUEUE_SIZE = 50;
|
||||||
static constexpr uint32_t PLOC_UPDATER_QUEUE_SIZE = 50;
|
static constexpr uint32_t PLOC_UPDATER_QUEUE_SIZE = 50;
|
||||||
static constexpr uint32_t CCSDS_HANDLER_QUEUE_SIZE = 50;
|
|
||||||
static constexpr uint8_t NUMBER_OF_VIRTUAL_CHANNELS = 4;
|
|
||||||
static constexpr uint8_t VC0_QUEUE_SIZE = 50;
|
|
||||||
static constexpr uint8_t VC1_QUEUE_SIZE = 50;
|
|
||||||
static constexpr uint8_t VC2_QUEUE_SIZE = 50;
|
|
||||||
static constexpr uint8_t VC3_QUEUE_SIZE = 50;
|
|
||||||
|
|
||||||
static constexpr uint8_t LIVE_TM = 0;
|
static constexpr uint8_t LIVE_TM = 0;
|
||||||
|
|
||||||
|
@ -5,8 +5,7 @@
|
|||||||
#include "fsfw/serviceinterface/ServiceInterface.h"
|
#include "fsfw/serviceinterface/ServiceInterface.h"
|
||||||
#include "PtmeConfig.h"
|
#include "PtmeConfig.h"
|
||||||
|
|
||||||
Ptme::Ptme(object_id_t objectId) :
|
Ptme::Ptme(object_id_t objectId): SystemObject(objectId) {
|
||||||
SystemObject(objectId) {
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Ptme::~Ptme() {
|
Ptme::~Ptme() {
|
||||||
@ -54,7 +53,7 @@ ReturnValue_t Ptme::writeToVc(uint8_t vcId, const uint8_t * data, size_t size) {
|
|||||||
|
|
||||||
void Ptme::addVcInterface(VcId_t vcId, VcInterfaceIF* vc) {
|
void Ptme::addVcInterface(VcId_t vcId, VcInterfaceIF* vc) {
|
||||||
|
|
||||||
if (vcId > config::NUMBER_OF_VIRTUAL_CHANNELS) {
|
if (vcId > common::NUMBER_OF_VIRTUAL_CHANNELS) {
|
||||||
sif::warning << "Ptme::addVcInterface: Invalid virtual channel ID" << std::endl;
|
sif::warning << "Ptme::addVcInterface: Invalid virtual channel ID" << std::endl;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -78,7 +78,7 @@ private:
|
|||||||
static const int PTME_DATA_REG_OFFSET = 256;
|
static const int PTME_DATA_REG_OFFSET = 256;
|
||||||
|
|
||||||
/** The file descriptor of the UIO driver */
|
/** The file descriptor of the UIO driver */
|
||||||
int fd;
|
int fd = 0;
|
||||||
|
|
||||||
uint32_t* ptmeBaseAddress = nullptr;
|
uint32_t* ptmeBaseAddress = nullptr;
|
||||||
|
|
||||||
|
@ -78,7 +78,7 @@ MessageQueueId_t CCSDSHandler::getCommandQueue() const {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void CCSDSHandler::addVirtualChannel(VcId_t vcId, VirtualChannel* virtualChannel) {
|
void CCSDSHandler::addVirtualChannel(VcId_t vcId, VirtualChannel* virtualChannel) {
|
||||||
if (vcId > config::NUMBER_OF_VIRTUAL_CHANNELS) {
|
if (vcId > common::NUMBER_OF_VIRTUAL_CHANNELS) {
|
||||||
sif::warning << "CCSDSHandler::addVirtualChannel: Invalid virtual channel ID" << std::endl;
|
sif::warning << "CCSDSHandler::addVirtualChannel: Invalid virtual channel ID" << std::endl;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -97,7 +97,7 @@ void CCSDSHandler::addVirtualChannel(VcId_t vcId, VirtualChannel* virtualChannel
|
|||||||
}
|
}
|
||||||
|
|
||||||
MessageQueueId_t CCSDSHandler::getReportReceptionQueue(uint8_t virtualChannel) {
|
MessageQueueId_t CCSDSHandler::getReportReceptionQueue(uint8_t virtualChannel) {
|
||||||
if (virtualChannel < config::NUMBER_OF_VIRTUAL_CHANNELS) {
|
if (virtualChannel < common::NUMBER_OF_VIRTUAL_CHANNELS) {
|
||||||
VirtualChannelMapIter iter = virtualChannelMap.find(virtualChannel);
|
VirtualChannelMapIter iter = virtualChannelMap.find(virtualChannel);
|
||||||
if (iter != virtualChannelMap.end()) {
|
if (iter != virtualChannelMap.end()) {
|
||||||
return iter->second->getReportReceptionQueue();
|
return iter->second->getReportReceptionQueue();
|
||||||
|
@ -53,7 +53,7 @@ public:
|
|||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
static const uint32_t QUEUE_SIZE = config::CCSDS_HANDLER_QUEUE_SIZE;
|
static const uint32_t QUEUE_SIZE = common::CCSDS_HANDLER_QUEUE_SIZE;
|
||||||
|
|
||||||
using VirtualChannelMap = std::unordered_map<VcId_t, VirtualChannel*>;
|
using VirtualChannelMap = std::unordered_map<VcId_t, VirtualChannel*>;
|
||||||
using VirtualChannelMapIter = VirtualChannelMap::iterator;
|
using VirtualChannelMapIter = VirtualChannelMap::iterator;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user