81template <u
int8_t TMode, u
int32_t TSize,
class TStrategy,
class TPlatform>
200 if (TStrategy::WEIGHT_API)
207 int32_t
GetWeight()
const {
return (TStrategy::WEIGHT_API ?
m_user->GetWeight() : 1); }
502 m_hrt[0].periodicity = periodicity_tc;
503 m_hrt[0].deadline = deadline_tc;
505 if (start_delay_tc > 0)
530 m_hrt[0].duration = 0;
531 m_hrt[0].done =
false;
545 m_user->OnDeadlineMissed(duration);
554 m_hrt[0].done =
true;
555 __stk_full_memfence();
577 if (TStrategy::SLEEP_EVENT_API)
584 __stk_full_memfence();
642 const Ticks deadline = now + ticks;
645 for (; now < deadline; now =
GetTicks())
743 m_platform =
static_cast<TPlatform *
>(platform);
787 #if !STK_TICKLESS_IDLE
789 "STK_TICKLESS_IDLE must be defined to 1 for KERNEL_TICKLESS");
929 #if STK_SEGGER_SYSVIEW
930 SEGGER_SYSVIEW_Start();
935 SendTaskTraceInfo(task);
1011 #if STK_NEED_TASK_ID
1025 #if STK_NEED_TASK_ID
1041 for (uint32_t i = 0; i <
TASKS_MAX; ++i)
1053 if (new_task ==
nullptr)
1056 #if defined(NDEBUG) && !defined(_STK_ASSERT_REDIRECT)
1075 #if STK_SEGGER_SYSVIEW
1077 SEGGER_SYSVIEW_OnTaskCreate(task->
GetUserStack()->tid);
1079 SendTaskTraceInfo(task);
1110 task->
HrtInit(periodicity_tc, deadline_tc, start_delay_tc);
1145 for (uint32_t i = 0; i <
TASKS_MAX; ++i)
1161 for (uint32_t i = 0; i <
TASKS_MAX; ++i)
1182 for (uint32_t i = 0; i <
TASKS_MAX; ++i)
1205 #if STK_SEGGER_SYSVIEW
1206 SEGGER_SYSVIEW_OnTaskTerminate(task->
GetUserStack()->tid);
1228 if (TStrategy::SLEEP_EVENT_API)
1230 for (uint32_t i = 0; i <
TASKS_MAX; ++i)
1280 #if STK_SEGGER_SYSVIEW
1281 SEGGER_SYSVIEW_OnTaskStartExec(
m_task_now->tid);
1323 #if !STK_TICKLESS_IDLE
1332 #if STK_TICKLESS_IDLE
1433 if (sync_obj->
GetHead() ==
nullptr)
1494 for (uint32_t i = 0; i <
TASKS_MAX; ++i)
1516 if (TStrategy::SLEEP_EVENT_API)
1531 if (TStrategy::SLEEP_EVENT_API)
1549 bool can_recover =
false;
1552 if (TStrategy::DEADLINE_MISSED_API)
1553 can_recover =
m_strategy.OnTaskDeadlineMissed(task);
1578 sleep_ticks =
stk::Min(sleep_ticks, task_sleep);
1582 sleep_ticks =
stk::Min(sleep_ticks, task_sleep);
1587 sleep_ticks =
stk::Min(sleep_ticks, task_sleep);
1606 while (itr !=
nullptr)
1612 if (!
static_cast<ISyncObject *
>(itr)->Tick(elapsed_ticks))
1636 for (uint32_t i = 0; i <
TASKS_MAX; ++i)
1645 __stk_full_memfence();
1694#ifdef _STK_UNDER_TEST
1711 bool switch_context =
false;
1718 switch_context =
StateSwitch(now, next, idle, active);
1721 switch_context =
StateSleep(now, next, idle, active);
1724 switch_context =
StateWake(now, next, idle, active);
1727 switch_context =
StateExit(now, next, idle, active);
1730 return switch_context;
1738 return switch_context;
1779 #if STK_SEGGER_SYSVIEW
1781 SEGGER_SYSVIEW_OnTaskStartReady(next->
GetUserStack()->tid);
1809 #if STK_SEGGER_SYSVIEW
1810 SEGGER_SYSVIEW_OnTaskStartReady(next->
GetUserStack()->tid);
1838 #if STK_SEGGER_SYSVIEW
1900#if STK_SEGGER_SYSVIEW
1905 void SendTaskTraceInfo(KernelTask *task)
1909 SEGGER_SYSVIEW_TASKINFO info =
1911 .TaskID = task->GetUserStack()->tid,
1912 .sName = task->GetUserTask()->GetTraceName(),
1914 .StackBase =
hw::PtrToWord(task->GetUserTask()->GetStack()),
1915 .StackSize = task->GetUserTask()->GetStackSizeBytes()
1917 SEGGER_SYSVIEW_SendTaskInfo(&info);
#define STK_KERNEL_PANIC(id)
Called when the kernel detects an unrecoverable internal fault.
#define STK_STATIC_ASSERT_N(NAME, X)
Compile-time assertion with a user-defined name suffix.
#define __stk_forceinline
Forces compiler to always inline the decorated function, regardless of optimisation level.
#define STK_TICKLESS_IDLE
Enables tickless (dynamic-tick) low-power operation during idle periods.
#define STK_ASSERT(e)
Runtime assertion. Halts execution if the expression e evaluates to false.
#define __stk_attr_noinline
Prevents compiler from inlining the decorated function (function prefix).
#define STK_TICKLESS_TICKS_MAX
Maximum number of kernel ticks the hardware timer may be suppressed in one tickless idle interval whe...
#define STK_STATIC_ASSERT_DESC(X, DESC)
Compile-time assertion with a custom error description. Produces a compilation error if X is false.
#define STK_STACK_MEMORY_FILLER
Sentinel value written to the entire stack region at initialization (stack watermark pattern).
#define STK_ALLOCATE_COUNT(MODE, FLAG, ONTRUE, ONFALSE)
Selects a static array element count at compile time based on a mode flag.
Contains helper implementations which simplify user-side code.
Earliest Deadline First (EDF) task-switching strategy (stk::SwitchStrategyEDF).
Fixed-priority preemptive task-switching strategy with round-robin within each priority level (stk::S...
Rate-Monotonic (RM) and Deadline-Monotonic (DM) task-switching strategies (stk::SwitchStrategyMonoton...
Round-Robin task-switching strategy (stk::SwitchStrategyRoundRobin / stk::SwitchStrategyRR).
Smooth Weighted Round-Robin task-switching strategy (stk::SwitchStrategySmoothWeightedRoundRobin / st...
#define __stk_relax_cpu
Emits a CPU pipeline-relaxation hint for use inside hot busy-wait (spin) loops (in-code statement).
Namespace of STK package.
uintptr_t Word
Native processor word type.
const Timeout WAIT_INFINITE
Timeout value: block indefinitely until the synchronization object is signaled.
int64_t Ticks
Ticks value.
int32_t Timeout
Timeout time (ticks).
@ STACK_SLEEP_TRAP
Stack of the Sleep trap.
@ STACK_USER_TASK
Stack of the user task.
@ STACK_EXIT_TRAP
Stack of the Exit trap.
constexpr T Max(T a, T b) noexcept
Compile-time maximum of two values.
constexpr T Min(T a, T b) noexcept
Compile-time minimum of two values.
@ PERIODICITY_DEFAULT
Default periodicity (microseconds), 1 millisecond.
@ PERIODICITY_MAX
Maximum periodicity (microseconds), 99 milliseconds (note: this value is the highest working on a rea...
@ SYS_TASK_ID_EXIT
Exit trap.
@ SYS_TASK_ID_SLEEP
Sleep trap.
@ ACCESS_PRIVILEGED
Privileged access mode (access to hardware is fully unrestricted).
@ KERNEL_TICKLESS
Tickless mode. To use this mode STK_TICKLESS_IDLE must be defined to 1 in stk_config....
@ KERNEL_SYNC
Synchronization support (see Event).
@ KERNEL_HRT
Hard Real-Time (HRT) behavior (tasks are scheduled periodically and have an execution deadline,...
@ KERNEL_STATIC
All tasks are static and can not exit.
@ KERNEL_DYNAMIC
Tasks can be added or removed and therefore exit when done.
@ KERNEL_PANIC_BAD_MODE
Kernel is in bad/unsupported mode for the current operation.
@ KERNEL_PANIC_BAD_STATE
Kernel entered unexpected (bad) state.
__stk_forceinline void WriteVolatile64(volatile T *addr, T value)
Atomically write a 64-bit volatile value.
__stk_forceinline Word PtrToWord(T *ptr) noexcept
Cast a pointer to a CPU register-width integer.
bool IsInsideISR()
Check whether the CPU is currently executing inside a hardware interrupt service routine (ISR).
__stk_forceinline T ReadVolatile64(volatile const T *addr)
Atomically read a 64-bit volatile value.
volatile uint8_t m_request
Bitmask of pending ERequest flags from running tasks. Written by tasks, read/cleared by UpdateTaskReq...
static bool IsStaticMode()
bool UpdateFsmState(Stack *&idle, Stack *&active)
Update FSM state.
TStrategy m_strategy
Task-switching strategy (determines which task runs next).
KernelTask * AllocateNewTask(ITask *user_task)
Allocate new instance of KernelTask.
void OnStart(Stack *&active)
Called by platform driver immediately after a scheduler start (first tick).
SyncObjectList m_sync_list[((((TMode) &(KERNEL_SYNC)) !=0U) ?(1) :(0))]
List of active sync objects. Zero-size (no memory) if KERNEL_SYNC is not set.
EFsmState
Finite-state machine (FSM) state. Encodes what the kernel is currently doing between two consecutive ...
@ FSM_STATE_EXITING
All tasks exited (KERNEL_DYNAMIC only), executing the exit trap to return from Start().
@ FSM_STATE_SLEEPING
All tasks are sleeping, the sleep trap is executing (CPU in low-power state).
@ FSM_STATE_SWITCHING
Normal operation: switching between runnable tasks each tick.
@ FSM_STATE_NONE
Sentinel / uninitialized value. Set by the constructor, replaced by FSM_STATE_SWITCHING on the first ...
@ FSM_STATE_MAX
Sentinel: number of valid states (used to size the FSM table), denotes uninitialized state.
@ FSM_STATE_WAKING
At least one task woke up, transitioning from sleep trap back to a user task.
KernelTask * FindTaskByStack(const Stack *stack)
Find kernel task by the bound Stack instance.
KernelTask TaskStorageType[TASKS_MAX]
KernelTask array type used as a storage for the KernelTask instances.
volatile EState m_state
Current kernel state.
SleepTrapStack m_sleep_trap[1]
Sleep trap (always present): executed when all tasks are sleeping.
void OnTaskSwitch(Word caller_SP)
Called by Thread process (via IKernelService::SwitchToNext) to switch to a next task.
EFsmState GetNewFsmState(KernelTask *&next)
Get new FSM state.
void RequestAddTask(ITask *user_task)
Request to add new task.
void AddTask(ITask *user_task, Timeout periodicity_tc, Timeout deadline_tc, Timeout start_delay_tc)
Register a task for hard real-time (HRT) scheduling.
StackMemoryWrapper< STACK_SIZE_MIN > ExitTrapStackMemory
Stack memory wrapper type for the exit trap.
void Initialize(uint32_t resolution_us=PERIODICITY_DEFAULT)
Prepare kernel for use: reset state, configure the platform, and register the service singleton.
bool StateWake(KernelTask *now, KernelTask *next, Stack *&idle, Stack *&active)
Wakes up after sleeping.
bool OnTick(Stack *&idle, Stack *&active)
Process one scheduler tick. Called from the platform timer/tick ISR.
EState GetState() const
Get kernel state.
KernelTask * FindTaskBySP(Word SP)
Find kernel task for a Stack Pointer (SP).
void InitTraps()
Initialize stack of the traps.
void OnTaskSleepUntil(Word caller_SP, Ticks timestamp)
Called by Thread process (via IKernelService::SleepUntil) for exclusion of the calling process from s...
ISyncObject::ListHeadType SyncObjectList
Intrusive list of active ISyncObject instances registered with this kernel. Each sync object in this ...
ExitTrapStack m_exit_trap[((((TMode) &(KERNEL_DYNAMIC)) !=0U) ?(1) :(0))]
Exit trap: zero-size in KERNEL_STATIC mode; one entry in KERNEL_DYNAMIC mode.
EFsmEvent
Finite-state machine (FSM) event. Computed by FetchNextEvent() each tick based on strategy output and...
@ FSM_EVENT_EXIT
No tasks remain (KERNEL_DYNAMIC), exit scheduling and return from Start().
@ FSM_EVENT_WAKE
A task became runnable while the kernel was sleeping, wake from sleep trap.
@ FSM_EVENT_SLEEP
No runnable tasks, enter sleep trap.
@ FSM_EVENT_SWITCH
Strategy returned a runnable task, perform a context switch.
@ FSM_EVENT_MAX
Sentinel: number of valid events (used to size the FSM table).
IWaitObject * OnTaskWait(Word caller_SP, ISyncObject *sync_obj, IMutex *mutex, Timeout timeout)
Called from the Thread process when task needs to wait.
ITaskSwitchStrategy * GetSwitchStrategy()
Get task-switching strategy instance owned by this kernel.
KernelTask * FindTaskByUserTask(const ITask *user_task)
Find kernel task by the bound ITask instance.
static bool IsValidFsmState(EFsmState state)
Check if FSM state is valid.
TaskStorageType m_task_storage
Static pool of TSize KernelTask slots (free slots have m_user == nullptr).
void RemoveTask(KernelTask *task)
Remove kernel task.
void Start()
Start the scheduler. This call does not return until all tasks have exited (KERNEL_DYNAMIC mode) or i...
void AddKernelTask(KernelTask *task)
Add kernel task to the scheduling strategy.
static bool IsDynamicMode()
KernelService m_service
Kernel service singleton exposed to running tasks via IKernelService::GetInstance().
void RemoveTask(ITask *user_task)
Remove a previously added task from the kernel before Start().
ERequest
Bitmask flags for pending inter-task requests that must be processed by the kernel on the next tick (...
@ REQUEST_NONE
No pending requests.
@ REQUEST_ADD_TASK
An AddTask() request is pending from a running task (KERNEL_DYNAMIC only).
bool StateExit(KernelTask *now, KernelTask *next, Stack *&idle, Stack *&active)
Exits from scheduling.
KernelTask * m_task_now
Currently executing task, or nullptr before Start() or after all tasks exit.
TId OnGetTid(Word caller_SP)
Called from the Thread process when for getting task/thread id of the process.
void AllocateAndAddNewTask(ITask *user_task)
Allocate new instance of KernelTask and add it into the scheduling process.
TPlatform m_platform
Platform driver (SysTick, PendSV, context switch implementation).
void HrtAllocateAndAddNewTask(ITask *user_task, Timeout periodicity_tc, Timeout deadline_tc, Timeout start_delay_tc)
Allocate new instance of KernelTask and add it into the HRT scheduling process.
EFsmState m_fsm_state
Current FSM state. Drives context-switch decision on every tick.
Timeout UpdateTasks(const Timeout elapsed_ticks)
Update tasks (sleep, requests).
void ScheduleAddTask()
Signal the kernel to process a pending AddTask request on the next tick.
bool IsInitialized() const
Check whether Initialize() has been called and completed successfully.
IPlatform * GetPlatform()
Get platform driver instance owned by this kernel.
bool StateSwitch(KernelTask *now, KernelTask *next, Stack *&idle, Stack *&active)
Switches contexts.
StackMemoryWrapper<(32)> SleepTrapStackMemory
Stack memory wrapper type for the sleep trap.
static bool IsTicklessMode()
void OnTaskExit(Stack *stack)
Called from the Thread process when task finished (its Run function exited by return).
Kernel()
Construct the kernel with all storage zero-initialised and the request flag set to ~0 (indicating uni...
@ TASKS_MAX
Maximum number of concurrently registered tasks. Fixed at compile time. Exceeding this limit in AddTa...
void UpdateTaskRequest()
Update pending task requests.
bool StateSleep(KernelTask *now, KernelTask *next, Stack *&idle, Stack *&active)
Enters into a sleeping mode.
Timeout UpdateTaskState(const Timeout elapsed_ticks)
Update task state: process removals, advance sleep timers, and track HRT durations.
void OnStop()
Called by the platform driver after a scheduler stop (all tasks have exited).
void UpdateSyncObjects(const Timeout elapsed_ticks)
Update synchronization objects.
void OnTaskSleep(Word caller_SP, Timeout ticks)
Called by Thread process (via IKernelService::Sleep) for exclusion of the calling process from schedu...
bool IsStarted() const
Check whether scheduler is currently running.
const EFsmState m_fsm[FSM_STATE_MAX][FSM_EVENT_MAX]
void AddTask(ITask *user_task)
Register task for a soft real-time (SRT) scheduling.
EFsmEvent FetchNextEvent(KernelTask *&next)
Fetch next event for the FSM.
Internal per-slot kernel descriptor that wraps a user ITask instance.
KernelTask()
Construct a free (unbound) task slot. All fields set to zero/null.
void ScheduleSleep(Timeout ticks)
Put the task into a sleeping state for the specified number of ticks.
TId GetTid() const
Get task identifier.
int32_t m_rt_weight[((((TStrategy::WEIGHT_API) &(1)) !=0U) ?(1) :(0))]
Run-time weight for weighted-round-robin scheduling. Zero-size for unweighted strategies.
WaitObject m_wait_obj[((((TMode) &(KERNEL_SYNC)) !=0U) ?(1) :(0))]
Embedded wait object for synchronization. Zero-size (no memory) if KERNEL_SYNC is not set.
void SetCurrentWeight(int32_t weight)
Update the run-time scheduling weight (weighted strategies only).
bool HrtIsDeadlineMissed(Timeout duration) const
Check if deadline missed.
EStateFlags
Bitmask of transient state flags. Set by the task or the kernel and consumed (cleared) during UpdateT...
@ STATE_REMOVE_PENDING
Task returned from its Run function; slot will be freed on the next tick (KERNEL_DYNAMIC only).
@ STATE_SLEEP_PENDING
Task called Sleep/SleepUntil/Yield; strategy's OnTaskSleep() will be invoked on the next tick (sleep-...
@ STATE_NONE
No pending state flags.
void ScheduleRemoval()
Schedule the removal of the task from the kernel on next tick.
Timeout GetHrtRelativeDeadline() const
Get remaining HRT deadline (ticks left before the deadline expires).
Stack m_stack
Stack descriptor (SP register value + access mode + optional tid).
Stack * GetUserStack()
Get stack descriptor for this task slot.
void Bind(TPlatform *platform, ITask *user_task)
Bind this slot to a user task: set access mode, task ID, and initialise the stack.
void HrtHardFailDeadline(IPlatform *platform)
Hard-fail HRT task when it missed its deadline.
void HrtInit(Timeout periodicity_tc, Timeout deadline_tc, Timeout start_delay_tc)
Initialize task with HRT info.
volatile uint32_t m_state
Bitmask of EStateFlags. Written by task thread, read/cleared by kernel tick.
int32_t GetCurrentWeight() const
Get current (run-time) scheduling weight.
ITask * GetUserTask()
Get bound user task.
ITask * m_user
Bound user task, or NULL when slot is free.
bool IsBusy() const
Check whether this slot is bound to a user task.
void HrtOnWorkCompleted()
Called when task process called IKernelService::SwitchToNext to inform Kernel that work is completed.
void Wake()
Wake this task on the next scheduling tick.
HrtInfo m_hrt[((((TMode) &(KERNEL_HRT)) !=0U) ?(1) :(0))]
HRT metadata. Zero-size (no memory) in non-HRT mode.
Timeout GetHrtDeadline() const
Get absolute HRT deadline (ticks elapsed since task was activated).
SrtInfo m_srt[((((TMode) &(KERNEL_HRT)) !=0U) ?(0) :(1))]
SRT metadata. Zero-size (no memory) in KERNEL_HRT mode.
volatile Timeout m_time_sleep
Sleep countdown: negative while sleeping (absolute value = ticks remaining), zero when awake.
bool IsPendingRemoval() const
Check if task is pending removal.
void HrtOnSwitchedOut(IPlatform *)
Called when task is switched out from the scheduling process.
void Unbind()
Reset this slot to the free (unbound) state, clearing all scheduling metadata.
void HrtOnSwitchedIn()
Called when task is switched into the scheduling process.
bool IsMemoryOfSP(Word SP) const
Check if Stack Pointer (SP) belongs to this task.
int32_t GetWeight() const
Get static scheduling weight from the user task.
Timeout GetHrtPeriodicity() const
Get HRT scheduling periodicity.
bool IsSleeping() const
Check whether this task is currently sleeping (waiting for a tick or a wake event).
Payload for an in-flight AddTask() request issued by a running task.
ITask * user_task
User task to add. Must remain valid for the lifetime of its kernel slot.
Per-task soft real-time (SRT) metadata.
void Clear()
Clear all fields, ready for slot re-use.
AddTaskRequest * add_task_req
Per-task Hard Real-Time (HRT) scheduling metadata.
void Clear()
Clear all fields, ready for slot re-use or re-activation.
volatile bool done
Set to true when the task signals work completion (via Yield() or on exit). Triggers HrtOnSwitchedOut...
Timeout deadline
Maximum allowed active duration in ticks (relative to switch-in). Exceeding this triggers OnDeadlineM...
Timeout periodicity
Activation period in ticks: the task is re-activated every this many ticks.
Timeout duration
Ticks spent in the active (non-sleeping) state in the current period. Incremented by UpdateTaskState(...
Concrete implementation of IWaitObject, embedded in each KernelTask slot.
bool IsWaiting() const
Check if busy with waiting.
bool Tick(Timeout elapsed_ticks)
Advance the timeout countdown by one tick.
Timeout m_time_wait
Ticks remaining until timeout. Decremented each tick; WAIT_INFINITE means no timeout.
bool IsTimeout() const
Check whether the wait expired due to timeout.
void Wake(bool timeout)
Wake the waiting task (called by ISyncObject when it signals).
void SetupWait(ISyncObject *sync_obj, Timeout timeout)
Configure and arm this wait object for a new wait operation.
TId GetTid() const
Get the TId of the task that owns this wait object.
volatile bool m_timeout
true if the wait expired due to timeout rather than a Wake() signal.
ISyncObject * m_sync_obj
Sync object this wait is registered with, or NULL when not waiting.
KernelTask * m_task
Back-pointer to the owning KernelTask. Set once at construction; never changes.
Payload stored in the sync object's kernel-side list entry while a task is waiting.
ISyncObject * sync_obj
Sync object whose Tick() will be called each kernel tick.
Concrete implementation of IKernelService exposed to running tasks.
KernelService()
Construct an uninitialised service instance (m_platform = null, m_ticks = 0).
IWaitObject * Wait(ISyncObject *sobj, IMutex *mutex, Timeout ticks)
Block the calling task until a synchronization object signals or the timeout expires.
volatile Ticks m_ticks
Global tick counter. Written via hw::WriteVolatile64() by IncrementTick() (ISR context); read via hw:...
~KernelService()
Destructor.
void SwitchToNext()
Yield the CPU to the next runnable task.
Ticks GetTicks() const
Get the current tick count since kernel start.
void Sleep(Timeout ticks)
Yield the CPU for ticks, allowing the scheduler to run other tasks.
TPlatform * m_platform
Typed platform driver pointer, set at Initialize().
int32_t GetTickResolution() const
Get the tick resolution.
void SleepUntil(Ticks timestamp)
Yield the CPU till timestamp, allowing the scheduler to run other tasks.
TId GetTid() const
Get the TId of the calling task.
void Delay(Timeout ticks)
Busy-wait until ticks have elapsed.
void IncrementTicks(Ticks advance)
Increment counter by value.
void Initialize(IPlatform *platform)
Initialize instance.
Storage bundle for the sleep trap: a Stack descriptor paired with its backing memory.
SleepTrapStackMemory::MemoryType Memory
Memory memory
Backing stack memory array. Size: STK_SLEEP_TRAP_STACK_SIZE elements of Word.
Stack stack
Stack descriptor (SP register value + access mode). Initialised by InitTraps() on every Start().
Storage bundle for the exit trap: a Stack descriptor paired with its backing memory.
Memory memory
Backing stack memory array. Size: STACK_SIZE_MIN elements of Word.
ExitTrapStackMemory::MemoryType Memory
Stack stack
Stack descriptor (SP register value + access mode). Initialised by InitTraps() on every Start().
RAII guard that enters the critical section on construction and exits it on destruction.
EAccessMode mode
access mode
virtual Word * GetStack() const =0
Get pointer to the stack memory.
DLEntryType ListEntryType
List entry type of ISyncObject elements.
virtual void AddWaitObject(IWaitObject *wobj)
Called by kernel when a new task starts waiting on this event.
DLHeadType ListHeadType
List head type for ISyncObject elements.
Interface for mutex synchronization primitive.
virtual void Unlock()=0
Unlock the mutex.
virtual void Lock()=0
Lock the mutex.
Interface for a user task.
virtual EAccessMode GetAccessMode() const =0
Get hardware access mode of the user task.
virtual TId GetId() const =0
Get task Id set by application.
Scheduling-strategy-facing interface for a kernel task slot.
Interface for a platform driver.
virtual void ProcessHardFault()=0
Cause a hard fault of the system.
Interface for a back-end event handler.
Interface for a task switching strategy implementation.
Interface for the implementation of the kernel of the scheduler. It supports Soft and Hard Real-Time ...
@ STATE_INACTIVE
not ready, IKernel::Initialize() must be called
@ STATE_READY
ready to start, IKernel::Start() must be called
@ STATE_RUNNING
initialized and running, IKernel::Start() was called successfully
Interface for the kernel services exposed to the user processes during run-time when Kernel started s...
Adapts an externally-owned stack memory array to the IStackMemory interface.
StackMemoryDef< _StackSize >::Type MemoryType
DLHeadType * GetHead() const
Get the list head this entry currently belongs to.
DLEntryType * GetNext() const
Get the next entry in the list.