VSF Documented
macos_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 __MACOS_GENERIC_H__
19#define __MACOS_GENERIC_H__
20
21/*============================ INCLUDES ======================================*/
22
23#include "hal/vsf_hal_cfg.h"
25
26#if defined(__VSF_ARCH_MACOS_IMPLEMENT)
27# define __VSF_CLASS_IMPLEMENT__
28#endif
29
30#include "utilities/ooc_class.h"
31
32#ifdef __cplusplus
33extern "C" {
34#endif
35
36/*============================ MACROS ========================================*/
37
38#ifndef __BYTE_ORDER
39# define __BYTE_ORDER __LITTLE_ENDIAN
40#endif
41
42#ifndef VSF_ARCH_PRI_NUM
43# define VSF_ARCH_PRI_NUM 1
44#endif
45#if VSF_ARCH_PRI_NUM != 1
46# error VSF_ARCH_PRI_NUM MUST be 1 for macos
47#endif
48
49#ifndef VSF_SYSTIMER_CFG_IMPL_MODE
50# define VSF_SYSTIMER_CFG_IMPL_MODE VSF_SYSTIMER_IMPL_REQUEST_RESPONSE
51#endif
52
53// software interrupt provided by arch
54#ifndef VSF_ARCH_SWI_NUM
55# define VSF_ARCH_SWI_NUM 0
56#endif
57#if VSF_ARCH_SWI_NUM != 0
58# error VSF_ARCH_SWI_NUM MUST be 0 for macos
59#endif
60
61#define VSF_ARCH_STACK_ALIGN_BIT 4
62#define VSF_ARCH_LIMIT_NO_SET_STACK
63
64#define VSF_ARCH_STACK_PAGE_SIZE 4096
65#define VSF_ARCH_STACK_GUARDIAN_SIZE 4096
66
67/*============================ MACROFIED FUNCTIONS ===========================*/
68
69#define __VSF_ARCH_PRI(__N, __BIT) \
70 VSF_ARCH_PRIO_##__N = (__N), \
71 vsf_arch_prio_##__N = (__N),
72
73#define vsf_arch_wakeup()
74
75/*============================ TYPES =========================================*/
76
77// unit is ns
79
80typedef enum vsf_arch_prio_t {
86
87typedef void (*vsf_arch_irq_entry_t)(void*);
88
90 private_member(
91 int id;
92 void *irq_thread_to_exit;
93 void *arch_thread;
94 bool is_triggered;
95 bool is_inited;
96 )
97};
98
99typedef volatile bool vsf_gint_state_t;
100
101/*============================ INCLUDES ======================================*/
102
104
105/*============================ TYPES =========================================*/
106
108 private_member(
110 void *exit;
111 bool is_to_restart;
112 )
113};
114
115/*============================ GLOBAL VARIABLES ==============================*/
116/*============================ LOCAL VARIABLES ===============================*/
117/*============================ PROTOTYPES ====================================*/
118
119extern void __vsf_arch_irq_sleep(uint32_t ms);
120
125
126extern void __vsf_arch_irq_init(vsf_arch_irq_thread_t *irq_thread, char *name,
127 vsf_arch_irq_entry_t entry, vsf_arch_prio_t priority);
128extern void __vsf_arch_irq_fini(vsf_arch_irq_thread_t *irq_thread);
130extern void __vsf_arch_irq_start(vsf_arch_irq_thread_t *irq_thread);
131extern void __vsf_arch_irq_end(vsf_arch_irq_thread_t *irq_thread, bool is_terminate);
132
133extern void __vsf_arch_irq_exit(vsf_arch_irq_thread_t *irq_thread);
135 vsf_arch_irq_request_t *request_pending);
136
137#ifdef __cplusplus
138}
139#endif
140
141#endif
142/* EOF */
vsf_err_t
Definition __type.h:42
Definition linux_generic.h:99
Definition linux_generic.h:117
vsf_arch_prio_t
Definition cortex_a_generic.h:85
@ VSF_ARCH_PRIO_INVALID
Definition macos_generic.h:81
@ vsf_arch_prio_highest
Definition macos_generic.h:84
@ vsf_arch_prio_invalid
Definition macos_generic.h:82
void __vsf_arch_irq_set_background(vsf_arch_irq_thread_t *irq_thread)
Definition win_generic.c:726
#define __VSF_ARCH_PRI(__N, __BIT)
Definition macos_generic.h:69
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
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
uint64_t vsf_systimer_tick_t
Definition macos_generic.h:78
void __vsf_arch_irq_sleep(uint32_t ms)
Definition linux_generic.c:321
volatile bool vsf_gint_state_t
Definition macos_generic.h:99
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
void __vsf_arch_irq_request_pend(vsf_arch_irq_request_t *request)
Definition linux_generic.c:205
void(* vsf_arch_irq_entry_t)(void *)
Definition macos_generic.h:87
void __vsf_arch_irq_start(vsf_arch_irq_thread_t *irq_thread)
Definition win_generic.c:661
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
void __vsf_arch_irq_exit(vsf_arch_irq_thread_t *irq_thread)
Definition linux_generic.c:303
#define VSF_ARCH_PRI_NUM
Definition macos_generic.h:43
#define VSF_ARCH_PRI_BIT
Definition mcs51_generic.h:39
#define vsf_class(__name)
Definition ooc_class.h:52
unsigned uint32_t
Definition stdint.h:9
unsigned long long uint64_t
Definition stdint.h:11
Definition vsf_arch_without_thread_suspend_template.h:23
#define exit
Definition stdlib.h:33
#define VSF_MREPEAT(__COUNT, __MACRO, __PARAM)
Definition vsf_repeat_macro.h:51
Generated from commit: vsfteam/vsf@85be636