VSF Documented
rtos_generic.h
Go to the documentation of this file.
1/*****************************************************************************
2 * Copyright(C)2009-2022 by VSF Team *
3 * *
4 * Licensed under the Apache License, Version 2.0 (the "License"); *
5 * you may not use this file except in compliance with the License. *
6 * You may obtain a copy of the License at *
7 * *
8 * http://www.apache.org/licenses/LICENSE-2.0 *
9 * *
10 * Unless required by applicable law or agreed to in writing, software *
11 * distributed under the License is distributed on an "AS IS" BASIS, *
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. *
13 * See the License for the specific language governing permissions and *
14 * limitations under the License. *
15 * *
16 ****************************************************************************/
17
18#ifndef __RTOS_GENERIC_H__
19#define __RTOS_GENERIC_H__
20
21/*============================ INCLUDES ======================================*/
22
23#include "hal/vsf_hal_cfg.h"
24
25#ifdef __cplusplus
26extern "C" {
27#endif
28
29/*============================ MACROS ========================================*/
30
31#ifndef __LITTLE_ENDIAN
32# define __LITTLE_ENDIAN 1
33#endif
34#ifndef __BYTE_ORDER
35# define __BYTE_ORDER __LITTLE_ENDIAN
36#endif
37
38#ifndef VSF_ARCH_RTOS_CFG_STACK_DEPTH
39# define VSF_ARCH_RTOS_CFG_STACK_DEPTH 1024
40#endif
41
42#ifndef VSF_ARCH_SWI_NUM
43# define VSF_ARCH_SWI_NUM 0
44#endif
45
46#ifndef VSF_ARCH_PRI_NUM
47# if VSF_ARCH_SWI_NUM > 0
48# define VSF_ARCH_PRI_NUM VSF_ARCH_SWI_NUM
49# else
50# define VSF_ARCH_PRI_NUM 1
51# endif
52#endif
53
54// for rtos support, default vsf entry is int vsf_main(void)
55#ifndef VSF_USER_ENTRY
56# define VSF_USER_ENTRY vsf_main
57#endif
58
59#define VSF_ARCH_IRQ_REQUEST_SUPPORT_MANUAL_RESET
60
61#define VSF_ARCH_RTOS_MODE_SUSPEND_RESUME 1
62#define VSF_ARCH_RTOS_MODE_REQUEST 2
63
64// TODO: remove suspend/resume mode later if request mode is tested OK
65#define VSF_ARCH_RTOS_CFG_MODE VSF_ARCH_RTOS_MODE_SUSPEND_RESUME
66
67/*============================ MACROFIED FUNCTIONS ===========================*/
68
69#define __VSF_ARCH_PRI(__N, __UNUSED) \
70 VSF_ARCH_PRIO_##__N = (__N), \
71 vsf_arch_prio_##__N = (__N),
72
73/*============================ TYPES =========================================*/
74
75typedef enum vsf_arch_prio_t {
81
82typedef void (*vsf_arch_irq_thread_entry_t)(void*);
83
84/*============================ INCLUDES ======================================*/
85
86#if !defined(VSF_ARCH_RTOS_MODEL_HEADER)
87# if defined(__FREERTOS__)
88# define VSF_ARCH_RTOS_MODEL_HEADER "./freertos/freertos_generic.h"
89# else
90# error no supported rtos found
91# endif
92#endif
93
94#ifdef __cplusplus
95}
96#endif
97
98// rtos_model contains:
99// 1. vsf_systimer_tick_t if sys timer is enabled
100// 2. vsf_arch_set_stack if thread is enabled
101// 3. irq_request implementation
102// 4. irq_thread implementation
103// 5. vsf_arch_model_low_level_init
104// 6. vsf_arch_prio_t
105// 7. VSF_ARCH_RTOS_PRIORITY_NUM
106// 8. gint
107#include VSF_ARCH_RTOS_MODEL_HEADER
108
109#if defined(__VSF_ARCH_RTOS_IMPLEMENT)
110# define __VSF_CLASS_IMPLEMENT__
111#endif
112
113#include "utilities/ooc_class.h"
114
115#ifdef __cplusplus
116extern "C" {
117#endif
118
119/*============================ MACROS ========================================*/
120
121#ifndef VSF_ARCH_RTOS_CFG_SET_STACK
122# define VSF_ARCH_LIMIT_NO_SET_STACK
123#endif
124
125#if VSF_ARCH_SWI_NUM > VSF_ARCH_RTOS_PRIORITY_NUM
126# error too many SWI to support in the current rtos configuration
127#endif
128
129// if stack is supported, and stack_depth is 0, means using dynamic stack
130#if defined(VSF_ARCH_IRQ_SUPPORT_STACK) && (VSF_ARCH_RTOS_CFG_STACK_DEPTH == 0)
131# define VSF_ARCH_RTOS_DYNAMIC_STACK ENABLED
132#endif
133
134/*============================ TYPES =========================================*/
135
137 private_member(
138 implement(vsf_arch_irq_thread_t)
139
142#else
144#endif
145 )
146};
147
148/*============================ GLOBAL VARIABLES ==============================*/
149/*============================ LOCAL VARIABLES ===============================*/
150/*============================ PROTOTYPES ====================================*/
151
152extern void __vsf_arch_delay_ms(uint_fast32_t ms);
153
154extern void __vsf_arch_irq_request_init(vsf_arch_irq_request_t *request, bool auto_reset);
159
160extern void __vsf_arch_irq_enter(void);
161extern void __vsf_arch_irq_leave(void);
162
163// if priority < 0, then inherit from current priority
164extern void __vsf_arch_irq_init(vsf_arch_irq_thread_t *irq_thread,
165 const char * const name, vsf_arch_irq_thread_entry_t entry, vsf_arch_prio_t priority,
166 VSF_ARCH_RTOS_STACK_T *stack, uint_fast32_t stack_depth);
168 vsf_arch_irq_request_t *request_pending);
169extern void __vsf_arch_irq_exit(vsf_arch_irq_thread_t *irq_thread);
170extern void __vsf_arch_irq_set_priority(vsf_arch_irq_thread_t *irq_thread, vsf_arch_prio_t priority);
171
172#if VSF_ARCH_RTOS_CFG_MODE == VSF_ARCH_RTOS_MODE_SUSPEND_RESUME
173extern void __vsf_arch_irq_suspend(vsf_arch_irq_thread_t *irq_thread);
174extern void __vsf_arch_irq_resume(vsf_arch_irq_thread_t *irq_thread);
176#endif
177
178// for rtos support, vsf_arch_wakeup is used to wakeup vsf thread
179extern void vsf_arch_wakeup(void);
180
181#ifndef VSF_ARCH_LIMIT_NO_SET_STACK
182static VSF_CAL_ALWAYS_INLINE void vsf_arch_set_stack(uint32_t stack)
183{
184 VSF_ARCH_RTOS_CFG_SET_STACK(stack);
185}
186#endif
187
188#ifdef __cplusplus
189}
190#endif
191
192#endif
193/* EOF */
194
#define VSF_CAL_ALIGN(__N)
Definition __compiler.h:179
vsf_err_t
Definition __type.h:42
Definition linux_generic.h:104
Definition linux_generic.h:122
Definition rtos_generic.h:136
vsf_arch_prio_t
Definition cortex_a_generic.h:88
#define VSF_ARCH_RTOS_STACK_T
Definition freertos_generic.h:49
#define VSF_ARCH_STACK_ALIGN_BIT
Definition linux_generic.h:64
#define vsf_class(__name)
Definition ooc_class.h:48
void __vsf_arch_irq_request_reset(vsf_arch_irq_request_t *request)
Definition freertos_generic.c:199
vsf_arch_prio_t __vsf_arch_irq_get_priority(vsf_arch_irq_thread_t *irq_thread)
Definition freertos_generic.c:289
@ VSF_ARCH_PRIO_INVALID
Definition rtos_generic.h:76
@ vsf_arch_prio_highest
Definition rtos_generic.h:79
@ vsf_arch_prio_invalid
Definition rtos_generic.h:77
void vsf_arch_wakeup(void)
Definition rtos_generic.c:201
#define __VSF_ARCH_PRI(__N, __UNUSED)
Definition rtos_generic.h:69
void __vsf_arch_irq_request_init(vsf_arch_irq_request_t *request, bool auto_reset)
Definition freertos_generic.c:160
void __vsf_arch_delay_ms(uint_fast32_t ms)
Definition freertos_generic.c:310
void __vsf_arch_irq_enter(void)
Definition freertos_generic.c:130
vsf_err_t __vsf_arch_irq_restart(vsf_arch_irq_thread_t *irq_thread, vsf_arch_irq_request_t *request_pending)
Definition linux_generic.c:309
void __vsf_arch_irq_request_fini(vsf_arch_irq_request_t *request)
Definition linux_generic.c:188
void __vsf_arch_irq_init(vsf_arch_irq_thread_t *irq_thread, const char *const name, vsf_arch_irq_thread_entry_t entry, vsf_arch_prio_t priority, VSF_ARCH_RTOS_STACK_T *stack, uint_fast32_t stack_depth)
Definition freertos_generic.c:213
void __vsf_arch_irq_set_priority(vsf_arch_irq_thread_t *irq_thread, vsf_arch_prio_t priority)
Definition freertos_generic.c:266
void(* vsf_arch_irq_thread_entry_t)(void *)
Definition rtos_generic.h:82
void __vsf_arch_irq_leave(void)
Definition freertos_generic.c:143
void __vsf_arch_irq_request_pend(vsf_arch_irq_request_t *request)
Definition linux_generic.c:205
void __vsf_arch_irq_request_send(vsf_arch_irq_request_t *request)
Definition linux_generic.c:228
void __vsf_arch_irq_suspend(vsf_arch_irq_thread_t *irq_thread)
Definition freertos_generic.c:279
#define VSF_ARCH_RTOS_CFG_STACK_DEPTH
Definition rtos_generic.h:39
void __vsf_arch_irq_resume(vsf_arch_irq_thread_t *irq_thread)
Definition freertos_generic.c:284
void __vsf_arch_irq_exit(vsf_arch_irq_thread_t *irq_thread)
Definition linux_generic.c:303
#define VSF_ARCH_PRI_NUM
Definition rtos_generic.h:50
unsigned uint32_t
Definition stdint.h:9
unsigned int uint_fast32_t
Definition stdint.h:27
#define VSF_MREPEAT(__COUNT, __MACRO, __PARAM)
Definition vsf_repeat_macro.h:51