X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/33145f3a1e718d721f062d152cda9a98d1aab5b8..095b4b57dba45599d3d4b4d8ac36230b2cbeb6c0:/src/simix/smx_user.c diff --git a/src/simix/smx_user.c b/src/simix/smx_user.c index 255907e1f3..e26d97fe81 100644 --- a/src/simix/smx_user.c +++ b/src/simix/smx_user.c @@ -1205,6 +1205,41 @@ size_t simcall_file_write(const void* ptr, size_t size, size_t nmemb, smx_file_t return simcall->file_write.result; } +smx_file_t* simcall_file_open(const char* path, const char* mode) +{ + smx_simcall_t simcall = SIMIX_simcall_mine(); + + simcall->call = SIMCALL_FILE_OPEN; + simcall->file_open.path = path; + simcall->file_open.mode = mode; + SIMIX_simcall_push(simcall->issuer); + + return simcall->file_open.result; +} + +int simcall_file_close(smx_file_t* fp) +{ + smx_simcall_t simcall = SIMIX_simcall_mine(); + + simcall->call = SIMCALL_FILE_CLOSE; + simcall->file_close.fp = fp; + SIMIX_simcall_push(simcall->issuer); + + return simcall->file_close.result; +} + +int simcall_file_stat(int fd, void* buf) +{ + smx_simcall_t simcall = SIMIX_simcall_mine(); + + simcall->call = SIMCALL_FILE_STAT; + simcall->file_stat.fd = fd; + simcall->file_stat.buf = buf; + SIMIX_simcall_push(simcall->issuer); + + return simcall->file_stat.result; +} + /* ************************************************************************** */ /** @brief returns a printable string representing a simcall */