Logo AND Algorithmique Numérique Distribuée

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