Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
23d99fd7baef7c76151404ef54124fd189f6b3a2
[simgrid.git] / src / simix / popping_generated.cpp
1 /**********************************************************************/
2 /* File generated by src/simix/simcalls.py from src/simix/simcalls.in */
3 /*                                                                    */
4 /*                    DO NOT EVER CHANGE THIS FILE                    */
5 /*                                                                    */
6 /* change simcalls specification in src/simix/simcalls.in             */
7 /**********************************************************************/
8
9 /*
10  * Note that the name comes from http://en.wikipedia.org/wiki/Popping
11  * Indeed, the control flow is doing a strange dance in there.
12  *
13  * That's not about http://en.wikipedia.org/wiki/Poop, despite the odor :)
14  */
15
16 #include <xbt/base.h>
17 #include "smx_private.h"
18 #if HAVE_MC
19 #include "src/mc/mc_forward.hpp"
20 #endif
21
22 XBT_LOG_EXTERNAL_DEFAULT_CATEGORY(simix_popping);
23
24 /** @brief Simcalls' names (generated from src/simix/simcalls.in) */
25 const char* simcall_names[] = {
26    "SIMCALL_NONE",  "SIMCALL_VM_SUSPEND",
27   "SIMCALL_VM_RESUME",
28   "SIMCALL_VM_SHUTDOWN",
29   "SIMCALL_VM_SAVE",
30   "SIMCALL_VM_RESTORE",
31   "SIMCALL_PROCESS_CREATE",
32   "SIMCALL_PROCESS_KILL",
33   "SIMCALL_PROCESS_KILLALL",
34   "SIMCALL_PROCESS_CLEANUP",
35   "SIMCALL_PROCESS_SUSPEND",
36   "SIMCALL_PROCESS_RESUME",
37   "SIMCALL_PROCESS_SET_HOST",
38   "SIMCALL_PROCESS_IS_SUSPENDED",
39   "SIMCALL_PROCESS_JOIN",
40   "SIMCALL_PROCESS_SLEEP",
41   "SIMCALL_EXECUTION_START",
42   "SIMCALL_EXECUTION_PARALLEL_START",
43   "SIMCALL_EXECUTION_DESTROY",
44   "SIMCALL_EXECUTION_CANCEL",
45   "SIMCALL_EXECUTION_SET_PRIORITY",
46   "SIMCALL_EXECUTION_SET_BOUND",
47   "SIMCALL_EXECUTION_SET_AFFINITY",
48   "SIMCALL_EXECUTION_WAIT",
49   "SIMCALL_PROCESS_ON_EXIT",
50   "SIMCALL_PROCESS_AUTO_RESTART_SET",
51   "SIMCALL_PROCESS_RESTART",
52   "SIMCALL_MBOX_CREATE",
53   "SIMCALL_MBOX_SET_RECEIVER",
54   "SIMCALL_COMM_IPROBE",
55   "SIMCALL_COMM_SEND",
56   "SIMCALL_COMM_ISEND",
57   "SIMCALL_COMM_RECV",
58   "SIMCALL_COMM_IRECV",
59   "SIMCALL_COMM_WAITANY",
60   "SIMCALL_COMM_WAIT",
61   "SIMCALL_COMM_TEST",
62   "SIMCALL_COMM_TESTANY",
63   "SIMCALL_MUTEX_INIT",
64   "SIMCALL_MUTEX_LOCK",
65   "SIMCALL_MUTEX_TRYLOCK",
66   "SIMCALL_MUTEX_UNLOCK",
67   "SIMCALL_COND_INIT",
68   "SIMCALL_COND_SIGNAL",
69   "SIMCALL_COND_WAIT",
70   "SIMCALL_COND_WAIT_TIMEOUT",
71   "SIMCALL_COND_BROADCAST",
72   "SIMCALL_SEM_INIT",
73   "SIMCALL_SEM_RELEASE",
74   "SIMCALL_SEM_WOULD_BLOCK",
75   "SIMCALL_SEM_ACQUIRE",
76   "SIMCALL_SEM_ACQUIRE_TIMEOUT",
77   "SIMCALL_SEM_GET_CAPACITY",
78   "SIMCALL_FILE_READ",
79   "SIMCALL_FILE_WRITE",
80   "SIMCALL_FILE_OPEN",
81   "SIMCALL_FILE_CLOSE",
82   "SIMCALL_FILE_UNLINK",
83   "SIMCALL_FILE_GET_SIZE",
84   "SIMCALL_FILE_TELL",
85   "SIMCALL_FILE_SEEK",
86   "SIMCALL_FILE_GET_INFO",
87   "SIMCALL_FILE_MOVE",
88   "SIMCALL_STORAGE_GET_FREE_SIZE",
89   "SIMCALL_STORAGE_GET_USED_SIZE",
90   "SIMCALL_STORAGE_GET_PROPERTIES",
91   "SIMCALL_STORAGE_GET_CONTENT",
92   "SIMCALL_ASR_GET_PROPERTIES",
93   "SIMCALL_MC_RANDOM",
94   "SIMCALL_SET_CATEGORY",
95   "SIMCALL_RUN_KERNEL",};
96
97 /**
98  * @brief (in kernel mode) unpack the simcall and activate the handler
99  * 
100  * This function is generated from src/simix/simcalls.in
101  */
102 void SIMIX_simcall_handle(smx_simcall_t simcall, int value) {
103   XBT_DEBUG("Handling simcall %p: %s", simcall, SIMIX_simcall_name(simcall->call));
104   SIMCALL_SET_MC_VALUE(simcall, value);
105   if (simcall->issuer->context->iwannadie && simcall->call != SIMCALL_PROCESS_CLEANUP)
106     return;
107   switch (simcall->call) {
108 case SIMCALL_VM_SUSPEND:
109        simcall_HANDLER_vm_suspend(simcall , (sg_host_t) simcall->args[0].dp);
110       SIMIX_simcall_answer(simcall);
111       break;  
112
113 case SIMCALL_VM_RESUME:
114        simcall_HANDLER_vm_resume(simcall , (sg_host_t) simcall->args[0].dp);
115       SIMIX_simcall_answer(simcall);
116       break;  
117
118 case SIMCALL_VM_SHUTDOWN:
119        simcall_HANDLER_vm_shutdown(simcall , (sg_host_t) simcall->args[0].dp);
120       SIMIX_simcall_answer(simcall);
121       break;  
122
123 case SIMCALL_VM_SAVE:
124        simcall_HANDLER_vm_save(simcall , (sg_host_t) simcall->args[0].dp);
125       SIMIX_simcall_answer(simcall);
126       break;  
127
128 case SIMCALL_VM_RESTORE:
129        simcall_HANDLER_vm_restore(simcall , (sg_host_t) simcall->args[0].dp);
130       SIMIX_simcall_answer(simcall);
131       break;  
132
133 case SIMCALL_PROCESS_CREATE:
134       simcall->result.dp = simcall_HANDLER_process_create(simcall ,  simcall->args[0].cc, (xbt_main_func_t) simcall->args[1].fp,  simcall->args[2].dp,  simcall->args[3].cc,  simcall->args[4].d,  simcall->args[5].i, (char**) simcall->args[6].dp, (xbt_dict_t) simcall->args[7].dp,  simcall->args[8].i);
135       SIMIX_simcall_answer(simcall);
136       break;  
137
138 case SIMCALL_PROCESS_KILL:
139        simcall_HANDLER_process_kill(simcall , (smx_process_t) simcall->args[0].dp);
140       SIMIX_simcall_answer(simcall);
141       break;  
142
143 case SIMCALL_PROCESS_KILLALL:
144        simcall_HANDLER_process_killall(simcall ,  simcall->args[0].i);
145       SIMIX_simcall_answer(simcall);
146       break;  
147
148 case SIMCALL_PROCESS_CLEANUP:
149        SIMIX_process_cleanup((smx_process_t) simcall->args[0].dp);
150       SIMIX_simcall_answer(simcall);
151       break;  
152
153 case SIMCALL_PROCESS_SUSPEND:
154        simcall_HANDLER_process_suspend(simcall , (smx_process_t) simcall->args[0].dp);
155        break;  
156
157 case SIMCALL_PROCESS_RESUME:
158        simcall_HANDLER_process_resume(simcall , (smx_process_t) simcall->args[0].dp);
159       SIMIX_simcall_answer(simcall);
160       break;  
161
162 case SIMCALL_PROCESS_SET_HOST:
163        simcall_HANDLER_process_set_host(simcall , (smx_process_t) simcall->args[0].dp, (sg_host_t) simcall->args[1].dp);
164       SIMIX_simcall_answer(simcall);
165       break;  
166
167 case SIMCALL_PROCESS_IS_SUSPENDED:
168       simcall->result.i = SIMIX_process_is_suspended((smx_process_t) simcall->args[0].dp);
169       SIMIX_simcall_answer(simcall);
170       break;  
171
172 case SIMCALL_PROCESS_JOIN:
173        simcall_HANDLER_process_join(simcall , (smx_process_t) simcall->args[0].dp,  simcall->args[1].d);
174        break;  
175
176 case SIMCALL_PROCESS_SLEEP:
177        simcall_HANDLER_process_sleep(simcall ,  simcall->args[0].d);
178        break;  
179
180 case SIMCALL_EXECUTION_START:
181       simcall->result.dp = simcall_HANDLER_execution_start(simcall ,  simcall->args[0].cc,  simcall->args[1].d,  simcall->args[2].d,  simcall->args[3].d,  simcall->args[4].ul);
182       SIMIX_simcall_answer(simcall);
183       break;  
184
185 case SIMCALL_EXECUTION_PARALLEL_START:
186       simcall->result.dp = SIMIX_execution_parallel_start( simcall->args[0].cc, simcall->args[1].i,(sg_host_t*) simcall->args[2].dp,(double*) simcall->args[3].dp,(double*) simcall->args[4].dp, simcall->args[5].d, simcall->args[6].d);
187       SIMIX_simcall_answer(simcall);
188       break;  
189
190 case SIMCALL_EXECUTION_DESTROY:
191        SIMIX_execution_destroy((smx_synchro_t) simcall->args[0].dp);
192       SIMIX_simcall_answer(simcall);
193       break;  
194
195 case SIMCALL_EXECUTION_CANCEL:
196        SIMIX_execution_cancel((smx_synchro_t) simcall->args[0].dp);
197       SIMIX_simcall_answer(simcall);
198       break;  
199
200 case SIMCALL_EXECUTION_SET_PRIORITY:
201        SIMIX_execution_set_priority((smx_synchro_t) simcall->args[0].dp, simcall->args[1].d);
202       SIMIX_simcall_answer(simcall);
203       break;  
204
205 case SIMCALL_EXECUTION_SET_BOUND:
206        SIMIX_execution_set_bound((smx_synchro_t) simcall->args[0].dp, simcall->args[1].d);
207       SIMIX_simcall_answer(simcall);
208       break;  
209
210 case SIMCALL_EXECUTION_SET_AFFINITY:
211        SIMIX_execution_set_affinity((smx_synchro_t) simcall->args[0].dp,(sg_host_t) simcall->args[1].dp, simcall->args[2].ul);
212       SIMIX_simcall_answer(simcall);
213       break;  
214
215 case SIMCALL_EXECUTION_WAIT:
216        simcall_HANDLER_execution_wait(simcall , (smx_synchro_t) simcall->args[0].dp);
217        break;  
218
219 case SIMCALL_PROCESS_ON_EXIT:
220        SIMIX_process_on_exit((smx_process_t) simcall->args[0].dp,(int_f_pvoid_pvoid_t) simcall->args[1].fp, simcall->args[2].dp);
221       SIMIX_simcall_answer(simcall);
222       break;  
223
224 case SIMCALL_PROCESS_AUTO_RESTART_SET:
225        SIMIX_process_auto_restart_set((smx_process_t) simcall->args[0].dp, simcall->args[1].i);
226       SIMIX_simcall_answer(simcall);
227       break;  
228
229 case SIMCALL_PROCESS_RESTART:
230       simcall->result.dp = simcall_HANDLER_process_restart(simcall , (smx_process_t) simcall->args[0].dp);
231       SIMIX_simcall_answer(simcall);
232       break;  
233
234 case SIMCALL_MBOX_CREATE:
235       simcall->result.dp = SIMIX_mbox_create( simcall->args[0].cc);
236       SIMIX_simcall_answer(simcall);
237       break;  
238
239 case SIMCALL_MBOX_SET_RECEIVER:
240        SIMIX_mbox_set_receiver((smx_mailbox_t) simcall->args[0].dp,(smx_process_t) simcall->args[1].dp);
241       SIMIX_simcall_answer(simcall);
242       break;  
243
244 case SIMCALL_COMM_IPROBE:
245       simcall->result.dp = simcall_HANDLER_comm_iprobe(simcall , (smx_mailbox_t) simcall->args[0].dp,  simcall->args[1].i,  simcall->args[2].i,  simcall->args[3].i, (simix_match_func_t) simcall->args[4].fp,  simcall->args[5].dp);
246       SIMIX_simcall_answer(simcall);
247       break;  
248
249 case SIMCALL_COMM_SEND:
250        simcall_HANDLER_comm_send(simcall , (smx_process_t) simcall->args[0].dp, (smx_mailbox_t) simcall->args[1].dp,  simcall->args[2].d,  simcall->args[3].d,  simcall->args[4].dp,  simcall->args[5].sz, (simix_match_func_t) simcall->args[6].fp, (simix_copy_data_func_t) simcall->args[7].fp,  simcall->args[8].dp,  simcall->args[9].d);
251        break;  
252
253 case SIMCALL_COMM_ISEND:
254       simcall->result.dp = simcall_HANDLER_comm_isend(simcall , (smx_process_t) simcall->args[0].dp, (smx_mailbox_t) simcall->args[1].dp,  simcall->args[2].d,  simcall->args[3].d,  simcall->args[4].dp,  simcall->args[5].sz, (simix_match_func_t) simcall->args[6].fp, (simix_clean_func_t) simcall->args[7].fp, (simix_copy_data_func_t) simcall->args[8].fp,  simcall->args[9].dp,  simcall->args[10].i);
255       SIMIX_simcall_answer(simcall);
256       break;  
257
258 case SIMCALL_COMM_RECV:
259        simcall_HANDLER_comm_recv(simcall , (smx_process_t) simcall->args[0].dp, (smx_mailbox_t) simcall->args[1].dp,  simcall->args[2].dp, (size_t*) simcall->args[3].dp, (simix_match_func_t) simcall->args[4].fp, (simix_copy_data_func_t) simcall->args[5].fp,  simcall->args[6].dp,  simcall->args[7].d,  simcall->args[8].d);
260        break;  
261
262 case SIMCALL_COMM_IRECV:
263       simcall->result.dp = simcall_HANDLER_comm_irecv(simcall , (smx_process_t) simcall->args[0].dp, (smx_mailbox_t) simcall->args[1].dp,  simcall->args[2].dp, (size_t*) simcall->args[3].dp, (simix_match_func_t) simcall->args[4].fp, (simix_copy_data_func_t) simcall->args[5].fp,  simcall->args[6].dp,  simcall->args[7].d);
264       SIMIX_simcall_answer(simcall);
265       break;  
266
267 case SIMCALL_COMM_WAITANY:
268        simcall_HANDLER_comm_waitany(simcall , (xbt_dynar_t) simcall->args[0].dp);
269        break;  
270
271 case SIMCALL_COMM_WAIT:
272        simcall_HANDLER_comm_wait(simcall , (smx_synchro_t) simcall->args[0].dp,  simcall->args[1].d);
273        break;  
274
275 case SIMCALL_COMM_TEST:
276        simcall_HANDLER_comm_test(simcall , (smx_synchro_t) simcall->args[0].dp);
277        break;  
278
279 case SIMCALL_COMM_TESTANY:
280        simcall_HANDLER_comm_testany(simcall , (xbt_dynar_t) simcall->args[0].dp);
281        break;  
282
283 case SIMCALL_MUTEX_INIT:
284       simcall->result.dp = simcall_HANDLER_mutex_init(simcall );
285       SIMIX_simcall_answer(simcall);
286       break;  
287
288 case SIMCALL_MUTEX_LOCK:
289        simcall_HANDLER_mutex_lock(simcall , (smx_mutex_t) simcall->args[0].dp);
290        break;  
291
292 case SIMCALL_MUTEX_TRYLOCK:
293       simcall->result.i = simcall_HANDLER_mutex_trylock(simcall , (smx_mutex_t) simcall->args[0].dp);
294       SIMIX_simcall_answer(simcall);
295       break;  
296
297 case SIMCALL_MUTEX_UNLOCK:
298        simcall_HANDLER_mutex_unlock(simcall , (smx_mutex_t) simcall->args[0].dp);
299       SIMIX_simcall_answer(simcall);
300       break;  
301
302 case SIMCALL_COND_INIT:
303       simcall->result.dp = SIMIX_cond_init();
304       SIMIX_simcall_answer(simcall);
305       break;  
306
307 case SIMCALL_COND_SIGNAL:
308        SIMIX_cond_signal((smx_cond_t) simcall->args[0].dp);
309       SIMIX_simcall_answer(simcall);
310       break;  
311
312 case SIMCALL_COND_WAIT:
313        simcall_HANDLER_cond_wait(simcall , (smx_cond_t) simcall->args[0].dp, (smx_mutex_t) simcall->args[1].dp);
314        break;  
315
316 case SIMCALL_COND_WAIT_TIMEOUT:
317        simcall_HANDLER_cond_wait_timeout(simcall , (smx_cond_t) simcall->args[0].dp, (smx_mutex_t) simcall->args[1].dp,  simcall->args[2].d);
318        break;  
319
320 case SIMCALL_COND_BROADCAST:
321        SIMIX_cond_broadcast((smx_cond_t) simcall->args[0].dp);
322       SIMIX_simcall_answer(simcall);
323       break;  
324
325 case SIMCALL_SEM_INIT:
326       simcall->result.dp = SIMIX_sem_init( simcall->args[0].ui);
327       SIMIX_simcall_answer(simcall);
328       break;  
329
330 case SIMCALL_SEM_RELEASE:
331        simcall_HANDLER_sem_release(simcall , (smx_sem_t) simcall->args[0].dp);
332       SIMIX_simcall_answer(simcall);
333       break;  
334
335 case SIMCALL_SEM_WOULD_BLOCK:
336       simcall->result.i = simcall_HANDLER_sem_would_block(simcall , (smx_sem_t) simcall->args[0].dp);
337       SIMIX_simcall_answer(simcall);
338       break;  
339
340 case SIMCALL_SEM_ACQUIRE:
341        simcall_HANDLER_sem_acquire(simcall , (smx_sem_t) simcall->args[0].dp);
342        break;  
343
344 case SIMCALL_SEM_ACQUIRE_TIMEOUT:
345        simcall_HANDLER_sem_acquire_timeout(simcall , (smx_sem_t) simcall->args[0].dp,  simcall->args[1].d);
346        break;  
347
348 case SIMCALL_SEM_GET_CAPACITY:
349       simcall->result.i = simcall_HANDLER_sem_get_capacity(simcall , (smx_sem_t) simcall->args[0].dp);
350       SIMIX_simcall_answer(simcall);
351       break;  
352
353 case SIMCALL_FILE_READ:
354        simcall_HANDLER_file_read(simcall , (smx_file_t) simcall->args[0].dp,  simcall->args[1].sgsz, (sg_host_t) simcall->args[2].dp);
355        break;  
356
357 case SIMCALL_FILE_WRITE:
358        simcall_HANDLER_file_write(simcall , (smx_file_t) simcall->args[0].dp,  simcall->args[1].sgsz, (sg_host_t) simcall->args[2].dp);
359        break;  
360
361 case SIMCALL_FILE_OPEN:
362        simcall_HANDLER_file_open(simcall ,  simcall->args[0].cc, (sg_host_t) simcall->args[1].dp);
363        break;  
364
365 case SIMCALL_FILE_CLOSE:
366        simcall_HANDLER_file_close(simcall , (smx_file_t) simcall->args[0].dp, (sg_host_t) simcall->args[1].dp);
367        break;  
368
369 case SIMCALL_FILE_UNLINK:
370       simcall->result.i = SIMIX_file_unlink((smx_file_t) simcall->args[0].dp,(sg_host_t) simcall->args[1].dp);
371       SIMIX_simcall_answer(simcall);
372       break;  
373
374 case SIMCALL_FILE_GET_SIZE:
375       simcall->result.sgsz = simcall_HANDLER_file_get_size(simcall , (smx_file_t) simcall->args[0].dp);
376       SIMIX_simcall_answer(simcall);
377       break;  
378
379 case SIMCALL_FILE_TELL:
380       simcall->result.sgsz = simcall_HANDLER_file_tell(simcall , (smx_file_t) simcall->args[0].dp);
381       SIMIX_simcall_answer(simcall);
382       break;  
383
384 case SIMCALL_FILE_SEEK:
385       simcall->result.i = simcall_HANDLER_file_seek(simcall , (smx_file_t) simcall->args[0].dp,  simcall->args[1].sgoff,  simcall->args[2].i);
386       SIMIX_simcall_answer(simcall);
387       break;  
388
389 case SIMCALL_FILE_GET_INFO:
390       simcall->result.dp = simcall_HANDLER_file_get_info(simcall , (smx_file_t) simcall->args[0].dp);
391       SIMIX_simcall_answer(simcall);
392       break;  
393
394 case SIMCALL_FILE_MOVE:
395       simcall->result.i = simcall_HANDLER_file_move(simcall , (smx_file_t) simcall->args[0].dp,  simcall->args[1].cc);
396       SIMIX_simcall_answer(simcall);
397       break;  
398
399 case SIMCALL_STORAGE_GET_FREE_SIZE:
400       simcall->result.sgsz = simcall_HANDLER_storage_get_free_size(simcall , (smx_storage_t) simcall->args[0].dp);
401       SIMIX_simcall_answer(simcall);
402       break;  
403
404 case SIMCALL_STORAGE_GET_USED_SIZE:
405       simcall->result.sgsz = simcall_HANDLER_storage_get_used_size(simcall , (smx_storage_t) simcall->args[0].dp);
406       SIMIX_simcall_answer(simcall);
407       break;  
408
409 case SIMCALL_STORAGE_GET_PROPERTIES:
410       simcall->result.dp = SIMIX_storage_get_properties((smx_storage_t) simcall->args[0].dp);
411       SIMIX_simcall_answer(simcall);
412       break;  
413
414 case SIMCALL_STORAGE_GET_CONTENT:
415       simcall->result.dp = SIMIX_storage_get_content((smx_storage_t) simcall->args[0].dp);
416       SIMIX_simcall_answer(simcall);
417       break;  
418
419 case SIMCALL_ASR_GET_PROPERTIES:
420       simcall->result.dp = simcall_HANDLER_asr_get_properties(simcall ,  simcall->args[0].cc);
421       SIMIX_simcall_answer(simcall);
422       break;  
423
424 case SIMCALL_MC_RANDOM:
425       simcall->result.i = simcall_HANDLER_mc_random(simcall ,  simcall->args[0].i,  simcall->args[1].i);
426       SIMIX_simcall_answer(simcall);
427       break;  
428
429 case SIMCALL_SET_CATEGORY:
430        SIMIX_set_category((smx_synchro_t) simcall->args[0].dp, simcall->args[1].cc);
431       SIMIX_simcall_answer(simcall);
432       break;  
433
434 case SIMCALL_RUN_KERNEL:
435        SIMIX_run_kernel( simcall->args[0].dp);
436       SIMIX_simcall_answer(simcall);
437       break;  
438     case NUM_SIMCALLS:
439       break;
440     case SIMCALL_NONE:
441       THROWF(arg_error,0,"Asked to do the noop syscall on %s@%s",
442           SIMIX_process_get_name(simcall->issuer),
443           sg_host_get_name(SIMIX_process_get_host(simcall->issuer))
444           );
445       break;
446
447   }
448 }