40 #include "qf_port.hpp"
57 #define QF_PTR_INC_(p_) (++(p_))
83 && (active_[p] ==
nullptr));
107 && (active_[p] == a));
111 active_[p] =
nullptr;
112 a->m_state.fun =
nullptr;
153 0U, 1U, 2U, 2U, 3U, 3U, 3U, 3U,
154 4U, 4U, 4U, 4U, 4U, 4U, 4U, 4U
159 #if (QF_MAX_ACTIVE > 16U)
166 #if (QF_MAX_ACTIVE > 8U)
178 return n + log2LUT[x];
unsigned int uint_fast16_t
fast at-least 16-bit unsigned int
unsigned char uint8_t
exact-width 8-bit unsigned int
unsigned int uint_fast8_t
fast at-least 8-bit unsigned int
QActive active object (based on QP::QHsm implementation)
static void bzero(void *const start, std::uint_fast16_t const len) noexcept
Clear a specified region of memory to zero.
static void add_(QActive *const a) noexcept
Register an active object to be managed by the framework.
static QActive * active_[QF_MAX_ACTIVE+1U]
array of registered active objects
static void remove_(QActive *const a) noexcept
Remove the active object from the framework.
namespace associated with the QP/C++ framework
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_REQUIRE_ID(id_, test_)
Assertion for checking preconditions with user-specified assertion-id.
std::uint_fast8_t QF_LOG2(QP::QPSetBits x) noexcept
function that returns (log2(x) + 1), where x is a 32-bit bitmask
Internal (package scope) QF/C++ interface.
#define QF_CRIT_STAT_
This is an internal macro for defining the critical section status type.
#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.
Dummy definitions of the QS macros that avoid code generation from the QS instrumentation.
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.