| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329 |
- /*
- * Copyright (c) 2013-2023 Arm Limited. All rights reserved.
- *
- * SPDX-License-Identifier: Apache-2.0
- *
- * Licensed under the Apache License, Version 2.0 (the License); you may
- * not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an AS IS BASIS, WITHOUT
- * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- *
- * -----------------------------------------------------------------------------
- *
- * Project: CMSIS-RTOS RTX
- * Title: RTX Library definitions
- *
- * -----------------------------------------------------------------------------
- */
- #ifndef RTX_LIB_H_
- #define RTX_LIB_H_
- #include <string.h>
- #include "rtx_def.h" // RTX Configuration definitions
- #include "rtx_core_c.h" // Cortex core definitions
- #ifdef RTX_TZ_CONTEXT
- #include "tz_context.h" // TrustZone Context API
- #endif
- #include "os_tick.h" // CMSIS OS Tick API
- #include "cmsis_os2.h" // CMSIS RTOS API
- #include "rtx_os.h" // RTX OS definitions
- #include "rtx_evr.h" // RTX Event Recorder definitions
- // ==== Library defines ====
- #define os_thread_t osRtxThread_t
- #define os_timer_t osRtxTimer_t
- #define os_timer_finfo_t osRtxTimerFinfo_t
- #define os_event_flags_t osRtxEventFlags_t
- #define os_mutex_t osRtxMutex_t
- #define os_semaphore_t osRtxSemaphore_t
- #define os_mp_info_t osRtxMpInfo_t
- #define os_memory_pool_t osRtxMemoryPool_t
- #define os_message_t osRtxMessage_t
- #define os_message_queue_t osRtxMessageQueue_t
- #define os_object_t osRtxObject_t
- // ==== Library sections ====
- #if defined(__CC_ARM) || \
- (defined(__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050))
- // Referenced through linker
- //lint -esym(528, __os_thread_cb_start__, __os_thread_cb_length__)
- //lint -esym(528, __os_timer_cb_start__, __os_timer_cb_length__)
- //lint -esym(528, __os_evflags_cb_start__, __os_evflags_cb_length__)
- //lint -esym(528, __os_mutex_cb_start__, __os_mutex_cb_length__)
- //lint -esym(528, __os_semaphore_cb_start__, __os_semaphore_cb_length__)
- //lint -esym(528, __os_mempool_cb_start__, __os_mempool_cb_length__)
- //lint -esym(528, __os_msgqueue_cb_start__, __os_msgqueue_cb_length__)
- // Accessed through linker
- //lint -esym(551, __os_thread_cb_start__, __os_thread_cb_length__)
- //lint -esym(551, __os_timer_cb_start__, __os_timer_cb_length__)
- //lint -esym(551, __os_evflags_cb_start__, __os_evflags_cb_length__)
- //lint -esym(551, __os_mutex_cb_start__, __os_mutex_cb_length__)
- //lint -esym(551, __os_semaphore_cb_start__, __os_semaphore_cb_length__)
- //lint -esym(551, __os_mempool_cb_start__, __os_mempool_cb_length__)
- //lint -esym(551, __os_msgqueue_cb_start__, __os_msgqueue_cb_length__)
- // Initialized through linker
- //lint -esym(728, __os_thread_cb_start__, __os_thread_cb_length__)
- //lint -esym(728, __os_timer_cb_start__, __os_timer_cb_length__)
- //lint -esym(728, __os_evflags_cb_start__, __os_evflags_cb_length__)
- //lint -esym(728, __os_mutex_cb_start__, __os_mutex_cb_length__)
- //lint -esym(728, __os_semaphore_cb_start__, __os_semaphore_cb_length__)
- //lint -esym(728, __os_mempool_cb_start__, __os_mempool_cb_length__)
- //lint -esym(728, __os_msgqueue_cb_start__, __os_msgqueue_cb_length__)
- // Global scope
- //lint -esym(9003, __os_thread_cb_start__, __os_thread_cb_length__)
- //lint -esym(9003, __os_timer_cb_start__, __os_timer_cb_length__)
- //lint -esym(9003, __os_evflags_cb_start__, __os_evflags_cb_length__)
- //lint -esym(9003, __os_mutex_cb_start__, __os_mutex_cb_length__)
- //lint -esym(9003, __os_semaphore_cb_start__, __os_semaphore_cb_length__)
- //lint -esym(9003, __os_mempool_cb_start__, __os_mempool_cb_length__)
- //lint -esym(9003, __os_msgqueue_cb_start__, __os_msgqueue_cb_length__)
- static const uint32_t __os_thread_cb_start__ __attribute__((weakref(".bss.os.thread.cb$$Base")));
- static const uint32_t __os_thread_cb_length__ __attribute__((weakref(".bss.os.thread.cb$$Length")));
- static const uint32_t __os_timer_cb_start__ __attribute__((weakref(".bss.os.timer.cb$$Base")));
- static const uint32_t __os_timer_cb_length__ __attribute__((weakref(".bss.os.timer.cb$$Length")));
- static const uint32_t __os_evflags_cb_start__ __attribute__((weakref(".bss.os.evflags.cb$$Base")));
- static const uint32_t __os_evflags_cb_length__ __attribute__((weakref(".bss.os.evflags.cb$$Length")));
- static const uint32_t __os_mutex_cb_start__ __attribute__((weakref(".bss.os.mutex.cb$$Base")));
- static const uint32_t __os_mutex_cb_length__ __attribute__((weakref(".bss.os.mutex.cb$$Length")));
- static const uint32_t __os_semaphore_cb_start__ __attribute__((weakref(".bss.os.semaphore.cb$$Base")));
- static const uint32_t __os_semaphore_cb_length__ __attribute__((weakref(".bss.os.semaphore.cb$$Length")));
- static const uint32_t __os_mempool_cb_start__ __attribute__((weakref(".bss.os.mempool.cb$$Base")));
- static const uint32_t __os_mempool_cb_length__ __attribute__((weakref(".bss.os.mempool.cb$$Length")));
- static const uint32_t __os_msgqueue_cb_start__ __attribute__((weakref(".bss.os.msgqueue.cb$$Base")));
- static const uint32_t __os_msgqueue_cb_length__ __attribute__((weakref(".bss.os.msgqueue.cb$$Length")));
- #else
- extern const uint32_t __os_thread_cb_start__ __attribute__((weak));
- extern const uint32_t __os_thread_cb_length__ __attribute__((weak));
- extern const uint32_t __os_timer_cb_start__ __attribute__((weak));
- extern const uint32_t __os_timer_cb_length__ __attribute__((weak));
- extern const uint32_t __os_evflags_cb_start__ __attribute__((weak));
- extern const uint32_t __os_evflags_cb_length__ __attribute__((weak));
- extern const uint32_t __os_mutex_cb_start__ __attribute__((weak));
- extern const uint32_t __os_mutex_cb_length__ __attribute__((weak));
- extern const uint32_t __os_semaphore_cb_start__ __attribute__((weak));
- extern const uint32_t __os_semaphore_cb_length__ __attribute__((weak));
- extern const uint32_t __os_mempool_cb_start__ __attribute__((weak));
- extern const uint32_t __os_mempool_cb_length__ __attribute__((weak));
- extern const uint32_t __os_msgqueue_cb_start__ __attribute__((weak));
- extern const uint32_t __os_msgqueue_cb_length__ __attribute__((weak));
- #endif
- // ==== Inline functions ====
- // Thread ID
- __STATIC_INLINE os_thread_t *osRtxThreadId (osThreadId_t thread_id) {
- //lint -e{9079} -e{9087} "cast from pointer to void to pointer to object type" [MISRA Note 2]
- return ((os_thread_t *)thread_id);
- }
- // Timer ID
- __STATIC_INLINE os_timer_t *osRtxTimerId (osTimerId_t timer_id) {
- //lint -e{9079} -e{9087} "cast from pointer to void to pointer to object type" [MISRA Note 2]
- return ((os_timer_t *)timer_id);
- }
- // Event Flags ID
- __STATIC_INLINE os_event_flags_t *osRtxEventFlagsId (osEventFlagsId_t ef_id) {
- //lint -e{9079} -e{9087} "cast from pointer to void to pointer to object type" [MISRA Note 2]
- return ((os_event_flags_t *)ef_id);
- }
- // Mutex ID
- __STATIC_INLINE os_mutex_t *osRtxMutexId (osMutexId_t mutex_id) {
- //lint -e{9079} -e{9087} "cast from pointer to void to pointer to object type" [MISRA Note 2]
- return ((os_mutex_t *)mutex_id);
- }
- // Semaphore ID
- __STATIC_INLINE os_semaphore_t *osRtxSemaphoreId (osSemaphoreId_t semaphore_id) {
- //lint -e{9079} -e{9087} "cast from pointer to void to pointer to object type" [MISRA Note 2]
- return ((os_semaphore_t *)semaphore_id);
- }
- // Memory Pool ID
- __STATIC_INLINE os_memory_pool_t *osRtxMemoryPoolId (osMemoryPoolId_t mp_id) {
- //lint -e{9079} -e{9087} "cast from pointer to void to pointer to object type" [MISRA Note 2]
- return ((os_memory_pool_t *)mp_id);
- }
- // Message Queue ID
- __STATIC_INLINE os_message_queue_t *osRtxMessageQueueId (osMessageQueueId_t mq_id) {
- //lint -e{9079} -e{9087} "cast from pointer to void to pointer to object type" [MISRA Note 2]
- return ((os_message_queue_t *)mq_id);
- }
- // Generic Object
- __STATIC_INLINE os_object_t *osRtxObject (void *object) {
- //lint -e{9079} -e{9087} "cast from pointer to void to pointer to object type" [MISRA Note 3]
- return ((os_object_t *)object);
- }
- // Thread Object
- __STATIC_INLINE os_thread_t *osRtxThreadObject (os_object_t *object) {
- //lint -e{740} -e{826} -e{9087} "cast from pointer to generic object to specific object" [MISRA Note 4]
- return ((os_thread_t *)object);
- }
- // Timer Object
- __STATIC_INLINE os_timer_t *osRtxTimerObject (os_object_t *object) {
- //lint -e{740} -e{826} -e{9087} "cast from pointer to generic object to specific object" [MISRA Note 4]
- return ((os_timer_t *)object);
- }
- // Event Flags Object
- __STATIC_INLINE os_event_flags_t *osRtxEventFlagsObject (os_object_t *object) {
- //lint -e{740} -e{826} -e{9087} "cast from pointer to generic object to specific object" [MISRA Note 4]
- return ((os_event_flags_t *)object);
- }
- // Mutex Object
- __STATIC_INLINE os_mutex_t *osRtxMutexObject (os_object_t *object) {
- //lint -e{740} -e{826} -e{9087} "cast from pointer to generic object to specific object" [MISRA Note 4]
- return ((os_mutex_t *)object);
- }
- // Semaphore Object
- __STATIC_INLINE os_semaphore_t *osRtxSemaphoreObject (os_object_t *object) {
- //lint -e{740} -e{826} -e{9087} "cast from pointer to generic object to specific object" [MISRA Note 4]
- return ((os_semaphore_t *)object);
- }
- // Memory Pool Object
- __STATIC_INLINE os_memory_pool_t *osRtxMemoryPoolObject (os_object_t *object) {
- //lint -e{740} -e{826} -e{9087} "cast from pointer to generic object to specific object" [MISRA Note 4]
- return ((os_memory_pool_t *)object);
- }
- // Message Queue Object
- __STATIC_INLINE os_message_queue_t *osRtxMessageQueueObject (os_object_t *object) {
- //lint -e{740} -e{826} -e{9087} "cast from pointer to generic object to specific object" [MISRA Note 4]
- return ((os_message_queue_t *)object);
- }
- // Message Object
- __STATIC_INLINE os_message_t *osRtxMessageObject (os_object_t *object) {
- //lint -e{740} -e{826} -e{9087} "cast from pointer to generic object to specific object" [MISRA Note 4]
- return ((os_message_t *)object);
- }
- // Kernel State
- __STATIC_INLINE osKernelState_t osRtxKernelState (void) {
- //lint -e{9030} -e{9034} "cast to enum"
- return ((osKernelState_t)(osRtxInfo.kernel.state));
- }
- // Thread State
- __STATIC_INLINE osThreadState_t osRtxThreadState (const os_thread_t *thread) {
- uint8_t state = thread->state & osRtxThreadStateMask;
- //lint -e{9030} -e{9034} "cast to enum"
- return ((osThreadState_t)state);
- }
- // Thread Priority
- __STATIC_INLINE osPriority_t osRtxThreadPriority (const os_thread_t *thread) {
- //lint -e{9030} -e{9034} "cast to enum"
- return ((osPriority_t)thread->priority);
- }
- // Kernel Get State
- __STATIC_INLINE uint8_t osRtxKernelGetState (void) {
- return osRtxInfo.kernel.state;
- }
- // Thread Get/Set Running
- __STATIC_INLINE os_thread_t *osRtxThreadGetRunning (void) {
- return osRtxInfo.thread.run.curr;
- }
- __STATIC_INLINE void osRtxThreadSetRunning (os_thread_t *thread) {
- osRtxInfo.thread.run.curr = thread;
- }
- // ==== Library functions ====
- // Kernel Library functions
- extern void osRtxKernelBeforeInit (void);
- // Thread Library functions
- extern void osRtxThreadListPut (os_object_t *object, os_thread_t *thread);
- extern os_thread_t *osRtxThreadListGet (os_object_t *object);
- extern void osRtxThreadListSort (os_thread_t *thread);
- extern void osRtxThreadListRemove (os_thread_t *thread);
- extern void osRtxThreadReadyPut (os_thread_t *thread);
- //lint -esym(759,osRtxThreadDelayRemove) "Prototype in header"
- //lint -esym(765,osRtxThreadDelayRemove) "Global scope"
- extern void osRtxThreadDelayRemove (os_thread_t *thread);
- extern void osRtxThreadDelayTick (void);
- extern uint32_t *osRtxThreadRegPtr (const os_thread_t *thread);
- extern void osRtxThreadSwitch (os_thread_t *thread);
- extern void osRtxThreadDispatch (os_thread_t *thread);
- extern void osRtxThreadWaitExit (os_thread_t *thread, uint32_t ret_val, bool_t dispatch);
- extern bool_t osRtxThreadWaitEnter (uint8_t state, uint32_t timeout);
- #ifdef RTX_STACK_CHECK
- extern bool_t osRtxThreadStackCheck (const os_thread_t *thread);
- #endif
- #ifdef RTX_THREAD_WATCHDOG
- //lint -esym(759,osRtxThreadWatchdogRemove) "Prototype in header"
- //lint -esym(765,osRtxThreadWatchdogRemove) "Global scope"
- extern void osRtxThreadWatchdogRemove(const os_thread_t *thread);
- extern void osRtxThreadWatchdogTick (void);
- #endif
- //lint -esym(759,osRtxThreadJoinWakeup) "Prototype in header"
- //lint -esym(765,osRtxThreadJoinWakeup) "Global scope"
- extern void osRtxThreadJoinWakeup (const os_thread_t *thread);
- //lint -esym(759,osRtxThreadDestroy) "Prototype in header"
- //lint -esym(765,osRtxThreadDestroy) "Global scope"
- extern void osRtxThreadDestroy (os_thread_t *thread);
- extern void osRtxThreadBeforeFree (os_thread_t *thread);
- extern bool_t osRtxThreadStartup (void);
- // Timer Library functions
- extern int32_t osRtxTimerSetup (void);
- extern void osRtxTimerThread (void *argument);
- #ifdef RTX_SAFETY_CLASS
- extern void osRtxTimerDeleteClass (uint32_t safety_class, uint32_t mode);
- #endif
- // Mutex Library functions
- extern void osRtxMutexOwnerRelease (os_mutex_t *mutex_list);
- extern void osRtxMutexOwnerRestore (const os_mutex_t *mutex, const os_thread_t *thread_wakeup);
- #ifdef RTX_SAFETY_CLASS
- extern void osRtxMutexDeleteClass (uint32_t safety_class, uint32_t mode);
- #endif
- // Semaphore Library functions
- #ifdef RTX_SAFETY_CLASS
- extern void osRtxSemaphoreDeleteClass (uint32_t safety_class, uint32_t mode);
- #endif
- // Event Flags Library functions
- #ifdef RTX_SAFETY_CLASS
- extern void osRtxEventFlagsDeleteClass(uint32_t safety_class, uint32_t mode);
- #endif
- // Memory Heap Library functions
- extern uint32_t osRtxMemoryInit (void *mem, uint32_t size);
- extern void *osRtxMemoryAlloc(void *mem, uint32_t size, uint32_t type);
- extern uint32_t osRtxMemoryFree (void *mem, void *block);
- // Memory Pool Library functions
- extern uint32_t osRtxMemoryPoolInit (os_mp_info_t *mp_info, uint32_t block_count, uint32_t block_size, void *block_mem);
- extern void *osRtxMemoryPoolAlloc (os_mp_info_t *mp_info);
- extern osStatus_t osRtxMemoryPoolFree (os_mp_info_t *mp_info, void *block);
- #ifdef RTX_SAFETY_CLASS
- extern void osRtxMemoryPoolDeleteClass(uint32_t safety_class, uint32_t mode);
- #endif
- // Message Queue Library functions
- extern int32_t osRtxMessageQueueTimerSetup (void);
- #ifdef RTX_SAFETY_CLASS
- extern void osRtxMessageQueueDeleteClass(uint32_t safety_class, uint32_t mode);
- #endif
- // System Library functions
- extern void osRtxTick_Handler (void);
- extern void osRtxPendSV_Handler (void);
- extern void osRtxPostProcess (os_object_t *object);
- #endif // RTX_LIB_H_
|