40 #include "qf_port.hpp"
52 #error "Source file included in a project NOT based on the QXK kernel"
110 bool signaled =
true;
123 && (m_max_count > 0U)
156 if (m_waitSet.hasElement(p)) {
231 bool signaled =
true;
238 if (m_count < m_max_count) {
242 if (m_waitSet.notEmpty()) {
254 && (thr->m_osObject !=
nullptr)
unsigned int uint16_t
exact-width 16-bit unsigned int
unsigned int uint_fast16_t
fast at-least 16-bit unsigned int
unsigned int uint_fast8_t
fast at-least 8-bit unsigned int
std::uint8_t m_prio
QF priority (1..QF_MAX_ACTIVE) of this active object.
static QActive * active_[QF_MAX_ACTIVE+1U]
array of registered active objects
QHsmAttr m_temp
temporary: transition chain, target state, etc.
Counting Semaphore of the QXK preemptive kernel.
bool wait(std::uint_fast16_t const nTicks=QXTHREAD_NO_TIMEOUT) noexcept
wait (block) on the semaphore
bool signal(void) noexcept
signal (unblock) the semaphore
bool tryWait(void) noexcept
try wait on the semaphore (non-blocking)
Extended (blocking) thread of the QXK preemptive kernel.
QTimeEvt m_timeEvt
time event to handle blocking timeouts
void teArm_(enum_t const sig, std::uint_fast16_t const nTicks) noexcept
bool teDisarm_(void) noexcept
namespace associated with the QP/C++ framework
QMState const * obj
pointer to QMState object
State object for the QP::QMsm class (QM State Machine).
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.
#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.
std::uint8_t volatile lockHolder
prio of the lock holder
#define QXK_ISR_CONTEXT_()
Internal port-specific macro that reports the execution context.
std::uint_fast8_t QXK_sched_(void) noexcept
QXK scheduler finds the highest-priority thread ready to run.
QP::QPSet readySet
ready-set of all threads
QP::QActive *volatile curr
currently executing thread
QXK_Attr QXK_attr_
global attributes of the QXK kernel
Internal (package scope) QXK/C++ interface.
#define QXK_PTR_CAST_(type_, ptr_)
intertnal macro to encapsulate casting of pointers for MISRA deviations
QSignal sig
signal of the event instance
void insert(std::uint_fast8_t const n) noexcept
insert element n into the set, n = 1..QF_MAX_ACTIVE
void rmove(std::uint_fast8_t const n) noexcept
remove element n from the set, n = 1..QF_MAX_ACTIVE