41 #include "qf_port.hpp"
90 enum_t const maxSignal) noexcept
98 bzero(subscrSto,
static_cast<unsigned>(maxSignal) *
sizeof(
QSubscrList));
122 void const *
const sender,
140 if (e->poolId_ != 0U) {
166 static_cast<void>(active_[p]->POST(e, sender));
unsigned int uint_fast8_t
fast at-least 8-bit unsigned int
void unsubscribeAll(void) const noexcept
Un-subscribes from the delivery of all signals to the active object.
void subscribe(enum_t const sig) const noexcept
Subscribes for delivery of signal sig to the active object.
void unsubscribe(enum_t const sig) const noexcept
Un-subscribes from the delivery of signal sig to the active object.
static QActive * active_[QF_MAX_ACTIVE+1U]
array of registered active objects
static void publish_(QEvt const *const e, void const *const sender, std::uint_fast8_t const qs_id) noexcept
Publish event to the framework.
namespace associated with the QP/C++ framework
@ QS_QF_PUBLISH
an event was published
@ QS_QF_ACTIVE_UNSUBSCRIBE
an AO unsubscribed to an event
@ QS_QF_ACTIVE_SUBSCRIBE
an AO subscribed to an event
void QF_EVT_REF_CTR_INC_(QEvt const *const e) noexcept
increment the refCtr_ of an event e
enum_t QF_maxPubSignal_
the maximum published signal
constexpr enum_t Q_USER_SIG
Offset or the user signals.
QSubscrList * QF_subscrList_
the subscriber list array
Customizable and memory-efficient assertions for embedded systems.
#define Q_DEFINE_THIS_MODULE(name_)
Define the user-specified module name for assertions in this file.
#define Q_ASSERT_ID(id_, test_)
General purpose assertion with user-specified assertion-id.
#define Q_REQUIRE_ID(id_, test_)
Assertion for checking preconditions with user-specified assertion-id.
int enum_t
alias for enumerations used for event signals
#define QF_CRIT_EXIT_NOP()
No-operation for exiting a critical section.
Internal (package scope) QF/C++ interface.
#define QF_CRIT_STAT_
This is an internal macro for defining the critical section status type.
#define QF_PTR_AT_(base_, i_)
access element at index i_ from the base pointer base_
#define QF_CRIT_X_()
This is an internal macro for exiting a critical section.
#define QF_CRIT_E_()
This is an internal macro for entering a critical section.
#define QF_SCHED_LOCK_(prio_)
Internal macro for selective scheduler locking.
#define QF_SCHED_UNLOCK_()
Internal macro for selective scheduler unlocking.
#define QF_SCHED_STAT_
Internal macro to represent the scheduler lock status.
Dummy definitions of the QS macros that avoid code generation from the QS instrumentation.
#define QS_BEGIN_NOCRIT_PRE_(rec_, qs_id_)
#define QS_OBJ_PRE_(obj_)
#define QS_END_NOCRIT_PRE_()
#define QS_2U8_PRE_(data1_, data2_)
#define QS_SIG_PRE_(sig_)
Internal (package scope) QS/C++ interface.
QS/C++ port to a 32-bit CPU, generic compiler.
#define QF_MAX_ACTIVE
The maximum number of active objects in the application.
Priority Set of up to 32 elements */.
void rmove(std::uint_fast8_t const n) noexcept
remove element n from the set, n = 1..QF_MAX_ACTIVE
bool notEmpty(void) const noexcept
Evaluates to true if the priority set is not empty.
std::uint_fast8_t findMax(void) const noexcept