39 #include "qf_port.hpp"
114 m_free_head = poolSto;
122 while (m_blockSize <
static_cast<QMPoolSize>(blockSize)) {
142 while (poolSize >= blockSize) {
196 static_cast<void>(qs_id);
232 if (m_nFree >
static_cast<QMPoolCtr>(margin)) {
239 void *
const fb_next = fb->
m_next;
258 if (m_nMin > m_nFree) {
263 m_free_head = fb_next;
285 static_cast<void>(qs_id);
unsigned int uint_fast16_t
fast at-least 16-bit unsigned int
unsigned int uint_fast8_t
fast at-least 8-bit unsigned int
unsigned long uint_fast32_t
fast at-least 32-bit unsigned int
static std::uint_fast16_t getPoolMin(std::uint_fast8_t const poolId) noexcept
This function returns the minimum of free entries of the given event pool.
Native QF memory pool class.
void put(void *const b, std::uint_fast8_t const qs_id) noexcept
Returns a memory block back to a memory pool.
void init(void *const poolSto, std::uint_fast32_t poolSize, std::uint_fast16_t blockSize) noexcept
Initializes the native QF event pool.
void * get(std::uint_fast16_t const margin, std::uint_fast8_t const qs_id) noexcept
Obtains a memory block from a memory pool.
namespace associated with the QP/C++ framework
@ QS_QF_MPOOL_GET_ATTEMPT
attempt to get a memory block failed
@ QS_QF_MPOOL_PUT
a memory block was returned to memory pool
@ QS_QF_MPOOL_GET
a memory block was removed from memory pool
std::uint_fast8_t QF_maxPool_
QFreeBlock *volatile m_next
link to the next free block
QF_EPOOL_TYPE_ QF_pool_[QF_MAX_EPOOL]
allocate event pools
Structure representing a free block in the Native QF Memory Pool.
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.
#define Q_DIM(array_)
Helper macro to calculate static dimension of a 1-dim array_.
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 Q_ASSERT_CRIT_(id_, test_)
#define QF_CRIT_X_()
This is an internal macro for exiting a critical section.
#define QF_PTR_RANGE_(x_, min_, max_)
macro to test that a pointer x_ is in range between min_ and max_
#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.
#define QS_BEGIN_NOCRIT_PRE_(rec_, qs_id_)
#define QS_OBJ_PRE_(obj_)
#define QS_MPC_PRE_(ctr_)
#define QS_END_NOCRIT_PRE_()
Internal (package scope) QS/C++ interface.
QS/C++ port to a 32-bit CPU, generic compiler.