X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/c5ad8ca1a68bbaa9152471c8d0eeb99d762f0d86..1128245fc5ccac68ce1f696aab780e15ff9f735a:/src/simix/smx_user.c diff --git a/src/simix/smx_user.c b/src/simix/smx_user.c index 6c8825e0a1..8c08f25690 100644 --- a/src/simix/smx_user.c +++ b/src/simix/smx_user.c @@ -17,6 +17,7 @@ #include "smx_private.h" #include "mc/mc.h" +#include "xbt/ex.h" XBT_LOG_EXTERNAL_DEFAULT_CATEGORY(simix); @@ -1177,13 +1178,73 @@ int simcall_sem_get_capacity(smx_sem_t sem) return simcall->sem_get_capacity.result; } -void simcall_file_read(char* name) +size_t simcall_file_read(const char* storage, void* ptr, size_t size, size_t nmemb, smx_file_t stream) { smx_simcall_t simcall = SIMIX_simcall_mine(); simcall->call = SIMCALL_FILE_READ; - simcall->file_read.name = name; + simcall->file_read.storage = storage; + simcall->file_read.ptr = ptr; + simcall->file_read.size = size; + simcall->file_read.nmemb = nmemb; + simcall->file_read.stream = stream; SIMIX_simcall_push(simcall->issuer); + + return simcall->file_read.result; +} + +size_t simcall_file_write(const char* storage, const void* ptr, size_t size, size_t nmemb, smx_file_t stream) +{ + smx_simcall_t simcall = SIMIX_simcall_mine(); + + simcall->call = SIMCALL_FILE_WRITE; + simcall->file_write.storage = storage; + simcall->file_write.ptr = ptr; + simcall->file_write.size = size; + simcall->file_write.nmemb = nmemb; + simcall->file_write.stream = stream; + SIMIX_simcall_push(simcall->issuer); + + return simcall->file_write.result; +} + +smx_file_t simcall_file_open(const char* storage, const char* path, const char* mode) +{ + smx_simcall_t simcall = SIMIX_simcall_mine(); + + simcall->call = SIMCALL_FILE_OPEN; + simcall->file_open.storage = storage; + simcall->file_open.path = path; + simcall->file_open.mode = mode; + SIMIX_simcall_push(simcall->issuer); + + return simcall->file_open.result; +} + +int simcall_file_close(const char* storage, smx_file_t fp) +{ + smx_simcall_t simcall = SIMIX_simcall_mine(); + + simcall->call = SIMCALL_FILE_CLOSE; + simcall->file_close.storage = storage; + simcall->file_close.fp = fp; + SIMIX_simcall_push(simcall->issuer); + + return simcall->file_close.result; +} + +int simcall_file_stat(const char* storage, smx_file_t fd, s_file_stat_t *buf) +{ + smx_simcall_t simcall = SIMIX_simcall_mine(); + simcall->call = SIMCALL_FILE_STAT; + simcall->file_stat.storage = storage; + simcall->file_stat.fd = fd; + + SIMIX_simcall_push(simcall->issuer); + + *buf = simcall->file_stat.buf; + + return simcall->file_stat.result; } /* ************************************************************************** */