SuperTinyKernel™ RTOS 1.06.x
Lightweight, high-performance, deterministic, bare-metal C++ RTOS for resource-constrained embedded systems. MIT Open Source License.
Loading...
Searching...
No Matches
stk_arch_arm-cortex-m.h
Go to the documentation of this file.
1/*
2 * SuperTinyKernel(TM) RTOS: Lightweight High-Performance Deterministic C++ RTOS for Embedded Systems.
3 *
4 * Source: https://github.com/SuperTinyKernel-RTOS
5 *
6 * Copyright (c) 2022-2026 Neutron Code Limited <stk@neutroncode.com>. All Rights Reserved.
7 * License: MIT License, see LICENSE for a full text.
8 */
9
10#ifndef STK_ARCH_ARM_CORTEX_M_H_
11#define STK_ARCH_ARM_CORTEX_M_H_
12
13#include "stk_common.h"
14
18
19namespace stk {
20
24class PlatformArmCortexM final : public IPlatform
25{
26public:
31
32 void Initialize(IEventHandler *event_handler, IKernelService *service, uint32_t resolution_us, Stack *exit_trap) override;
33 void Start() override;
34 void Stop() override;
35 bool InitStack(EStackType stack_type, Stack *stack, IStackMemory *stack_memory, ITask *user_task) override;
36 uint32_t GetTickResolution() const override;
37 Cycles GetSysTimerCount() const override;
38 uint32_t GetSysTimerFrequency() const override;
39 void SwitchToNext() override;
40 void Sleep(Timeout ticks) override;
41 bool SleepUntil(Ticks timestamp) override;
42 IWaitObject *Wait(ISyncObject *sync_obj, IMutex *mutex, Timeout timeout) override;
43 void ProcessTick() override;
44 void ProcessHardFault() override;
45 void SetEventOverrider(IEventOverrider *overrider) override;
46 Word GetCallerSP() const override;
47 TId GetTid() const override;
48 Timeout Suspend() override;
49 void Resume(Timeout elapsed_ticks) override;
50};
51
56
57// Inline TLS via r9. Active when both STK_TLS and STK_TLS_PREFER_REGISTER are
58// enabled. Requires -ffixed-r9 on all translation units containing task code
59// (see GetTls/SetTls warnings below). If -ffixed-r9 is unavailable or
60// undesirable, leave STK_TLS_PREFER_REGISTER disabled; the kernel will fall back
61// to a memory-based TLS slot with a small additional load/store per access.
62#if STK_TLS && STK_TLS_PREFER_REGISTER
63
78{
79 Word tp;
80 __asm volatile("MOV %0, r9" : "=r"(tp) : /* input: none */ : /* clobbers: none */);
81 return tp;
82}
83
93{
94 __asm volatile("MOV r9, %0" : /* output: none */ : "r"(tp) : /* clobbers: none */);
95}
96
97// Notify stk_arch.h that we defined inline versions of GetTls/SetTls.
98#define STK_INLINE_TLS 1
99
100#endif // STK_TLS_PREFER_REGISTER
101
102} // namespace stk
103
107static __stk_forceinline void __stk_dmb() { __asm volatile("dmb sy" ::: "memory"); }
108
113#define __stk_tz_nsc_entry __attribute__((cmse_nonsecure_entry))
114
115#endif /* STK_ARCH_ARM_CORTEX_M_H_ */
static void __stk_dmb()
Contains interface definitions of the library.
#define __stk_forceinline
Forces compiler to always inline the decorated function, regardless of optimisation level.
Definition stk_defs.h:174
#define STK_VIRT_DTOR
Makes destructors virtual and compliant to strict rules if STK_STRICT_COMPLIANCY=0.
Definition stk_defs.h:158
Namespace of STK package.
uintptr_t Word
Native processor word type.
Definition stk_common.h:115
int64_t Ticks
Ticks value.
Definition stk_common.h:130
int32_t Timeout
Timeout time (ticks).
Definition stk_common.h:125
EStackType
Stack type.
Definition stk_common.h:72
__stk_forceinline void SetTls(Word tp)
Set thread-local storage (TLS).
__stk_forceinline Word GetTls()
Get thread-local storage (TLS).
PlatformArmCortexM PlatformDefault
Default platform implementation.
uint64_t Cycles
Cycles value.
Definition stk_common.h:140
Word TId
Definition stk_common.h:120
Concrete implementation of IPlatform driver for the Arm Cortex-M0, M3, M4, M7 processors.
void SwitchToNext() override
Switch to a next task.
void Sleep(Timeout ticks) override
Put calling process into a sleep state.
void ProcessTick() override
Process one tick.
Word GetCallerSP() const override
Get caller's Stack Pointer (SP).
void ProcessHardFault() override
Cause a hard fault of the system.
uint32_t GetTickResolution() const override
Get resolution of the system tick timer in microseconds. Resolution means a number of microseconds be...
Timeout Suspend() override
Suspend scheduling.
void Start() override
Start scheduling.
bool InitStack(EStackType stack_type, Stack *stack, IStackMemory *stack_memory, ITask *user_task) override
Initialize stack memory of the user task.
void Stop() override
Stop scheduling.
TId GetTid() const override
Get thread Id.
uint32_t GetSysTimerFrequency() const override
Get system timer frequency.
Cycles GetSysTimerCount() const override
Get system timer count value.
void Resume(Timeout elapsed_ticks) override
Resume scheduling after a prior Suspend() call.
void SetEventOverrider(IEventOverrider *overrider) override
Set platform event overrider.
void Initialize(IEventHandler *event_handler, IKernelService *service, uint32_t resolution_us, Stack *exit_trap) override
Initialize scheduler's context.
IWaitObject * Wait(ISyncObject *sync_obj, IMutex *mutex, Timeout timeout) override
Put calling process into a waiting state until synchronization object is signaled or timeout occurs.
~PlatformArmCortexM()=default
Destructor.
bool SleepUntil(Ticks timestamp) override
Put calling process into a sleep state until the specified timestamp.
Stack descriptor.
Definition stk_common.h:280
Interface for a stack memory region.
Definition stk_common.h:297
Wait object.
Definition stk_common.h:335
Synchronization object.
Definition stk_common.h:429
Interface for mutex synchronization primitive.
Definition stk_common.h:532
Interface for a user task.
Definition stk_common.h:589
Interface for a platform driver.
Definition stk_common.h:753
Interface for a back-end event handler.
Definition stk_common.h:761
Interface for a platform event overrider.
Definition stk_common.h:843
Interface for the kernel services exposed to the user processes during run-time when Kernel started s...