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
23#include "hal/vsf_hal_cfg.h"
25
26#undef __VSF_WIN_PUBLIC_CONST__
27#if defined(__VSF_ARCH_WIN_IMPLEMENT)
28# define __VSF_CLASS_IMPLEMENT__
29# define __VSF_WIN_PUBLIC_CONST__
30#else
31# define __VSF_WIN_PUBLIC_CONST__ const
32#endif
33
34#include "utilities/ooc_class.h"
35
36#ifdef __cplusplus
37extern "C" {
38#endif
39
40/*============================ MACROS ========================================*/
41
42#ifndef __LITTLE_ENDIAN
43# define __LITTLE_ENDIAN 1
44#endif
45#ifndef __BIG_ENDIAN
46# define __BIG_ENDIAN 0
47#endif
48#ifndef __BYTE_ORDER
49# define __BYTE_ORDER __LITTLE_ENDIAN
50#endif
51
52#ifndef VSF_SYSTIMER_CFG_IMPL_MODE
53# define VSF_SYSTIMER_CFG_IMPL_MODE VSF_SYSTIMER_IMPL_REQUEST_RESPONSE
54#endif
55
56#if defined(__CPU_X86__)
57// x86 stack alignment is 8bytes
58# define VSF_ARCH_STACK_ALIGN_BIT 3
59#elif defined(__CPU_X64__)
60// x64 stack alignment is 16bytes
61# define VSF_ARCH_STACK_ALIGN_BIT 4
62// longjmp in x64_win will issue exception if stack is switched to task thread
63// to support x64_win, please include setjmp_x64.asm from intel,
64// and with MACRO below, setjmp/longjmp in setjmp_x64.asm will be used
65# define VSF_ARCH_SETJMP SetJumpUser
66# define VSF_ARCH_LONGJMP LongJumpUser
67#endif
68#define VSF_ARCH_STACK_PAGE_SIZE 4096
69#define VSF_ARCH_STACK_GUARDIAN_SIZE 4096
70#define VSF_ARCH_PROVIDE_HEAP ENABLED
71# define VSF_ARCH_HEAP_HAS_STATISTICS ENABLED
72#define VSF_ARCH_PROVIDE_ARGU ENABLED
73#define VSF_ARCH_PROVIDE_EXE ENABLED
74// there will be memory allocation before entering vsf.
75// if VSF_USE_LINUX is enabled, and if these memories are handled(realloc, etc),
76// there will be problem because of different process context in vsf linux subsystem.
77#define VSF_ARCH_ALLOC_BEFORE_ENTRY
78// define VSF_ARCH_LIMIT_NO_SET_STACK to remove dependency of setjmp/longjmp
79// and use stack of thread in windows for the best compatibility
80// note that VSF_ARCH_PRI_NUM MUST defined to 1 and VSF_ARCH_SWI_NUM to 0
81//#define VSF_ARCH_LIMIT_NO_SET_STACK
82
83#ifdef VSF_ARCH_LIMIT_NO_SET_STACK
84# define VSF_ARCH_PRI_NUM 1
85# define VSF_ARCH_SWI_NUM 0
86#endif
87
88// software interrupt provided by arch
89#ifndef VSF_ARCH_SWI_NUM
90# define VSF_ARCH_SWI_NUM 32
91#endif
92#ifndef VSF_ARCH_PRI_NUM
93# define VSF_ARCH_PRI_NUM 64
94#endif
95
97#define VSF_ARCH_SYSTIMER_FREQ (10 * 1000 * 1000)
98
99#ifndef FAR
100# define FAR
101#endif
102#ifndef NEAR
103# define NEAR
104#endif
105
106/*============================ MACROFIED FUNCTIONS ===========================*/
107
108// for trace
109#ifndef VSF_ARCH_TRACE_FUNC
110# define VSF_ARCH_TRACE_FUNC(...) __vsf_arch_trace(0, __VA_ARGS__)
111#endif
112
113#ifndef vsf_arch_trace
114# if VSF_ARCH_PRI_NUM == 1 && VSF_ARCH_SWI_NUM == 0
115# define vsf_arch_trace(__header, __color, ...)
116# else
117# define vsf_arch_trace(__header, __color, ...) \
118 do { \
119 vsf_arch_irq_thread_t *__irq_thread = \
120 __vsf_arch_get_cur_irq_thread(); \
121 __vsf_arch_trace_lock(); \
122 VSF_ARCH_TRACE_FUNC("%s[%s]: ", (__color), (__header)); \
123 if (__irq_thread != NULL) { \
124 VSF_ARCH_TRACE_FUNC("%s(%d) %lld ", \
125 __irq_thread->name, (int)__irq_thread->thread_id, \
126 __vsf_systimer_get()); \
127 } else { \
128 } \
129 VSF_ARCH_TRACE_FUNC(__VA_ARGS__); \
130 __vsf_arch_trace_unlock(); \
131 } while (0)
132# endif
133#endif
134
135#define __VSF_ARCH_PRI(__N, __UNUSED) \
136 VSF_ARCH_PRIO_##__N = (__N), \
137 vsf_arch_prio_##__N = (__N),
138
139#define vsf_arch_wakeup()
140
141/*============================ TYPES =========================================*/
142
143// avoid to use windows.h, fix if any conflicts
144typedef void * VSF_WIN_HANDLE;
145typedef unsigned long VSF_WIN_DWORD;
146typedef unsigned int VSF_WIN_UINT;
147typedef unsigned char VSF_WIN_BYTE;
148typedef char * VSF_WIN_LPSTR;
149#ifdef __CPU_X64__
150typedef unsigned long long VSF_WIN_ULONG_PTR, *VSF_WIN_PULONG_PTR;
151#else
152typedef unsigned long VSF_WIN_ULONG_PTR, *VSF_WIN_PULONG_PTR;
153#endif
155
156#ifndef VSF_ARCH_SYSTIMER_TICK_T
157# define VSF_ARCH_SYSTIMER_TICK_T uint64_t
158#endif
160
161typedef enum vsf_arch_prio_t {
167
168typedef void (*vsf_arch_irq_entry_t)(void*);
169
171 private_member(
172 VSF_WIN_HANDLE event;
173 bool is_inited;
174 )
175};
176
177typedef volatile bool vsf_gint_state_t;
178
179/*============================ INCLUDES ======================================*/
180
181#if VSF_ARCH_PRI_NUM == 1 && VSF_ARCH_SWI_NUM == 0
183#else
184# define VSF_ARCH_NO_DISABLE_INTERRUPT_BEFORE_SLEEP
185#endif
186
187/*============================ TYPES =========================================*/
188
189#if VSF_ARCH_PRI_NUM == 1 && VSF_ARCH_SWI_NUM == 0
191 private_member(
193 VSF_WIN_HANDLE thread;
194 VSF_WIN_DWORD thread_id;
195 )
196};
197#else
204
206 public_member(
207 const char name[32];
208
218};
219#endif
220#undef __VSF_WIN_PUBLIC_CONST__
221
222/*============================ GLOBAL VARIABLES ==============================*/
223/*============================ LOCAL VARIABLES ===============================*/
224/*============================ PROTOTYPES ====================================*/
225
226// this API is implement in driver
227extern int __vsf_arch_trace(int level, const char *format, ...);
228extern int __vsf_arch_console_readline(char *buf, int bufsize);
229
230extern bool __vsf_arch_before_entry(void);
231
232extern void __vsf_arch_irq_sleep(uint_fast32_t ms);
233extern int vsf_arch_argu(char ***argv);
235extern void vsf_arch_free_exe(void *ptr);
236
241
243extern void __vsf_arch_irq_init(vsf_arch_irq_thread_t *irq_thread, char *name,
244 vsf_arch_irq_entry_t entry, vsf_arch_prio_t priority);
245extern void __vsf_arch_irq_fini(vsf_arch_irq_thread_t *irq_thread);
247extern void __vsf_arch_irq_start(vsf_arch_irq_thread_t *irq_thread);
248extern void __vsf_arch_irq_end(vsf_arch_irq_thread_t *irq_thread, bool is_terminate);
249
250#ifdef VSF_ARCH_LIMIT_NO_SET_STACK
251extern void __vsf_arch_irq_exit(vsf_arch_irq_thread_t *irq_thread);
253 vsf_arch_irq_request_t *request_pending);
254#endif
255
256// for trace only
258
259#ifndef VSF_ARCH_LIMIT_NO_SET_STACK
260static VSF_CAL_ALWAYS_INLINE void vsf_arch_set_stack(uintptr_t stack, uint32_t stack_size)
261{
262#if defined(__CPU_X86__)
263 __asm__("movl %0, %%esp" : : "r"(stack));
264#elif defined(__CPU_X64__)
265 __asm__("movq %0, %%rsp" : : "r"(stack));
266#endif
267}
268
269static VSF_CAL_ALWAYS_INLINE uintptr_t vsf_arch_get_stack(void)
270{
271 uintptr_t stack;
272#if defined(__CPU_X86__)
273 __asm__("movl %%esp, %0" : "=r"(stack) :);
274#elif defined(__CPU_X64__)
275 __asm__("movq %%esp, %0" : "=r"(stack) :);
276#endif
277 return stack;
278}
279#endif
280
281#ifdef __cplusplus
282}
283#endif
284
285#endif
286/* EOF */
vsf_err_t
Definition __type.h:42
Definition linux_generic.h:102
Definition linux_generic.h:120
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 uint32_t
Definition stdint.h:9
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:162
@ vsf_arch_prio_highest
Definition win_generic.h:165
@ vsf_arch_prio_invalid
Definition win_generic.h:163
char * VSF_WIN_LPSTR
Definition win_generic.h:148
#define __VSF_ARCH_PRI(__N, __UNUSED)
Definition win_generic.h:135
unsigned long * VSF_WIN_PULONG_PTR
Definition win_generic.h:152
unsigned char VSF_WIN_BYTE
Definition win_generic.h:147
unsigned long VSF_WIN_DWORD
Definition win_generic.h:145
void __vsf_arch_irq_set_background(vsf_arch_irq_thread_t *irq_thread)
Definition win_generic.c:726
bool __vsf_arch_before_entry(void)
Definition win_generic.c:1348
VSF_WIN_ULONG_PTR * VSF_WIN_PDWORD_PTR
Definition win_generic.h:154
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:693
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:587
vsf_arch_irq_state_t
Definition win_generic.h:198
@ VSF_ARCH_IRQ_STATE_IDLE
Definition win_generic.h:199
@ VSF_ARCH_IRQ_STATE_BACKGROUND
Definition win_generic.h:202
@ VSF_ARCH_IRQ_STATE_FOREGROUND
Definition win_generic.h:201
@ VSF_ARCH_IRQ_STATE_ACTIVE
Definition win_generic.h:200
void __vsf_arch_irq_sleep(uint_fast32_t ms)
Definition win_generic.c:998
VSF_ARCH_SYSTIMER_TICK_T vsf_systimer_tick_t
Definition win_generic.h:159
volatile bool vsf_gint_state_t
Definition win_generic.h:177
int __vsf_arch_console_readline(char *buf, int bufsize)
Definition driver.c:118
VSF_WIN_ULONG_PTR VSF_WIN_DWORD_PTR
Definition win_generic.h:154
void __vsf_arch_irq_end(vsf_arch_irq_thread_t *irq_thread, bool is_terminate)
Definition win_generic.c:671
void __vsf_arch_irq_fini(vsf_arch_irq_thread_t *irq_thread)
Definition win_generic.c:681
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:152
#define VSF_ARCH_SYSTIMER_TICK_T
Definition win_generic.h:157
void * VSF_WIN_HANDLE
Definition win_generic.h:144
int vsf_arch_argu(char ***argv)
Definition linux_generic.c:601
#define __VSF_WIN_PUBLIC_CONST__
Definition win_generic.h:31
void(* vsf_arch_irq_entry_t)(void *)
Definition win_generic.h:168
void __vsf_arch_irq_start(vsf_arch_irq_thread_t *irq_thread)
Definition win_generic.c:661
void vsf_arch_free_exe(void *ptr)
Definition linux_generic.c:592
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:146
vsf_systimer_tick_t __vsf_systimer_get(void)
Definition win_generic.c:1069
vsf_arch_irq_thread_t * __vsf_arch_irq_get_cur(void)
Definition win_generic.c:721
#define VSF_ARCH_PRI_NUM
Definition win_generic.h:93
Generated from commit: vsfteam/vsf@3f77d3b