eive-obsw/bsp_hosted/fsfwconfig/FSFWConfig.h.in

78 lines
2.7 KiB
C
Raw Permalink Normal View History

2020-09-30 20:52:51 +02:00
#ifndef CONFIG_FSFWCONFIG_H_
#define CONFIG_FSFWCONFIG_H_
2020-11-02 16:45:35 +01:00
#include <cstddef>
#include <cstdint>
2020-09-30 20:52:51 +02:00
2021-01-07 20:38:07 +01:00
//! Used to determine whether C++ ostreams are used which can increase
//! the binary size significantly. If this is disabled,
//! the C stdio functions can be used alternatively
#define FSFW_CPP_OSTREAM_ENABLED 1
2020-09-30 20:52:51 +02:00
2021-01-14 12:07:11 +01:00
//! More FSFW related printouts depending on level. Useful for development.
#define FSFW_VERBOSE_LEVEL 1
2020-09-30 20:52:51 +02:00
2021-01-07 20:38:07 +01:00
//! Can be used to completely disable printouts, even the C stdio ones.
2021-01-14 12:07:11 +01:00
#if FSFW_CPP_OSTREAM_ENABLED == 0 && FSFW_VERBOSE_LEVEL == 0
#define FSFW_DISABLE_PRINTOUT 0
2021-01-07 20:38:07 +01:00
#endif
#define FSFW_USE_PUS_C_TELEMETRY 1
2021-06-21 17:35:30 +02:00
#define FSFW_USE_PUS_C_TELECOMMANDS 1
2021-01-07 20:38:07 +01:00
//! Can be used to disable the ANSI color sequences for C stdio.
#define FSFW_COLORED_OUTPUT 1
2020-11-02 16:45:35 +01:00
//! If FSFW_OBJ_EVENT_TRANSLATION is set to one,
//! additional output which requires the translation files translateObjects
//! and translateEvents (and their compiled source files)
#define FSFW_OBJ_EVENT_TRANSLATION 1
2020-11-02 16:45:35 +01:00
#if FSFW_OBJ_EVENT_TRANSLATION == 1
//! Specify whether info events are printed too.
#define FSFW_DEBUG_INFO 1
2021-01-07 20:38:07 +01:00
#include "events/translateEvents.h"
#include "objects/translateObjects.h"
2020-11-02 16:45:35 +01:00
#else
#endif
//! When using the newlib nano library, C99 support for stdio facilities
//! will not be provided. This define should be set to 1 if this is the case.
#define FSFW_NO_C99_IO 1
2021-01-07 20:38:07 +01:00
//! Specify whether a special mode store is used for Subsystem components.
#define FSFW_USE_MODESTORE 0
2020-11-02 16:45:35 +01:00
2021-05-17 16:10:53 +02:00
//! Defines if the real time scheduler for linux should be used.
//! If set to 0, this will also disable priority settings for linux
//! as most systems will not allow to set nice values without privileges
//! For embedded linux system set this to 1.
//! If set to 1 the binary needs "cap_sys_nice=eip" privileges to run
#define FSFW_USE_REALTIME_FOR_LINUX 0
2023-02-20 15:02:58 +01:00
#define FSFW_UDP_SEND_WIRETAPPING_ENABLED 0
2020-11-02 16:45:35 +01:00
namespace fsfwconfig {
2021-05-17 16:10:53 +02:00
//! Default timestamp size. The default timestamp will be an seven byte CDC short timestamp.
static constexpr uint8_t FSFW_MISSION_TIMESTAMP_SIZE = 7;
2020-11-02 16:45:35 +01:00
//! Configure the allocated pool sizes for the event manager.
static constexpr size_t FSFW_EVENTMGMR_MATCHTREE_NODES = 240;
static constexpr size_t FSFW_EVENTMGMT_EVENTIDMATCHERS = 120;
static constexpr size_t FSFW_EVENTMGMR_RANGEMATCHERS = 120;
2020-12-29 01:09:59 +01:00
//! Defines the FIFO depth of each commanding service base which
//! also determines how many commands a CSB service can handle in one cycle
2021-05-17 16:10:53 +02:00
//! simultaneously. This will increase the required RAM for
2020-12-29 01:09:59 +01:00
//! each CSB service !
static constexpr uint8_t FSFW_CSB_FIFO_DEPTH = 6;
2021-01-07 20:38:07 +01:00
static constexpr size_t FSFW_PRINT_BUFFER_SIZE = 124;
2021-05-17 16:10:53 +02:00
2021-06-21 17:09:49 +02:00
static constexpr size_t FSFW_MAX_TM_PACKET_SIZE = 2048;
} // namespace fsfwconfig
2020-09-30 20:52:51 +02:00
#endif /* CONFIG_FSFWCONFIG_H_ */