Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
3d42aab6b26ff1a838c9d187b6468fbd2df6b99e
[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_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_PROCESS_EXECUTE",
42   "SIMCALL_PROCESS_PARALLEL_EXECUTE",
43   "SIMCALL_PROCESS_EXECUTION_DESTROY",
44   "SIMCALL_PROCESS_EXECUTION_CANCEL",
45   "SIMCALL_PROCESS_EXECUTION_GET_REMAINS",
46   "SIMCALL_PROCESS_EXECUTION_GET_STATE",
47   "SIMCALL_PROCESS_EXECUTION_SET_PRIORITY",
48   "SIMCALL_PROCESS_EXECUTION_SET_BOUND",
49   "SIMCALL_PROCESS_EXECUTION_SET_AFFINITY",
50   "SIMCALL_PROCESS_EXECUTION_WAIT",
51   "SIMCALL_PROCESS_ON_EXIT",
52   "SIMCALL_PROCESS_AUTO_RESTART_SET",
53   "SIMCALL_PROCESS_RESTART",
54   "SIMCALL_RDV_CREATE",
55   "SIMCALL_RDV_DESTROY",
56   "SIMCALL_RDV_COMM_COUNT_BY_HOST",
57   "SIMCALL_RDV_GET_HEAD",
58   "SIMCALL_RDV_SET_RECEIVER",
59   "SIMCALL_RDV_GET_RECEIVER",
60   "SIMCALL_COMM_IPROBE",
61   "SIMCALL_COMM_SEND",
62   "SIMCALL_COMM_ISEND",
63   "SIMCALL_COMM_RECV",
64   "SIMCALL_COMM_IRECV",
65   "SIMCALL_COMM_CANCEL",
66   "SIMCALL_COMM_WAITANY",
67   "SIMCALL_COMM_WAIT",
68   "SIMCALL_COMM_TEST",
69   "SIMCALL_COMM_TESTANY",
70   "SIMCALL_COMM_GET_REMAINS",
71   "SIMCALL_COMM_GET_STATE",
72   "SIMCALL_COMM_GET_SRC_DATA",
73   "SIMCALL_COMM_GET_DST_DATA",
74   "SIMCALL_COMM_GET_SRC_PROC",
75   "SIMCALL_COMM_GET_DST_PROC",
76   "SIMCALL_MUTEX_INIT",
77   "SIMCALL_MUTEX_DESTROY",
78   "SIMCALL_MUTEX_LOCK",
79   "SIMCALL_MUTEX_TRYLOCK",
80   "SIMCALL_MUTEX_UNLOCK",
81   "SIMCALL_COND_INIT",
82   "SIMCALL_COND_DESTROY",
83   "SIMCALL_COND_SIGNAL",
84   "SIMCALL_COND_WAIT",
85   "SIMCALL_COND_WAIT_TIMEOUT",
86   "SIMCALL_COND_BROADCAST",
87   "SIMCALL_SEM_INIT",
88   "SIMCALL_SEM_DESTROY",
89   "SIMCALL_SEM_RELEASE",
90   "SIMCALL_SEM_WOULD_BLOCK",
91   "SIMCALL_SEM_ACQUIRE",
92   "SIMCALL_SEM_ACQUIRE_TIMEOUT",
93   "SIMCALL_SEM_GET_CAPACITY",
94   "SIMCALL_FILE_READ",
95   "SIMCALL_FILE_WRITE",
96   "SIMCALL_FILE_OPEN",
97   "SIMCALL_FILE_CLOSE",
98   "SIMCALL_FILE_UNLINK",
99   "SIMCALL_FILE_GET_SIZE",
100   "SIMCALL_FILE_TELL",
101   "SIMCALL_FILE_SEEK",
102   "SIMCALL_FILE_GET_INFO",
103   "SIMCALL_FILE_MOVE",
104   "SIMCALL_STORAGE_GET_FREE_SIZE",
105   "SIMCALL_STORAGE_GET_USED_SIZE",
106   "SIMCALL_STORAGE_GET_PROPERTIES",
107   "SIMCALL_STORAGE_GET_CONTENT",
108   "SIMCALL_ASR_GET_PROPERTIES",
109   "SIMCALL_MC_RANDOM",
110   "SIMCALL_SET_CATEGORY",
111   "SIMCALL_RUN_KERNEL",
112 #ifdef HAVE_LATENCY_BOUND_TRACKING
113   "SIMCALL_COMM_IS_LATENCY_BOUNDED",
114 #endif
115
116 #ifdef HAVE_MC
117   "SIMCALL_MC_SNAPSHOT",
118   "SIMCALL_MC_COMPARE_SNAPSHOTS",
119 #endif
120 };
121
122 /**
123  * @brief (in kernel mode) unpack the simcall and activate the handler
124  * 
125  * This function is generated from src/simix/simcalls.in
126  */
127 void SIMIX_simcall_handle(smx_simcall_t simcall, int value) {
128   XBT_DEBUG("Handling simcall %p: %s", simcall, SIMIX_simcall_name(simcall->call));
129   SIMCALL_SET_MC_VALUE(simcall, value);
130   if (simcall->issuer->context->iwannadie && simcall->call != SIMCALL_PROCESS_CLEANUP)
131     return;
132   switch (simcall->call) {
133 case SIMCALL_VM_SUSPEND:
134        simcall_HANDLER_vm_suspend(simcall , (sg_host_t) simcall->args[0].dp);
135       SIMIX_simcall_answer(simcall);
136       break;  
137
138 case SIMCALL_VM_RESUME:
139        simcall_HANDLER_vm_resume(simcall , (sg_host_t) simcall->args[0].dp);
140       SIMIX_simcall_answer(simcall);
141       break;  
142
143 case SIMCALL_VM_SHUTDOWN:
144        simcall_HANDLER_vm_shutdown(simcall , (sg_host_t) simcall->args[0].dp);
145       SIMIX_simcall_answer(simcall);
146       break;  
147
148 case SIMCALL_VM_SAVE:
149        simcall_HANDLER_vm_save(simcall , (sg_host_t) simcall->args[0].dp);
150       SIMIX_simcall_answer(simcall);
151       break;  
152
153 case SIMCALL_VM_RESTORE:
154        simcall_HANDLER_vm_restore(simcall , (sg_host_t) simcall->args[0].dp);
155       SIMIX_simcall_answer(simcall);
156       break;  
157
158 case SIMCALL_PROCESS_CREATE:
159       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);
160       SIMIX_simcall_answer(simcall);
161       break;  
162
163 case SIMCALL_PROCESS_KILL:
164        simcall_HANDLER_process_kill(simcall , (smx_process_t) simcall->args[0].dp);
165       SIMIX_simcall_answer(simcall);
166       break;  
167
168 case SIMCALL_PROCESS_KILLALL:
169        simcall_HANDLER_process_killall(simcall ,  simcall->args[0].i);
170       SIMIX_simcall_answer(simcall);
171       break;  
172
173 case SIMCALL_PROCESS_CLEANUP:
174        SIMIX_process_cleanup((smx_process_t) simcall->args[0].dp);
175       SIMIX_simcall_answer(simcall);
176       break;  
177
178 case SIMCALL_PROCESS_SUSPEND:
179        simcall_HANDLER_process_suspend(simcall , (smx_process_t) simcall->args[0].dp);
180        break;  
181
182 case SIMCALL_PROCESS_RESUME:
183        simcall_HANDLER_process_resume(simcall , (smx_process_t) simcall->args[0].dp);
184       SIMIX_simcall_answer(simcall);
185       break;  
186
187 case SIMCALL_PROCESS_SET_HOST:
188        simcall_HANDLER_process_set_host(simcall , (smx_process_t) simcall->args[0].dp, (sg_host_t) simcall->args[1].dp);
189       SIMIX_simcall_answer(simcall);
190       break;  
191
192 case SIMCALL_PROCESS_IS_SUSPENDED:
193       simcall->result.i = SIMIX_process_is_suspended((smx_process_t) simcall->args[0].dp);
194       SIMIX_simcall_answer(simcall);
195       break;  
196
197 case SIMCALL_PROCESS_JOIN:
198        simcall_HANDLER_process_join(simcall , (smx_process_t) simcall->args[0].dp,  simcall->args[1].d);
199        break;  
200
201 case SIMCALL_PROCESS_SLEEP:
202        simcall_HANDLER_process_sleep(simcall ,  simcall->args[0].d);
203        break;  
204
205 case SIMCALL_PROCESS_EXECUTE:
206       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);
207       SIMIX_simcall_answer(simcall);
208       break;  
209
210 case SIMCALL_PROCESS_PARALLEL_EXECUTE:
211       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);
212       SIMIX_simcall_answer(simcall);
213       break;  
214
215 case SIMCALL_PROCESS_EXECUTION_DESTROY:
216        SIMIX_process_execution_destroy((smx_synchro_t) simcall->args[0].dp);
217       SIMIX_simcall_answer(simcall);
218       break;  
219
220 case SIMCALL_PROCESS_EXECUTION_CANCEL:
221        SIMIX_process_execution_cancel((smx_synchro_t) simcall->args[0].dp);
222       SIMIX_simcall_answer(simcall);
223       break;  
224
225 case SIMCALL_PROCESS_EXECUTION_GET_REMAINS:
226       simcall->result.d = SIMIX_process_execution_get_remains((smx_synchro_t) simcall->args[0].dp);
227       SIMIX_simcall_answer(simcall);
228       break;  
229
230 case SIMCALL_PROCESS_EXECUTION_GET_STATE:
231       simcall->result.i = SIMIX_process_execution_get_state((smx_synchro_t) simcall->args[0].dp);
232       SIMIX_simcall_answer(simcall);
233       break;  
234
235 case SIMCALL_PROCESS_EXECUTION_SET_PRIORITY:
236        SIMIX_process_execution_set_priority((smx_synchro_t) simcall->args[0].dp, simcall->args[1].d);
237       SIMIX_simcall_answer(simcall);
238       break;  
239
240 case SIMCALL_PROCESS_EXECUTION_SET_BOUND:
241        SIMIX_process_execution_set_bound((smx_synchro_t) simcall->args[0].dp, simcall->args[1].d);
242       SIMIX_simcall_answer(simcall);
243       break;  
244
245 case SIMCALL_PROCESS_EXECUTION_SET_AFFINITY:
246        SIMIX_process_execution_set_affinity((smx_synchro_t) simcall->args[0].dp,(sg_host_t) simcall->args[1].dp, simcall->args[2].ul);
247       SIMIX_simcall_answer(simcall);
248       break;  
249
250 case SIMCALL_PROCESS_EXECUTION_WAIT:
251        simcall_HANDLER_process_execution_wait(simcall , (smx_synchro_t) simcall->args[0].dp);
252        break;  
253
254 case SIMCALL_PROCESS_ON_EXIT:
255        SIMIX_process_on_exit((smx_process_t) simcall->args[0].dp,(int_f_pvoid_pvoid_t) simcall->args[1].fp, simcall->args[2].dp);
256       SIMIX_simcall_answer(simcall);
257       break;  
258
259 case SIMCALL_PROCESS_AUTO_RESTART_SET:
260        SIMIX_process_auto_restart_set((smx_process_t) simcall->args[0].dp, simcall->args[1].i);
261       SIMIX_simcall_answer(simcall);
262       break;  
263
264 case SIMCALL_PROCESS_RESTART:
265       simcall->result.dp = simcall_HANDLER_process_restart(simcall , (smx_process_t) simcall->args[0].dp);
266       SIMIX_simcall_answer(simcall);
267       break;  
268
269 case SIMCALL_RDV_CREATE:
270       simcall->result.dp = SIMIX_rdv_create( simcall->args[0].cc);
271       SIMIX_simcall_answer(simcall);
272       break;  
273
274 case SIMCALL_RDV_DESTROY:
275        SIMIX_rdv_destroy((smx_rdv_t) simcall->args[0].dp);
276       SIMIX_simcall_answer(simcall);
277       break;  
278
279 case SIMCALL_RDV_COMM_COUNT_BY_HOST:
280       simcall->result.ui = SIMIX_rdv_comm_count_by_host((smx_rdv_t) simcall->args[0].dp,(sg_host_t) simcall->args[1].dp);
281       SIMIX_simcall_answer(simcall);
282       break;  
283
284 case SIMCALL_RDV_GET_HEAD:
285       simcall->result.dp = SIMIX_rdv_get_head((smx_rdv_t) simcall->args[0].dp);
286       SIMIX_simcall_answer(simcall);
287       break;  
288
289 case SIMCALL_RDV_SET_RECEIVER:
290        SIMIX_rdv_set_receiver((smx_rdv_t) simcall->args[0].dp,(smx_process_t) simcall->args[1].dp);
291       SIMIX_simcall_answer(simcall);
292       break;  
293
294 case SIMCALL_RDV_GET_RECEIVER:
295       simcall->result.dp = SIMIX_rdv_get_receiver((smx_rdv_t) simcall->args[0].dp);
296       SIMIX_simcall_answer(simcall);
297       break;  
298
299 case SIMCALL_COMM_IPROBE:
300       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);
301       SIMIX_simcall_answer(simcall);
302       break;  
303
304 case SIMCALL_COMM_SEND:
305        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);
306        break;  
307
308 case SIMCALL_COMM_ISEND:
309       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);
310       SIMIX_simcall_answer(simcall);
311       break;  
312
313 case SIMCALL_COMM_RECV:
314        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);
315        break;  
316
317 case SIMCALL_COMM_IRECV:
318       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);
319       SIMIX_simcall_answer(simcall);
320       break;  
321
322 case SIMCALL_COMM_CANCEL:
323        SIMIX_comm_cancel((smx_synchro_t) simcall->args[0].dp);
324       SIMIX_simcall_answer(simcall);
325       break;  
326
327 case SIMCALL_COMM_WAITANY:
328        simcall_HANDLER_comm_waitany(simcall , (xbt_dynar_t) simcall->args[0].dp);
329        break;  
330
331 case SIMCALL_COMM_WAIT:
332        simcall_HANDLER_comm_wait(simcall , (smx_synchro_t) simcall->args[0].dp,  simcall->args[1].d);
333        break;  
334
335 case SIMCALL_COMM_TEST:
336        simcall_HANDLER_comm_test(simcall , (smx_synchro_t) simcall->args[0].dp);
337        break;  
338
339 case SIMCALL_COMM_TESTANY:
340        simcall_HANDLER_comm_testany(simcall , (xbt_dynar_t) simcall->args[0].dp);
341        break;  
342
343 case SIMCALL_COMM_GET_REMAINS:
344       simcall->result.d = SIMIX_comm_get_remains((smx_synchro_t) simcall->args[0].dp);
345       SIMIX_simcall_answer(simcall);
346       break;  
347
348 case SIMCALL_COMM_GET_STATE:
349       simcall->result.i = SIMIX_comm_get_state((smx_synchro_t) simcall->args[0].dp);
350       SIMIX_simcall_answer(simcall);
351       break;  
352
353 case SIMCALL_COMM_GET_SRC_DATA:
354       simcall->result.dp = SIMIX_comm_get_src_data((smx_synchro_t) simcall->args[0].dp);
355       SIMIX_simcall_answer(simcall);
356       break;  
357
358 case SIMCALL_COMM_GET_DST_DATA:
359       simcall->result.dp = SIMIX_comm_get_dst_data((smx_synchro_t) simcall->args[0].dp);
360       SIMIX_simcall_answer(simcall);
361       break;  
362
363 case SIMCALL_COMM_GET_SRC_PROC:
364       simcall->result.dp = SIMIX_comm_get_src_proc((smx_synchro_t) simcall->args[0].dp);
365       SIMIX_simcall_answer(simcall);
366       break;  
367
368 case SIMCALL_COMM_GET_DST_PROC:
369       simcall->result.dp = SIMIX_comm_get_dst_proc((smx_synchro_t) simcall->args[0].dp);
370       SIMIX_simcall_answer(simcall);
371       break;  
372
373 case SIMCALL_MUTEX_INIT:
374       simcall->result.dp = simcall_HANDLER_mutex_init(simcall );
375       SIMIX_simcall_answer(simcall);
376       break;  
377
378 case SIMCALL_MUTEX_DESTROY:
379        SIMIX_mutex_destroy((smx_mutex_t) simcall->args[0].dp);
380       SIMIX_simcall_answer(simcall);
381       break;  
382
383 case SIMCALL_MUTEX_LOCK:
384        simcall_HANDLER_mutex_lock(simcall , (smx_mutex_t) simcall->args[0].dp);
385        break;  
386
387 case SIMCALL_MUTEX_TRYLOCK:
388       simcall->result.i = simcall_HANDLER_mutex_trylock(simcall , (smx_mutex_t) simcall->args[0].dp);
389       SIMIX_simcall_answer(simcall);
390       break;  
391
392 case SIMCALL_MUTEX_UNLOCK:
393        simcall_HANDLER_mutex_unlock(simcall , (smx_mutex_t) simcall->args[0].dp);
394       SIMIX_simcall_answer(simcall);
395       break;  
396
397 case SIMCALL_COND_INIT:
398       simcall->result.dp = SIMIX_cond_init();
399       SIMIX_simcall_answer(simcall);
400       break;  
401
402 case SIMCALL_COND_DESTROY:
403        SIMIX_cond_destroy((smx_cond_t) simcall->args[0].dp);
404       SIMIX_simcall_answer(simcall);
405       break;  
406
407 case SIMCALL_COND_SIGNAL:
408        SIMIX_cond_signal((smx_cond_t) simcall->args[0].dp);
409       SIMIX_simcall_answer(simcall);
410       break;  
411
412 case SIMCALL_COND_WAIT:
413        simcall_HANDLER_cond_wait(simcall , (smx_cond_t) simcall->args[0].dp, (smx_mutex_t) simcall->args[1].dp);
414        break;  
415
416 case SIMCALL_COND_WAIT_TIMEOUT:
417        simcall_HANDLER_cond_wait_timeout(simcall , (smx_cond_t) simcall->args[0].dp, (smx_mutex_t) simcall->args[1].dp,  simcall->args[2].d);
418        break;  
419
420 case SIMCALL_COND_BROADCAST:
421        SIMIX_cond_broadcast((smx_cond_t) simcall->args[0].dp);
422       SIMIX_simcall_answer(simcall);
423       break;  
424
425 case SIMCALL_SEM_INIT:
426       simcall->result.dp = SIMIX_sem_init( simcall->args[0].ui);
427       SIMIX_simcall_answer(simcall);
428       break;  
429
430 case SIMCALL_SEM_DESTROY:
431        SIMIX_sem_destroy((smx_sem_t) simcall->args[0].dp);
432       SIMIX_simcall_answer(simcall);
433       break;  
434
435 case SIMCALL_SEM_RELEASE:
436        simcall_HANDLER_sem_release(simcall , (smx_sem_t) simcall->args[0].dp);
437       SIMIX_simcall_answer(simcall);
438       break;  
439
440 case SIMCALL_SEM_WOULD_BLOCK:
441       simcall->result.i = simcall_HANDLER_sem_would_block(simcall , (smx_sem_t) simcall->args[0].dp);
442       SIMIX_simcall_answer(simcall);
443       break;  
444
445 case SIMCALL_SEM_ACQUIRE:
446        simcall_HANDLER_sem_acquire(simcall , (smx_sem_t) simcall->args[0].dp);
447        break;  
448
449 case SIMCALL_SEM_ACQUIRE_TIMEOUT:
450        simcall_HANDLER_sem_acquire_timeout(simcall , (smx_sem_t) simcall->args[0].dp,  simcall->args[1].d);
451        break;  
452
453 case SIMCALL_SEM_GET_CAPACITY:
454       simcall->result.i = simcall_HANDLER_sem_get_capacity(simcall , (smx_sem_t) simcall->args[0].dp);
455       SIMIX_simcall_answer(simcall);
456       break;  
457
458 case SIMCALL_FILE_READ:
459        simcall_HANDLER_file_read(simcall , (smx_file_t) simcall->args[0].dp,  simcall->args[1].sgsz, (sg_host_t) simcall->args[2].dp);
460        break;  
461
462 case SIMCALL_FILE_WRITE:
463        simcall_HANDLER_file_write(simcall , (smx_file_t) simcall->args[0].dp,  simcall->args[1].sgsz, (sg_host_t) simcall->args[2].dp);
464        break;  
465
466 case SIMCALL_FILE_OPEN:
467        simcall_HANDLER_file_open(simcall ,  simcall->args[0].cc, (sg_host_t) simcall->args[1].dp);
468        break;  
469
470 case SIMCALL_FILE_CLOSE:
471        simcall_HANDLER_file_close(simcall , (smx_file_t) simcall->args[0].dp, (sg_host_t) simcall->args[1].dp);
472        break;  
473
474 case SIMCALL_FILE_UNLINK:
475       simcall->result.i = SIMIX_file_unlink((smx_file_t) simcall->args[0].dp,(sg_host_t) simcall->args[1].dp);
476       SIMIX_simcall_answer(simcall);
477       break;  
478
479 case SIMCALL_FILE_GET_SIZE:
480       simcall->result.sgsz = simcall_HANDLER_file_get_size(simcall , (smx_file_t) simcall->args[0].dp);
481       SIMIX_simcall_answer(simcall);
482       break;  
483
484 case SIMCALL_FILE_TELL:
485       simcall->result.sgsz = simcall_HANDLER_file_tell(simcall , (smx_file_t) simcall->args[0].dp);
486       SIMIX_simcall_answer(simcall);
487       break;  
488
489 case SIMCALL_FILE_SEEK:
490       simcall->result.i = simcall_HANDLER_file_seek(simcall , (smx_file_t) simcall->args[0].dp,  simcall->args[1].sgoff,  simcall->args[2].i);
491       SIMIX_simcall_answer(simcall);
492       break;  
493
494 case SIMCALL_FILE_GET_INFO:
495       simcall->result.dp = simcall_HANDLER_file_get_info(simcall , (smx_file_t) simcall->args[0].dp);
496       SIMIX_simcall_answer(simcall);
497       break;  
498
499 case SIMCALL_FILE_MOVE:
500       simcall->result.i = simcall_HANDLER_file_move(simcall , (smx_file_t) simcall->args[0].dp,  simcall->args[1].cc);
501       SIMIX_simcall_answer(simcall);
502       break;  
503
504 case SIMCALL_STORAGE_GET_FREE_SIZE:
505       simcall->result.sgsz = simcall_HANDLER_storage_get_free_size(simcall , (smx_storage_t) simcall->args[0].dp);
506       SIMIX_simcall_answer(simcall);
507       break;  
508
509 case SIMCALL_STORAGE_GET_USED_SIZE:
510       simcall->result.sgsz = simcall_HANDLER_storage_get_used_size(simcall , (smx_storage_t) simcall->args[0].dp);
511       SIMIX_simcall_answer(simcall);
512       break;  
513
514 case SIMCALL_STORAGE_GET_PROPERTIES:
515       simcall->result.dp = SIMIX_storage_get_properties((smx_storage_t) simcall->args[0].dp);
516       SIMIX_simcall_answer(simcall);
517       break;  
518
519 case SIMCALL_STORAGE_GET_CONTENT:
520       simcall->result.dp = SIMIX_storage_get_content((smx_storage_t) simcall->args[0].dp);
521       SIMIX_simcall_answer(simcall);
522       break;  
523
524 case SIMCALL_ASR_GET_PROPERTIES:
525       simcall->result.dp = simcall_HANDLER_asr_get_properties(simcall ,  simcall->args[0].cc);
526       SIMIX_simcall_answer(simcall);
527       break;  
528
529 case SIMCALL_MC_RANDOM:
530       simcall->result.i = simcall_HANDLER_mc_random(simcall ,  simcall->args[0].i,  simcall->args[1].i);
531       SIMIX_simcall_answer(simcall);
532       break;  
533
534 case SIMCALL_SET_CATEGORY:
535        SIMIX_set_category((smx_synchro_t) simcall->args[0].dp, simcall->args[1].cc);
536       SIMIX_simcall_answer(simcall);
537       break;  
538
539 case SIMCALL_RUN_KERNEL:
540        SIMIX_run_kernel( simcall->args[0].dp);
541       SIMIX_simcall_answer(simcall);
542       break;  
543
544 #ifdef HAVE_LATENCY_BOUND_TRACKING
545 case SIMCALL_COMM_IS_LATENCY_BOUNDED:
546       simcall->result.i = SIMIX_comm_is_latency_bounded((smx_synchro_t) simcall->args[0].dp);
547       SIMIX_simcall_answer(simcall);
548       break;  
549
550 #endif
551
552 #ifdef HAVE_MC
553 case SIMCALL_MC_SNAPSHOT:
554       simcall->result.dp = simcall_HANDLER_mc_snapshot(simcall );
555       SIMIX_simcall_answer(simcall);
556       break;  
557
558 case SIMCALL_MC_COMPARE_SNAPSHOTS:
559       simcall->result.i = simcall_HANDLER_mc_compare_snapshots(simcall , (mc_snapshot_t) simcall->args[0].dp, (mc_snapshot_t) simcall->args[1].dp);
560       SIMIX_simcall_answer(simcall);
561       break;  
562
563 #endif
564     case NUM_SIMCALLS:
565       break;
566     case SIMCALL_NONE:
567       THROWF(arg_error,0,"Asked to do the noop syscall on %s@%s",
568           SIMIX_process_get_name(simcall->issuer),
569           sg_host_get_name(SIMIX_process_get_host(simcall->issuer))
570           );
571       break;
572
573   }
574 }