Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
[simix] Switch to .cpp files
[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 #ifdef HAVE_MC
19 #include "src/mc/mc_forward.h"
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_HOST_ON",
27   "SIMCALL_HOST_OFF",
28   "SIMCALL_HOST_GET_PROPERTIES",
29   "SIMCALL_HOST_GET_PROCESS_LIST",
30   "SIMCALL_HOST_GET_CURRENT_POWER_PEAK",
31   "SIMCALL_HOST_GET_POWER_PEAK_AT",
32   "SIMCALL_HOST_GET_WATTMIN_AT",
33   "SIMCALL_HOST_GET_WATTMAX_AT",
34   "SIMCALL_HOST_SET_PSTATE",
35   "SIMCALL_HOST_GET_MOUNTED_STORAGE_LIST",
36   "SIMCALL_HOST_GET_ATTACHED_STORAGE_LIST",
37   "SIMCALL_HOST_GET_PARAMS",
38   "SIMCALL_HOST_SET_PARAMS",
39   "SIMCALL_VM_CREATE",
40   "SIMCALL_VM_START",
41   "SIMCALL_VM_GET_STATE",
42   "SIMCALL_VM_MIGRATE",
43   "SIMCALL_VM_GET_PM",
44   "SIMCALL_VM_SET_BOUND",
45   "SIMCALL_VM_SET_AFFINITY",
46   "SIMCALL_VM_DESTROY",
47   "SIMCALL_VM_SUSPEND",
48   "SIMCALL_VM_RESUME",
49   "SIMCALL_VM_SHUTDOWN",
50   "SIMCALL_VM_SAVE",
51   "SIMCALL_VM_RESTORE",
52   "SIMCALL_VM_MIGRATEFROM_RESUMETO",
53   "SIMCALL_PROCESS_CREATE",
54   "SIMCALL_PROCESS_KILL",
55   "SIMCALL_PROCESS_KILLALL",
56   "SIMCALL_PROCESS_CLEANUP",
57   "SIMCALL_PROCESS_SUSPEND",
58   "SIMCALL_PROCESS_RESUME",
59   "SIMCALL_PROCESS_COUNT",
60   "SIMCALL_PROCESS_GET_PID",
61   "SIMCALL_PROCESS_GET_PPID",
62   "SIMCALL_PROCESS_GET_DATA",
63   "SIMCALL_PROCESS_SET_DATA",
64   "SIMCALL_PROCESS_SET_HOST",
65   "SIMCALL_PROCESS_GET_HOST",
66   "SIMCALL_PROCESS_GET_NAME",
67   "SIMCALL_PROCESS_IS_SUSPENDED",
68   "SIMCALL_PROCESS_GET_PROPERTIES",
69   "SIMCALL_PROCESS_JOIN",
70   "SIMCALL_PROCESS_SLEEP",
71   "SIMCALL_PROCESS_EXECUTE",
72   "SIMCALL_PROCESS_PARALLEL_EXECUTE",
73   "SIMCALL_PROCESS_EXECUTION_DESTROY",
74   "SIMCALL_PROCESS_EXECUTION_CANCEL",
75   "SIMCALL_PROCESS_EXECUTION_GET_REMAINS",
76   "SIMCALL_PROCESS_EXECUTION_GET_STATE",
77   "SIMCALL_PROCESS_EXECUTION_SET_PRIORITY",
78   "SIMCALL_PROCESS_EXECUTION_SET_BOUND",
79   "SIMCALL_PROCESS_EXECUTION_SET_AFFINITY",
80   "SIMCALL_PROCESS_EXECUTION_WAIT",
81   "SIMCALL_PROCESS_ON_EXIT",
82   "SIMCALL_PROCESS_AUTO_RESTART_SET",
83   "SIMCALL_PROCESS_RESTART",
84   "SIMCALL_RDV_CREATE",
85   "SIMCALL_RDV_DESTROY",
86   "SIMCALL_RDV_COMM_COUNT_BY_HOST",
87   "SIMCALL_RDV_GET_HEAD",
88   "SIMCALL_RDV_SET_RECEIVER",
89   "SIMCALL_RDV_GET_RECEIVER",
90   "SIMCALL_COMM_IPROBE",
91   "SIMCALL_COMM_SEND",
92   "SIMCALL_COMM_ISEND",
93   "SIMCALL_COMM_RECV",
94   "SIMCALL_COMM_IRECV",
95   "SIMCALL_COMM_CANCEL",
96   "SIMCALL_COMM_WAITANY",
97   "SIMCALL_COMM_WAIT",
98   "SIMCALL_COMM_TEST",
99   "SIMCALL_COMM_TESTANY",
100   "SIMCALL_COMM_GET_REMAINS",
101   "SIMCALL_COMM_GET_STATE",
102   "SIMCALL_COMM_GET_SRC_DATA",
103   "SIMCALL_COMM_GET_DST_DATA",
104   "SIMCALL_COMM_GET_SRC_PROC",
105   "SIMCALL_COMM_GET_DST_PROC",
106   "SIMCALL_MUTEX_INIT",
107   "SIMCALL_MUTEX_DESTROY",
108   "SIMCALL_MUTEX_LOCK",
109   "SIMCALL_MUTEX_TRYLOCK",
110   "SIMCALL_MUTEX_UNLOCK",
111   "SIMCALL_COND_INIT",
112   "SIMCALL_COND_DESTROY",
113   "SIMCALL_COND_SIGNAL",
114   "SIMCALL_COND_WAIT",
115   "SIMCALL_COND_WAIT_TIMEOUT",
116   "SIMCALL_COND_BROADCAST",
117   "SIMCALL_SEM_INIT",
118   "SIMCALL_SEM_DESTROY",
119   "SIMCALL_SEM_RELEASE",
120   "SIMCALL_SEM_WOULD_BLOCK",
121   "SIMCALL_SEM_ACQUIRE",
122   "SIMCALL_SEM_ACQUIRE_TIMEOUT",
123   "SIMCALL_SEM_GET_CAPACITY",
124   "SIMCALL_FILE_READ",
125   "SIMCALL_FILE_WRITE",
126   "SIMCALL_FILE_OPEN",
127   "SIMCALL_FILE_CLOSE",
128   "SIMCALL_FILE_UNLINK",
129   "SIMCALL_FILE_GET_SIZE",
130   "SIMCALL_FILE_TELL",
131   "SIMCALL_FILE_SEEK",
132   "SIMCALL_FILE_GET_INFO",
133   "SIMCALL_FILE_MOVE",
134   "SIMCALL_STORAGE_GET_FREE_SIZE",
135   "SIMCALL_STORAGE_GET_USED_SIZE",
136   "SIMCALL_STORAGE_GET_PROPERTIES",
137   "SIMCALL_STORAGE_GET_CONTENT",
138   "SIMCALL_ASR_GET_PROPERTIES",
139   "SIMCALL_MC_RANDOM",
140   "SIMCALL_SET_CATEGORY",
141 #ifdef HAVE_LATENCY_BOUND_TRACKING
142   "SIMCALL_COMM_IS_LATENCY_BOUNDED",
143 #endif
144
145 #ifdef HAVE_MC
146   "SIMCALL_MC_SNAPSHOT",
147   "SIMCALL_MC_COMPARE_SNAPSHOTS",
148 #endif
149 };
150
151 /**
152  * @brief (in kernel mode) unpack the simcall and activate the handler
153  * 
154  * This function is generated from src/simix/simcalls.in
155  */
156 void SIMIX_simcall_handle(smx_simcall_t simcall, int value) {
157   XBT_DEBUG("Handling simcall %p: %s", simcall, SIMIX_simcall_name(simcall->call));
158   SIMCALL_SET_MC_VALUE(simcall, value);
159   if (simcall->issuer->context->iwannadie && simcall->call != SIMCALL_PROCESS_CLEANUP)
160     return;
161   switch (simcall->call) {
162 case SIMCALL_HOST_ON:
163        SIMIX_host_on((sg_host_t) simcall->args[0].dp);
164       SIMIX_simcall_answer(simcall);
165       break;  
166
167 case SIMCALL_HOST_OFF:
168        simcall_HANDLER_host_off(simcall , (sg_host_t) simcall->args[0].dp);
169       SIMIX_simcall_answer(simcall);
170       break;  
171
172 case SIMCALL_HOST_GET_PROPERTIES:
173       simcall->result.dp = SIMIX_host_get_properties((sg_host_t) simcall->args[0].dp);
174       SIMIX_simcall_answer(simcall);
175       break;  
176
177 case SIMCALL_HOST_GET_PROCESS_LIST:
178       simcall->result.dp = SIMIX_host_get_process_list((sg_host_t) simcall->args[0].dp);
179       SIMIX_simcall_answer(simcall);
180       break;  
181
182 case SIMCALL_HOST_GET_CURRENT_POWER_PEAK:
183       simcall->result.d = SIMIX_host_get_current_power_peak((sg_host_t) simcall->args[0].dp);
184       SIMIX_simcall_answer(simcall);
185       break;  
186
187 case SIMCALL_HOST_GET_POWER_PEAK_AT:
188       simcall->result.d = SIMIX_host_get_power_peak_at((sg_host_t) simcall->args[0].dp, simcall->args[1].i);
189       SIMIX_simcall_answer(simcall);
190       break;  
191
192 case SIMCALL_HOST_GET_WATTMIN_AT:
193       simcall->result.d = SIMIX_host_get_wattmin_at((sg_host_t) simcall->args[0].dp, simcall->args[1].i);
194       SIMIX_simcall_answer(simcall);
195       break;  
196
197 case SIMCALL_HOST_GET_WATTMAX_AT:
198       simcall->result.d = SIMIX_host_get_wattmax_at((sg_host_t) simcall->args[0].dp, simcall->args[1].i);
199       SIMIX_simcall_answer(simcall);
200       break;  
201
202 case SIMCALL_HOST_SET_PSTATE:
203        SIMIX_host_set_pstate((sg_host_t) simcall->args[0].dp, simcall->args[1].i);
204       SIMIX_simcall_answer(simcall);
205       break;  
206
207 case SIMCALL_HOST_GET_MOUNTED_STORAGE_LIST:
208       simcall->result.dp = SIMIX_host_get_mounted_storage_list((sg_host_t) simcall->args[0].dp);
209       SIMIX_simcall_answer(simcall);
210       break;  
211
212 case SIMCALL_HOST_GET_ATTACHED_STORAGE_LIST:
213       simcall->result.dp = SIMIX_host_get_attached_storage_list((sg_host_t) simcall->args[0].dp);
214       SIMIX_simcall_answer(simcall);
215       break;  
216
217 case SIMCALL_HOST_GET_PARAMS:
218        SIMIX_host_get_params((sg_host_t) simcall->args[0].dp,(vm_params_t) simcall->args[1].dp);
219       SIMIX_simcall_answer(simcall);
220       break;  
221
222 case SIMCALL_HOST_SET_PARAMS:
223        SIMIX_host_set_params((sg_host_t) simcall->args[0].dp,(vm_params_t) simcall->args[1].dp);
224       SIMIX_simcall_answer(simcall);
225       break;  
226
227 case SIMCALL_VM_CREATE:
228       simcall->result.dp = SIMIX_vm_create( simcall->args[0].cc,(sg_host_t) simcall->args[1].dp);
229       SIMIX_simcall_answer(simcall);
230       break;  
231
232 case SIMCALL_VM_START:
233        SIMIX_vm_start((sg_host_t) simcall->args[0].dp);
234       SIMIX_simcall_answer(simcall);
235       break;  
236
237 case SIMCALL_VM_GET_STATE:
238       simcall->result.i = SIMIX_vm_get_state((sg_host_t) simcall->args[0].dp);
239       SIMIX_simcall_answer(simcall);
240       break;  
241
242 case SIMCALL_VM_MIGRATE:
243        SIMIX_vm_migrate((sg_host_t) simcall->args[0].dp,(sg_host_t) simcall->args[1].dp);
244       SIMIX_simcall_answer(simcall);
245       break;  
246
247 case SIMCALL_VM_GET_PM:
248       simcall->result.dp = SIMIX_vm_get_pm((sg_host_t) simcall->args[0].dp);
249       SIMIX_simcall_answer(simcall);
250       break;  
251
252 case SIMCALL_VM_SET_BOUND:
253        SIMIX_vm_set_bound((sg_host_t) simcall->args[0].dp, simcall->args[1].d);
254       SIMIX_simcall_answer(simcall);
255       break;  
256
257 case SIMCALL_VM_SET_AFFINITY:
258        SIMIX_vm_set_affinity((sg_host_t) simcall->args[0].dp,(sg_host_t) simcall->args[1].dp, simcall->args[2].ul);
259       SIMIX_simcall_answer(simcall);
260       break;  
261
262 case SIMCALL_VM_DESTROY:
263        SIMIX_vm_destroy((sg_host_t) simcall->args[0].dp);
264       SIMIX_simcall_answer(simcall);
265       break;  
266
267 case SIMCALL_VM_SUSPEND:
268        simcall_HANDLER_vm_suspend(simcall , (sg_host_t) simcall->args[0].dp);
269       SIMIX_simcall_answer(simcall);
270       break;  
271
272 case SIMCALL_VM_RESUME:
273        simcall_HANDLER_vm_resume(simcall , (sg_host_t) simcall->args[0].dp);
274       SIMIX_simcall_answer(simcall);
275       break;  
276
277 case SIMCALL_VM_SHUTDOWN:
278        simcall_HANDLER_vm_shutdown(simcall , (sg_host_t) simcall->args[0].dp);
279       SIMIX_simcall_answer(simcall);
280       break;  
281
282 case SIMCALL_VM_SAVE:
283        simcall_HANDLER_vm_save(simcall , (sg_host_t) simcall->args[0].dp);
284       SIMIX_simcall_answer(simcall);
285       break;  
286
287 case SIMCALL_VM_RESTORE:
288        simcall_HANDLER_vm_restore(simcall , (sg_host_t) simcall->args[0].dp);
289       SIMIX_simcall_answer(simcall);
290       break;  
291
292 case SIMCALL_VM_MIGRATEFROM_RESUMETO:
293        SIMIX_vm_migratefrom_resumeto((sg_host_t) simcall->args[0].dp,(sg_host_t) simcall->args[1].dp,(sg_host_t) simcall->args[2].dp);
294       SIMIX_simcall_answer(simcall);
295       break;  
296
297 case SIMCALL_PROCESS_CREATE:
298       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);
299       SIMIX_simcall_answer(simcall);
300       break;  
301
302 case SIMCALL_PROCESS_KILL:
303        simcall_HANDLER_process_kill(simcall , (smx_process_t) simcall->args[0].dp);
304       SIMIX_simcall_answer(simcall);
305       break;  
306
307 case SIMCALL_PROCESS_KILLALL:
308        simcall_HANDLER_process_killall(simcall ,  simcall->args[0].i);
309       SIMIX_simcall_answer(simcall);
310       break;  
311
312 case SIMCALL_PROCESS_CLEANUP:
313        SIMIX_process_cleanup((smx_process_t) simcall->args[0].dp);
314       SIMIX_simcall_answer(simcall);
315       break;  
316
317 case SIMCALL_PROCESS_SUSPEND:
318        simcall_HANDLER_process_suspend(simcall , (smx_process_t) simcall->args[0].dp);
319        break;  
320
321 case SIMCALL_PROCESS_RESUME:
322        simcall_HANDLER_process_resume(simcall , (smx_process_t) simcall->args[0].dp);
323       SIMIX_simcall_answer(simcall);
324       break;  
325
326 case SIMCALL_PROCESS_COUNT:
327       simcall->result.i = SIMIX_process_count();
328       SIMIX_simcall_answer(simcall);
329       break;  
330
331 case SIMCALL_PROCESS_GET_PID:
332       simcall->result.i = SIMIX_process_get_PID((smx_process_t) simcall->args[0].dp);
333       SIMIX_simcall_answer(simcall);
334       break;  
335
336 case SIMCALL_PROCESS_GET_PPID:
337       simcall->result.i = SIMIX_process_get_PPID((smx_process_t) simcall->args[0].dp);
338       SIMIX_simcall_answer(simcall);
339       break;  
340
341 case SIMCALL_PROCESS_GET_DATA:
342       simcall->result.dp = SIMIX_process_get_data((smx_process_t) simcall->args[0].dp);
343       SIMIX_simcall_answer(simcall);
344       break;  
345
346 case SIMCALL_PROCESS_SET_DATA:
347        SIMIX_process_set_data((smx_process_t) simcall->args[0].dp, simcall->args[1].dp);
348       SIMIX_simcall_answer(simcall);
349       break;  
350
351 case SIMCALL_PROCESS_SET_HOST:
352        simcall_HANDLER_process_set_host(simcall , (smx_process_t) simcall->args[0].dp, (sg_host_t) simcall->args[1].dp);
353       SIMIX_simcall_answer(simcall);
354       break;  
355
356 case SIMCALL_PROCESS_GET_HOST:
357       simcall->result.dp = SIMIX_process_get_host((smx_process_t) simcall->args[0].dp);
358       SIMIX_simcall_answer(simcall);
359       break;  
360
361 case SIMCALL_PROCESS_GET_NAME:
362       simcall->result.cc = SIMIX_process_get_name((smx_process_t) simcall->args[0].dp);
363       SIMIX_simcall_answer(simcall);
364       break;  
365
366 case SIMCALL_PROCESS_IS_SUSPENDED:
367       simcall->result.i = SIMIX_process_is_suspended((smx_process_t) simcall->args[0].dp);
368       SIMIX_simcall_answer(simcall);
369       break;  
370
371 case SIMCALL_PROCESS_GET_PROPERTIES:
372       simcall->result.dp = SIMIX_process_get_properties((smx_process_t) simcall->args[0].dp);
373       SIMIX_simcall_answer(simcall);
374       break;  
375
376 case SIMCALL_PROCESS_JOIN:
377        simcall_HANDLER_process_join(simcall , (smx_process_t) simcall->args[0].dp,  simcall->args[1].d);
378        break;  
379
380 case SIMCALL_PROCESS_SLEEP:
381        simcall_HANDLER_process_sleep(simcall ,  simcall->args[0].d);
382        break;  
383
384 case SIMCALL_PROCESS_EXECUTE:
385       simcall->result.dp = simcall_HANDLER_process_execute(simcall ,  simcall->args[0].cc,  simcall->args[1].d,  simcall->args[2].d,  simcall->args[3].d,  simcall->args[4].ul);
386       SIMIX_simcall_answer(simcall);
387       break;  
388
389 case SIMCALL_PROCESS_PARALLEL_EXECUTE:
390       simcall->result.dp = SIMIX_process_parallel_execute( 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);
391       SIMIX_simcall_answer(simcall);
392       break;  
393
394 case SIMCALL_PROCESS_EXECUTION_DESTROY:
395        SIMIX_process_execution_destroy((smx_synchro_t) simcall->args[0].dp);
396       SIMIX_simcall_answer(simcall);
397       break;  
398
399 case SIMCALL_PROCESS_EXECUTION_CANCEL:
400        SIMIX_process_execution_cancel((smx_synchro_t) simcall->args[0].dp);
401       SIMIX_simcall_answer(simcall);
402       break;  
403
404 case SIMCALL_PROCESS_EXECUTION_GET_REMAINS:
405       simcall->result.d = SIMIX_process_execution_get_remains((smx_synchro_t) simcall->args[0].dp);
406       SIMIX_simcall_answer(simcall);
407       break;  
408
409 case SIMCALL_PROCESS_EXECUTION_GET_STATE:
410       simcall->result.i = SIMIX_process_execution_get_state((smx_synchro_t) simcall->args[0].dp);
411       SIMIX_simcall_answer(simcall);
412       break;  
413
414 case SIMCALL_PROCESS_EXECUTION_SET_PRIORITY:
415        SIMIX_process_execution_set_priority((smx_synchro_t) simcall->args[0].dp, simcall->args[1].d);
416       SIMIX_simcall_answer(simcall);
417       break;  
418
419 case SIMCALL_PROCESS_EXECUTION_SET_BOUND:
420        SIMIX_process_execution_set_bound((smx_synchro_t) simcall->args[0].dp, simcall->args[1].d);
421       SIMIX_simcall_answer(simcall);
422       break;  
423
424 case SIMCALL_PROCESS_EXECUTION_SET_AFFINITY:
425        SIMIX_process_execution_set_affinity((smx_synchro_t) simcall->args[0].dp,(sg_host_t) simcall->args[1].dp, simcall->args[2].ul);
426       SIMIX_simcall_answer(simcall);
427       break;  
428
429 case SIMCALL_PROCESS_EXECUTION_WAIT:
430        simcall_HANDLER_process_execution_wait(simcall , (smx_synchro_t) simcall->args[0].dp);
431        break;  
432
433 case SIMCALL_PROCESS_ON_EXIT:
434        SIMIX_process_on_exit((smx_process_t) simcall->args[0].dp,(int_f_pvoid_pvoid_t) simcall->args[1].fp, simcall->args[2].dp);
435       SIMIX_simcall_answer(simcall);
436       break;  
437
438 case SIMCALL_PROCESS_AUTO_RESTART_SET:
439        SIMIX_process_auto_restart_set((smx_process_t) simcall->args[0].dp, simcall->args[1].i);
440       SIMIX_simcall_answer(simcall);
441       break;  
442
443 case SIMCALL_PROCESS_RESTART:
444       simcall->result.dp = simcall_HANDLER_process_restart(simcall , (smx_process_t) simcall->args[0].dp);
445       SIMIX_simcall_answer(simcall);
446       break;  
447
448 case SIMCALL_RDV_CREATE:
449       simcall->result.dp = SIMIX_rdv_create( simcall->args[0].cc);
450       SIMIX_simcall_answer(simcall);
451       break;  
452
453 case SIMCALL_RDV_DESTROY:
454        SIMIX_rdv_destroy((smx_rdv_t) simcall->args[0].dp);
455       SIMIX_simcall_answer(simcall);
456       break;  
457
458 case SIMCALL_RDV_COMM_COUNT_BY_HOST:
459       simcall->result.ui = SIMIX_rdv_comm_count_by_host((smx_rdv_t) simcall->args[0].dp,(sg_host_t) simcall->args[1].dp);
460       SIMIX_simcall_answer(simcall);
461       break;  
462
463 case SIMCALL_RDV_GET_HEAD:
464       simcall->result.dp = SIMIX_rdv_get_head((smx_rdv_t) simcall->args[0].dp);
465       SIMIX_simcall_answer(simcall);
466       break;  
467
468 case SIMCALL_RDV_SET_RECEIVER:
469        SIMIX_rdv_set_receiver((smx_rdv_t) simcall->args[0].dp,(smx_process_t) simcall->args[1].dp);
470       SIMIX_simcall_answer(simcall);
471       break;  
472
473 case SIMCALL_RDV_GET_RECEIVER:
474       simcall->result.dp = SIMIX_rdv_get_receiver((smx_rdv_t) simcall->args[0].dp);
475       SIMIX_simcall_answer(simcall);
476       break;  
477
478 case SIMCALL_COMM_IPROBE:
479       simcall->result.dp = simcall_HANDLER_comm_iprobe(simcall , (smx_rdv_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);
480       SIMIX_simcall_answer(simcall);
481       break;  
482
483 case SIMCALL_COMM_SEND:
484        simcall_HANDLER_comm_send(simcall , (smx_process_t) simcall->args[0].dp, (smx_rdv_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);
485        break;  
486
487 case SIMCALL_COMM_ISEND:
488       simcall->result.dp = simcall_HANDLER_comm_isend(simcall , (smx_process_t) simcall->args[0].dp, (smx_rdv_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);
489       SIMIX_simcall_answer(simcall);
490       break;  
491
492 case SIMCALL_COMM_RECV:
493        simcall_HANDLER_comm_recv(simcall , (smx_process_t) simcall->args[0].dp, (smx_rdv_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);
494        break;  
495
496 case SIMCALL_COMM_IRECV:
497       simcall->result.dp = simcall_HANDLER_comm_irecv(simcall , (smx_process_t) simcall->args[0].dp, (smx_rdv_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);
498       SIMIX_simcall_answer(simcall);
499       break;  
500
501 case SIMCALL_COMM_CANCEL:
502        SIMIX_comm_cancel((smx_synchro_t) simcall->args[0].dp);
503       SIMIX_simcall_answer(simcall);
504       break;  
505
506 case SIMCALL_COMM_WAITANY:
507        simcall_HANDLER_comm_waitany(simcall , (xbt_dynar_t) simcall->args[0].dp);
508        break;  
509
510 case SIMCALL_COMM_WAIT:
511        simcall_HANDLER_comm_wait(simcall , (smx_synchro_t) simcall->args[0].dp,  simcall->args[1].d);
512        break;  
513
514 case SIMCALL_COMM_TEST:
515        simcall_HANDLER_comm_test(simcall , (smx_synchro_t) simcall->args[0].dp);
516        break;  
517
518 case SIMCALL_COMM_TESTANY:
519        simcall_HANDLER_comm_testany(simcall , (xbt_dynar_t) simcall->args[0].dp);
520        break;  
521
522 case SIMCALL_COMM_GET_REMAINS:
523       simcall->result.d = SIMIX_comm_get_remains((smx_synchro_t) simcall->args[0].dp);
524       SIMIX_simcall_answer(simcall);
525       break;  
526
527 case SIMCALL_COMM_GET_STATE:
528       simcall->result.i = SIMIX_comm_get_state((smx_synchro_t) simcall->args[0].dp);
529       SIMIX_simcall_answer(simcall);
530       break;  
531
532 case SIMCALL_COMM_GET_SRC_DATA:
533       simcall->result.dp = SIMIX_comm_get_src_data((smx_synchro_t) simcall->args[0].dp);
534       SIMIX_simcall_answer(simcall);
535       break;  
536
537 case SIMCALL_COMM_GET_DST_DATA:
538       simcall->result.dp = SIMIX_comm_get_dst_data((smx_synchro_t) simcall->args[0].dp);
539       SIMIX_simcall_answer(simcall);
540       break;  
541
542 case SIMCALL_COMM_GET_SRC_PROC:
543       simcall->result.dp = SIMIX_comm_get_src_proc((smx_synchro_t) simcall->args[0].dp);
544       SIMIX_simcall_answer(simcall);
545       break;  
546
547 case SIMCALL_COMM_GET_DST_PROC:
548       simcall->result.dp = SIMIX_comm_get_dst_proc((smx_synchro_t) simcall->args[0].dp);
549       SIMIX_simcall_answer(simcall);
550       break;  
551
552 case SIMCALL_MUTEX_INIT:
553       simcall->result.dp = simcall_HANDLER_mutex_init(simcall );
554       SIMIX_simcall_answer(simcall);
555       break;  
556
557 case SIMCALL_MUTEX_DESTROY:
558        SIMIX_mutex_destroy((smx_mutex_t) simcall->args[0].dp);
559       SIMIX_simcall_answer(simcall);
560       break;  
561
562 case SIMCALL_MUTEX_LOCK:
563        simcall_HANDLER_mutex_lock(simcall , (smx_mutex_t) simcall->args[0].dp);
564        break;  
565
566 case SIMCALL_MUTEX_TRYLOCK:
567       simcall->result.i = simcall_HANDLER_mutex_trylock(simcall , (smx_mutex_t) simcall->args[0].dp);
568       SIMIX_simcall_answer(simcall);
569       break;  
570
571 case SIMCALL_MUTEX_UNLOCK:
572        simcall_HANDLER_mutex_unlock(simcall , (smx_mutex_t) simcall->args[0].dp);
573       SIMIX_simcall_answer(simcall);
574       break;  
575
576 case SIMCALL_COND_INIT:
577       simcall->result.dp = SIMIX_cond_init();
578       SIMIX_simcall_answer(simcall);
579       break;  
580
581 case SIMCALL_COND_DESTROY:
582        SIMIX_cond_destroy((smx_cond_t) simcall->args[0].dp);
583       SIMIX_simcall_answer(simcall);
584       break;  
585
586 case SIMCALL_COND_SIGNAL:
587        SIMIX_cond_signal((smx_cond_t) simcall->args[0].dp);
588       SIMIX_simcall_answer(simcall);
589       break;  
590
591 case SIMCALL_COND_WAIT:
592        simcall_HANDLER_cond_wait(simcall , (smx_cond_t) simcall->args[0].dp, (smx_mutex_t) simcall->args[1].dp);
593        break;  
594
595 case SIMCALL_COND_WAIT_TIMEOUT:
596        simcall_HANDLER_cond_wait_timeout(simcall , (smx_cond_t) simcall->args[0].dp, (smx_mutex_t) simcall->args[1].dp,  simcall->args[2].d);
597        break;  
598
599 case SIMCALL_COND_BROADCAST:
600        SIMIX_cond_broadcast((smx_cond_t) simcall->args[0].dp);
601       SIMIX_simcall_answer(simcall);
602       break;  
603
604 case SIMCALL_SEM_INIT:
605       simcall->result.dp = SIMIX_sem_init( simcall->args[0].ui);
606       SIMIX_simcall_answer(simcall);
607       break;  
608
609 case SIMCALL_SEM_DESTROY:
610        SIMIX_sem_destroy((smx_sem_t) simcall->args[0].dp);
611       SIMIX_simcall_answer(simcall);
612       break;  
613
614 case SIMCALL_SEM_RELEASE:
615        simcall_HANDLER_sem_release(simcall , (smx_sem_t) simcall->args[0].dp);
616       SIMIX_simcall_answer(simcall);
617       break;  
618
619 case SIMCALL_SEM_WOULD_BLOCK:
620       simcall->result.i = simcall_HANDLER_sem_would_block(simcall , (smx_sem_t) simcall->args[0].dp);
621       SIMIX_simcall_answer(simcall);
622       break;  
623
624 case SIMCALL_SEM_ACQUIRE:
625        simcall_HANDLER_sem_acquire(simcall , (smx_sem_t) simcall->args[0].dp);
626        break;  
627
628 case SIMCALL_SEM_ACQUIRE_TIMEOUT:
629        simcall_HANDLER_sem_acquire_timeout(simcall , (smx_sem_t) simcall->args[0].dp,  simcall->args[1].d);
630        break;  
631
632 case SIMCALL_SEM_GET_CAPACITY:
633       simcall->result.i = simcall_HANDLER_sem_get_capacity(simcall , (smx_sem_t) simcall->args[0].dp);
634       SIMIX_simcall_answer(simcall);
635       break;  
636
637 case SIMCALL_FILE_READ:
638        simcall_HANDLER_file_read(simcall , (smx_file_t) simcall->args[0].dp,  simcall->args[1].sgsz, (sg_host_t) simcall->args[2].dp);
639        break;  
640
641 case SIMCALL_FILE_WRITE:
642        simcall_HANDLER_file_write(simcall , (smx_file_t) simcall->args[0].dp,  simcall->args[1].sgsz, (sg_host_t) simcall->args[2].dp);
643        break;  
644
645 case SIMCALL_FILE_OPEN:
646        simcall_HANDLER_file_open(simcall ,  simcall->args[0].cc, (sg_host_t) simcall->args[1].dp);
647        break;  
648
649 case SIMCALL_FILE_CLOSE:
650        simcall_HANDLER_file_close(simcall , (smx_file_t) simcall->args[0].dp, (sg_host_t) simcall->args[1].dp);
651        break;  
652
653 case SIMCALL_FILE_UNLINK:
654       simcall->result.i = SIMIX_file_unlink((smx_file_t) simcall->args[0].dp,(sg_host_t) simcall->args[1].dp);
655       SIMIX_simcall_answer(simcall);
656       break;  
657
658 case SIMCALL_FILE_GET_SIZE:
659       simcall->result.sgsz = simcall_HANDLER_file_get_size(simcall , (smx_file_t) simcall->args[0].dp);
660       SIMIX_simcall_answer(simcall);
661       break;  
662
663 case SIMCALL_FILE_TELL:
664       simcall->result.sgsz = simcall_HANDLER_file_tell(simcall , (smx_file_t) simcall->args[0].dp);
665       SIMIX_simcall_answer(simcall);
666       break;  
667
668 case SIMCALL_FILE_SEEK:
669       simcall->result.i = simcall_HANDLER_file_seek(simcall , (smx_file_t) simcall->args[0].dp,  simcall->args[1].sgoff,  simcall->args[2].i);
670       SIMIX_simcall_answer(simcall);
671       break;  
672
673 case SIMCALL_FILE_GET_INFO:
674       simcall->result.dp = simcall_HANDLER_file_get_info(simcall , (smx_file_t) simcall->args[0].dp);
675       SIMIX_simcall_answer(simcall);
676       break;  
677
678 case SIMCALL_FILE_MOVE:
679       simcall->result.i = simcall_HANDLER_file_move(simcall , (smx_file_t) simcall->args[0].dp,  simcall->args[1].cc);
680       SIMIX_simcall_answer(simcall);
681       break;  
682
683 case SIMCALL_STORAGE_GET_FREE_SIZE:
684       simcall->result.sgsz = simcall_HANDLER_storage_get_free_size(simcall , (smx_storage_t) simcall->args[0].dp);
685       SIMIX_simcall_answer(simcall);
686       break;  
687
688 case SIMCALL_STORAGE_GET_USED_SIZE:
689       simcall->result.sgsz = simcall_HANDLER_storage_get_used_size(simcall , (smx_storage_t) simcall->args[0].dp);
690       SIMIX_simcall_answer(simcall);
691       break;  
692
693 case SIMCALL_STORAGE_GET_PROPERTIES:
694       simcall->result.dp = SIMIX_storage_get_properties((smx_storage_t) simcall->args[0].dp);
695       SIMIX_simcall_answer(simcall);
696       break;  
697
698 case SIMCALL_STORAGE_GET_CONTENT:
699       simcall->result.dp = SIMIX_storage_get_content((smx_storage_t) simcall->args[0].dp);
700       SIMIX_simcall_answer(simcall);
701       break;  
702
703 case SIMCALL_ASR_GET_PROPERTIES:
704       simcall->result.dp = simcall_HANDLER_asr_get_properties(simcall ,  simcall->args[0].cc);
705       SIMIX_simcall_answer(simcall);
706       break;  
707
708 case SIMCALL_MC_RANDOM:
709       simcall->result.i = simcall_HANDLER_mc_random(simcall ,  simcall->args[0].i,  simcall->args[1].i);
710       SIMIX_simcall_answer(simcall);
711       break;  
712
713 case SIMCALL_SET_CATEGORY:
714        SIMIX_set_category((smx_synchro_t) simcall->args[0].dp, simcall->args[1].cc);
715       SIMIX_simcall_answer(simcall);
716       break;  
717
718 #ifdef HAVE_LATENCY_BOUND_TRACKING
719 case SIMCALL_COMM_IS_LATENCY_BOUNDED:
720       simcall->result.i = SIMIX_comm_is_latency_bounded((smx_synchro_t) simcall->args[0].dp);
721       SIMIX_simcall_answer(simcall);
722       break;  
723
724 #endif
725
726 #ifdef HAVE_MC
727 case SIMCALL_MC_SNAPSHOT:
728       simcall->result.dp = simcall_HANDLER_mc_snapshot(simcall );
729       SIMIX_simcall_answer(simcall);
730       break;  
731
732 case SIMCALL_MC_COMPARE_SNAPSHOTS:
733       simcall->result.i = simcall_HANDLER_mc_compare_snapshots(simcall , (mc_snapshot_t) simcall->args[0].dp, (mc_snapshot_t) simcall->args[1].dp);
734       SIMIX_simcall_answer(simcall);
735       break;  
736
737 #endif
738     case NUM_SIMCALLS:
739       break;
740     case SIMCALL_NONE:
741       THROWF(arg_error,0,"Asked to do the noop syscall on %s@%s",
742           SIMIX_process_get_name(simcall->issuer),
743           SIMIX_host_get_name(SIMIX_process_get_host(simcall->issuer))
744           );
745       break;
746
747   }
748 }