FreeCalypso > hg > freecalypso-citrine
comparison gpf/osl/os_tim_fl.c @ 0:75a11d740a02
initial import of gsm-fw from freecalypso-sw rev 1033:5ab737ac3ad7
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Thu, 09 Jun 2016 00:02:41 +0000 |
parents | |
children |
comparison
equal
deleted
inserted
replaced
-1:000000000000 | 0:75a11d740a02 |
---|---|
1 /* | |
2 * This C module is a reconstruction based on the disassembly of | |
3 * os_tim.obj in frame_na7_db_fl.lib from the Leonardo package, | |
4 * subsequently reworked by Space Falcon. | |
5 */ | |
6 | |
7 /* set of included headers from COFF symtab: */ | |
8 #include <stdio.h> | |
9 #include "gpfconf.h" /* FreeCalypso addition */ | |
10 #include "../../nucleus/nucleus.h" | |
11 #include "typedefs.h" | |
12 #include "os.h" | |
13 #include "gdi.h" | |
14 #include "os_types.h" | |
15 #include "os_glob.h" | |
16 | |
17 extern UNSIGNED TMD_Timer; | |
18 extern INT TMD_Timer_State; | |
19 | |
20 extern T_OS_TIMER_ENTRY TimerTable[]; | |
21 extern T_OS_TIMER_TABLE_ENTRY *p_list[]; | |
22 | |
23 extern void os_Timeout(UNSIGNED t_handle); | |
24 extern void timer_error(int err); | |
25 | |
26 unsigned os_time_to_tick_multiplier = TIME_TO_TICK_TDMA_FRAME_MULTIPLIER; | |
27 unsigned os_tick_to_time_multiplier = TICK_TO_TIME_TDMA_FRAME_MULTIPLIER; | |
28 | |
29 unsigned volatile t_start_ticks; | |
30 T_OS_TIMER_TABLE_ENTRY *t_running; | |
31 int used_timers; | |
32 int next_t_handle; | |
33 int volatile t_list_access; | |
34 int max_used_timers; | |
35 NU_SEMAPHORE TimSemCB; | |
36 NU_TIMER os_timer_cb; | |
37 | |
38 #define BARRIER asm volatile ("": : :"memory") | |
39 | |
40 GLOBAL LONG | |
41 os_set_tick(int os_system_tick) | |
42 { | |
43 switch (os_system_tick) { | |
44 case SYSTEM_TICK_TDMA_FRAME: | |
45 os_time_to_tick_multiplier = TIME_TO_TICK_TDMA_FRAME_MULTIPLIER; | |
46 os_tick_to_time_multiplier = TICK_TO_TIME_TDMA_FRAME_MULTIPLIER; | |
47 return(OS_OK); | |
48 case SYSTEM_TICK_10_MS: | |
49 os_time_to_tick_multiplier = TIME_TO_TICK_10MS_MULTIPLIER; | |
50 os_tick_to_time_multiplier = TICK_TO_TIME_10MS_MULTIPLIER; | |
51 return(OS_OK); | |
52 default: | |
53 return(OS_ERROR); | |
54 } | |
55 } | |
56 | |
57 GLOBAL LONG | |
58 os_TimerInformation(USHORT Index, char *Buffer) | |
59 { | |
60 static int t_info_read; | |
61 | |
62 if (t_info_read) { | |
63 t_info_read = 0; | |
64 return(OS_ERROR); | |
65 } | |
66 sprintf(Buffer, "Maximum %d of %d available timers running", | |
67 max_used_timers, MaxSimultaneousTimer); | |
68 t_info_read = 1; | |
69 return(OS_OK); | |
70 } | |
71 | |
72 GLOBAL LONG | |
73 os_TimInit(void) | |
74 { | |
75 int i; | |
76 | |
77 if (NU_Create_Semaphore(&TimSemCB, "TIMSEM", 1, NU_PRIORITY) | |
78 != NU_SUCCESS) | |
79 return(OS_ERROR); | |
80 if (NU_Create_Timer(&os_timer_cb, "OS_TIMER", os_Timeout, 0, 1, 0, | |
81 NU_DISABLE_TIMER) != NU_SUCCESS) | |
82 return(OS_ERROR); | |
83 used_timers = 0; | |
84 max_used_timers = 0; | |
85 next_t_handle = 1; | |
86 t_list_access = 0; | |
87 t_start_ticks = 0; | |
88 p_list[0] = 0; | |
89 for (i = 1; i < MaxSimultaneousTimer; i++) { | |
90 TimerTable[i].entry.status = TMR_FREE; | |
91 TimerTable[i].entry.next = 0; | |
92 TimerTable[i].entry.prev = 0; | |
93 TimerTable[i].next_t_handle = i + 1; | |
94 p_list[i] = 0; | |
95 } | |
96 TimerTable[MaxSimultaneousTimer].entry.status = TMR_FREE; | |
97 TimerTable[MaxSimultaneousTimer].next_t_handle = 0; | |
98 t_running = 0; | |
99 return(OS_OK); | |
100 } | |
101 | |
102 GLOBAL LONG | |
103 os_RecoverTick(OS_TICK ticks) | |
104 { | |
105 UNSIGNED current_system_clock; | |
106 | |
107 current_system_clock = NU_Retrieve_Clock(); | |
108 NU_Set_Clock(current_system_clock + ticks); | |
109 if (TMD_Timer_State == TM_ACTIVE) { | |
110 if (TMD_Timer <= ticks) { | |
111 TMD_Timer_State = TM_EXPIRED; | |
112 TMD_Timer = 0; | |
113 } else | |
114 TMD_Timer -= ticks; | |
115 } | |
116 return(OS_OK); | |
117 } | |
118 | |
119 GLOBAL LONG | |
120 os_QueryTimer(OS_HANDLE TaskHandle, OS_HANDLE TimerHandle, | |
121 OS_TIME *RemainingTime) | |
122 { | |
123 T_OS_TIMER_TABLE_ENTRY *timer, *t_iter; | |
124 OS_TICK c_ticks, r_ticks, e_ticks; | |
125 STATUS sts; | |
126 | |
127 if (TimerHandle > MaxSimultaneousTimer) | |
128 return(OS_ERROR); | |
129 sts = NU_Obtain_Semaphore(&TimSemCB, NU_SUSPEND); | |
130 timer = &TimerTable[TimerHandle].entry; | |
131 if (timer->status == TMR_FREE) { | |
132 if (sts == NU_SUCCESS) | |
133 NU_Release_Semaphore(&TimSemCB); | |
134 return(OS_ERROR); | |
135 } | |
136 t_list_access = 1; | |
137 BARRIER; | |
138 if (!t_running) { | |
139 r_ticks = 0; | |
140 goto out; | |
141 } | |
142 c_ticks = NU_Retrieve_Clock(); | |
143 e_ticks = c_ticks - t_start_ticks; | |
144 t_iter = t_running; | |
145 if (t_iter->r_ticks >= e_ticks) | |
146 r_ticks = t_iter->r_ticks - e_ticks; | |
147 else | |
148 r_ticks = 0; | |
149 while (t_iter != timer) { | |
150 t_iter = t_iter->next; | |
151 if (t_iter == t_running) { | |
152 r_ticks = 0; | |
153 goto out; | |
154 } | |
155 r_ticks += t_iter->r_ticks; | |
156 } | |
157 out: BARRIER; | |
158 t_list_access = 0; | |
159 if (sts == NU_SUCCESS) | |
160 NU_Release_Semaphore(&TimSemCB); | |
161 *RemainingTime = SYSTEM_TICKS_TO_TIME(r_ticks); | |
162 return(OS_OK); | |
163 } | |
164 | |
165 GLOBAL LONG | |
166 os_InactivityTicks(int *next_event, OS_TICK *next_event_ticks) | |
167 { | |
168 *next_event = 1; | |
169 switch (TMD_Timer_State) { | |
170 case TM_ACTIVE: | |
171 *next_event_ticks = TMD_Timer; | |
172 return(OS_OK); | |
173 case TM_NOT_ACTIVE: | |
174 *next_event_ticks = 0; | |
175 *next_event = 0; | |
176 return(OS_OK); | |
177 default: | |
178 *next_event_ticks = 0; | |
179 return(OS_OK); | |
180 } | |
181 } |