VSF Documented
win_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 __WIN_GENERIC_H__
19#define __WIN_GENERIC_H__
20
21/*============================ INCLUDES ======================================*/
22#include "hal/vsf_hal_cfg.h"
24
25#undef PUBLIC_CONST
26#if defined(__VSF_ARCH_WIN_IMPLEMENT)
27# define __VSF_CLASS_IMPLEMENT__
28# define PUBLIC_CONST
29#else
30# define PUBLIC_CONST const
31#endif
32
33#include "utilities/ooc_class.h"
34
35#ifdef __cplusplus
36extern "C" {
37#endif
38
39/*============================ MACROS ========================================*/
40
41#ifndef __LITTLE_ENDIAN
42# define __LITTLE_ENDIAN 1
43#endif
44#ifndef __BIG_ENDIAN
45# define __BIG_ENDIAN 0
46#endif
47#ifndef __BYTE_ORDER
48# define __BYTE_ORDER __LITTLE_ENDIAN
49#endif
50
51#ifndef VSF_SYSTIMER_CFG_IMPL_MODE
52# define VSF_SYSTIMER_CFG_IMPL_MODE VSF_SYSTIMER_IMPL_REQUEST_RESPONSE
53#endif
54
55#if defined(__CPU_X86__)
56// x86 stack alignment is 8bytes
57# define VSF_ARCH_STACK_ALIGN_BIT 3
58#elif defined(__CPU_X64__)
59// x64 stack alignment is 16bytes
60# define VSF_ARCH_STACK_ALIGN_BIT 4
61// longjmp in x64_win will issue exception if stack is switched to task thread
62// to support x64_win, please include setjmp_x64.asm from intel,
63// and with MACRO below, setjmp/longjmp in setjmp_x64.asm will be used
64# define VSF_ARCH_SETJMP SetJumpUser
65# define VSF_ARCH_LONGJMP LongJumpUser
66#endif
67#define VSF_ARCH_STACK_PAGE_SIZE 4096
68#define VSF_ARCH_STACK_GUARDIAN_SIZE 4096
69#ifndef VSF_ARCH_PROVIDE_HEAP
70# define VSF_ARCH_PROVIDE_HEAP ENABLED
71#endif
72#define VSF_ARCH_PROVIDE_ARGU ENABLED
73#define VSF_ARCH_PROVIDE_EXE ENABLED
74// define VSF_ARCH_LIMIT_NO_SET_STACK to remove dependency of setjmp/longjmp
75// and use stack of thread in windows for the best compatibility
76// note that VSF_ARCH_PRI_NUM MUST defined to 1 and VSF_ARCH_SWI_NUM to 0
77//#define VSF_ARCH_LIMIT_NO_SET_STACK
78
79#ifdef VSF_ARCH_LIMIT_NO_SET_STACK
80# define VSF_ARCH_PRI_NUM 1
81# define VSF_ARCH_SWI_NUM 0
82#endif
83
84// software interrupt provided by arch
85#ifndef VSF_ARCH_SWI_NUM
86# define VSF_ARCH_SWI_NUM 32
87#endif
88#ifndef VSF_ARCH_PRI_NUM
89# define VSF_ARCH_PRI_NUM 64
90#endif
91
93#define VSF_ARCH_SYSTIMER_FREQ (10 * 1000 * 1000)
94
95#ifndef FAR
96# define FAR
97#endif
98#ifndef NEAR
99# define NEAR
100#endif
101
102/*============================ MACROFIED FUNCTIONS ===========================*/
103
104// for trace
105#ifndef VSF_ARCH_TRACE_FUNC
106# define VSF_ARCH_TRACE_FUNC(...) __vsf_arch_trace(0, __VA_ARGS__)
107#endif
108
109#ifndef vsf_arch_trace
110# if VSF_ARCH_PRI_NUM == 1 && VSF_ARCH_SWI_NUM == 0
111# define vsf_arch_trace(__header, __color, ...)
112# else
113# define vsf_arch_trace(__header, __color, ...) \
114 do { \
115 vsf_arch_irq_thread_t *__irq_thread = \
116 __vsf_arch_get_cur_irq_thread(); \
117 __vsf_arch_trace_lock(); \
118 VSF_ARCH_TRACE_FUNC("%s[%s]: ", (__color), (__header)); \
119 if (__irq_thread != NULL) { \
120 VSF_ARCH_TRACE_FUNC("%s(%d) %lld ", \
121 __irq_thread->name, (int)__irq_thread->thread_id, \
122 __vsf_systimer_get()); \
123 } else { \
124 } \
125 VSF_ARCH_TRACE_FUNC(__VA_ARGS__); \
126 __vsf_arch_trace_unlock(); \
127 } while (0)
128# endif
129#endif
130
131#define __VSF_ARCH_PRI(__N, __UNUSED) \
132 VSF_ARCH_PRIO_##__N = (__N), \
133 vsf_arch_prio_##__N = (__N),
134
135#define vsf_arch_wakeup()
136
137/*============================ TYPES =========================================*/
138
139// avoid to use windows.h, fix if any conflicts
140typedef void * VSF_WIN_HANDLE;
141typedef unsigned long VSF_WIN_DWORD;
142typedef unsigned int VSF_WIN_UINT;
143typedef unsigned char VSF_WIN_BYTE;
144typedef char * VSF_WIN_LPSTR;
145#ifdef __CPU_X64__
146typedef unsigned long long VSF_WIN_ULONG_PTR, *VSF_WIN_PULONG_PTR;
147#else
148typedef unsigned long VSF_WIN_ULONG_PTR, *VSF_WIN_PULONG_PTR;
149#endif
151
152#ifndef VSF_ARCH_SYSTIMER_TICK_T
153# define VSF_ARCH_SYSTIMER_TICK_T uint64_t
154#endif
156
157typedef enum vsf_arch_prio_t {
163
164typedef void (*vsf_arch_irq_entry_t)(void*);
165
167 private_member(
168 VSF_WIN_HANDLE event;
169 bool is_inited;
170 )
171};
172
173typedef volatile bool vsf_gint_state_t;
174
175/*============================ INCLUDES ======================================*/
176
177#if VSF_ARCH_PRI_NUM == 1 && VSF_ARCH_SWI_NUM == 0
179#else
180# define VSF_ARCH_NO_DISABLE_INTERRUPT_BEFORE_SLEEP
181#endif
182
183/*============================ TYPES =========================================*/
184
185#if VSF_ARCH_PRI_NUM == 1 && VSF_ARCH_SWI_NUM == 0
187 private_member(
189 VSF_WIN_HANDLE thread;
190 VSF_WIN_DWORD thread_id;
191 )
192};
193#else
200
202 public_member(
203 const char name[32];
204
208 PUBLIC_CONST VSF_WIN_DWORD thread_id;
210 PUBLIC_CONST vsf_arch_irq_thread_t *prev; // call stack
214};
215#endif
216#undef PUBLIC_CONST
217
218/*============================ GLOBAL VARIABLES ==============================*/
219/*============================ LOCAL VARIABLES ===============================*/
220/*============================ PROTOTYPES ====================================*/
221
222// this API is implement in driver
223extern int __vsf_arch_trace(int level, const char *format, ...);
224
225extern void __vsf_arch_irq_sleep(uint_fast32_t ms);
226extern int vsf_arch_argu(char ***argv);
228extern void vsf_arch_free_exe(void *ptr);
229
234
236extern void __vsf_arch_irq_init(vsf_arch_irq_thread_t *irq_thread, char *name,
237 vsf_arch_irq_entry_t entry, vsf_arch_prio_t priority);
238extern void __vsf_arch_irq_fini(vsf_arch_irq_thread_t *irq_thread);
240extern void __vsf_arch_irq_start(vsf_arch_irq_thread_t *irq_thread);
241extern void __vsf_arch_irq_end(vsf_arch_irq_thread_t *irq_thread, bool is_terminate);
242
243#ifdef VSF_ARCH_LIMIT_NO_SET_STACK
244extern void __vsf_arch_irq_exit(vsf_arch_irq_thread_t *irq_thread);
246 vsf_arch_irq_request_t *request_pending);
247#endif
248
249// for trace only
251
252#ifndef VSF_ARCH_LIMIT_NO_SET_STACK
253static VSF_CAL_ALWAYS_INLINE void vsf_arch_set_stack(uintptr_t stack)
254{
255#if defined(__CPU_X86__)
256 __asm__("movl %0, %%esp" : : "r"(stack));
257#elif defined(__CPU_X64__)
258 __asm__("movq %0, %%rsp" : : "r"(stack));
259#endif
260}
261
262static VSF_CAL_ALWAYS_INLINE uintptr_t vsf_arch_get_stack(void)
263{
264 uintptr_t stack;
265#if defined(__CPU_X86__)
266 __asm__("movl %%esp, %0" : "=r"(stack) :);
267#elif defined(__CPU_X64__)
268 __asm__("movq %%esp, %0" : "=r"(stack) :);
269#endif
270 return stack;
271}
272#endif
273
274#ifdef __cplusplus
275}
276#endif
277
278#endif
279/* EOF */
vsf_err_t
Definition __type.h:42
Definition linux_generic.h:104
Definition linux_generic.h:122
vsf_arch_prio_t
Definition cortex_a_generic.h:88
uint64_t vsf_systimer_tick_t
Definition cortex_a_generic.h:73
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_exit(vsf_arch_irq_thread_t *irq_thread)
Definition linux_generic.c:303
#define vsf_class(__name)
Definition ooc_class.h:48
uint32_t uintptr_t
Definition stdint.h:38
unsigned int uint_fast32_t
Definition stdint.h:27
Definition vsf_arch_without_thread_suspend_template.h:23
Definition vsf_list.h:888
uint32_t size
Definition vsf_memfs.h:50
uint8_t state
Definition vsf_msg_tree.h:247
#define VSF_MREPEAT(__COUNT, __MACRO, __PARAM)
Definition vsf_repeat_macro.h:51
SDL_PixelFormat format
Definition vsf_sdl2_pixelformat.c:32
@ VSF_ARCH_PRIO_INVALID
Definition win_generic.h:158
@ vsf_arch_prio_highest
Definition win_generic.h:161
@ vsf_arch_prio_invalid
Definition win_generic.h:159
char * VSF_WIN_LPSTR
Definition win_generic.h:144
#define __VSF_ARCH_PRI(__N, __UNUSED)
Definition win_generic.h:131
unsigned long * VSF_WIN_PULONG_PTR
Definition win_generic.h:148
unsigned char VSF_WIN_BYTE
Definition win_generic.h:143
unsigned long VSF_WIN_DWORD
Definition win_generic.h:141
void __vsf_arch_irq_set_background(vsf_arch_irq_thread_t *irq_thread)
Definition win_generic.c:724
VSF_WIN_ULONG_PTR * VSF_WIN_PDWORD_PTR
Definition win_generic.h:150
void __vsf_arch_irq_init(vsf_arch_irq_thread_t *irq_thread, char *name, vsf_arch_irq_entry_t entry, vsf_arch_prio_t priority)
Definition win_generic.c:691
void __vsf_arch_irq_request_fini(vsf_arch_irq_request_t *request)
Definition linux_generic.c:188
void * vsf_arch_alloc_exe(uint_fast32_t size)
Definition linux_generic.c:589
vsf_arch_irq_state_t
Definition win_generic.h:194
@ VSF_ARCH_IRQ_STATE_IDLE
Definition win_generic.h:195
@ VSF_ARCH_IRQ_STATE_BACKGROUND
Definition win_generic.h:198
@ VSF_ARCH_IRQ_STATE_FOREGROUND
Definition win_generic.h:197
@ VSF_ARCH_IRQ_STATE_ACTIVE
Definition win_generic.h:196
void __vsf_arch_irq_sleep(uint_fast32_t ms)
Definition win_generic.c:996
VSF_ARCH_SYSTIMER_TICK_T vsf_systimer_tick_t
Definition win_generic.h:155
volatile bool vsf_gint_state_t
Definition win_generic.h:173
VSF_WIN_ULONG_PTR VSF_WIN_DWORD_PTR
Definition win_generic.h:150
void __vsf_arch_irq_end(vsf_arch_irq_thread_t *irq_thread, bool is_terminate)
Definition win_generic.c:669
void __vsf_arch_irq_fini(vsf_arch_irq_thread_t *irq_thread)
Definition win_generic.c:679
int __vsf_arch_trace(int level, const char *format,...)
Definition driver.c:97
void __vsf_arch_irq_request_pend(vsf_arch_irq_request_t *request)
Definition linux_generic.c:205
unsigned long VSF_WIN_ULONG_PTR
Definition win_generic.h:148
#define VSF_ARCH_SYSTIMER_TICK_T
Definition win_generic.h:153
void * VSF_WIN_HANDLE
Definition win_generic.h:140
int vsf_arch_argu(char ***argv)
Definition linux_generic.c:603
#define PUBLIC_CONST
Definition win_generic.h:30
void(* vsf_arch_irq_entry_t)(void *)
Definition win_generic.h:164
void __vsf_arch_irq_start(vsf_arch_irq_thread_t *irq_thread)
Definition win_generic.c:659
void vsf_arch_free_exe(void *ptr)
Definition linux_generic.c:594
void __vsf_arch_irq_request_send(vsf_arch_irq_request_t *request)
Definition linux_generic.c:228
void __vsf_arch_irq_request_init(vsf_arch_irq_request_t *request)
Definition linux_generic.c:167
unsigned int VSF_WIN_UINT
Definition win_generic.h:142
vsf_systimer_tick_t __vsf_systimer_get(void)
Definition win_generic.c:1067
vsf_arch_irq_thread_t * __vsf_arch_irq_get_cur(void)
Definition win_generic.c:719
#define VSF_ARCH_PRI_NUM
Definition win_generic.h:89