Logo AND Algorithmique Numérique Distribuée

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