X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/411e3479d19b1ccbd3ea92787646394a356e47e3..d2548eab32dea3d8939f0d71332c3e8ee2748445:/src/simix/smx_io_private.h diff --git a/src/simix/smx_io_private.h b/src/simix/smx_io_private.h index c457a02999..7914bc8d1f 100644 --- a/src/simix/smx_io_private.h +++ b/src/simix/smx_io_private.h @@ -10,20 +10,58 @@ #include "simgrid/simix.h" #include "smx_smurf_private.h" -void SIMIX_pre_file_read(smx_simcall_t simcall); -void SIMIX_pre_file_write(smx_simcall_t simcall); -void SIMIX_pre_file_open(smx_simcall_t simcall); -void SIMIX_pre_file_close(smx_simcall_t simcall); -void SIMIX_pre_file_stat(smx_simcall_t simcall); - -smx_action_t SIMIX_file_read(smx_process_t process, void* ptr, size_t size, size_t nmemb, smx_file_t stream); -smx_action_t SIMIX_file_write(smx_process_t process, const void* ptr, size_t size, size_t nmemb, smx_file_t stream); -smx_action_t SIMIX_file_open(smx_process_t process, const char* storage, const char* path, const char* mode); -smx_action_t SIMIX_file_close(smx_process_t process, smx_file_t fp); -smx_action_t SIMIX_file_stat(smx_process_t process, smx_file_t fd, s_file_stat_t buf); +static inline smx_storage_priv_t SIMIX_storage_priv(smx_storage_t storage){ + return xbt_lib_get_level(storage, SIMIX_STORAGE_LEVEL); +} + +smx_storage_t SIMIX_storage_create(const char *name, void *storage, void *data); +void* SIMIX_pre_file_get_data(smx_simcall_t simcall,smx_file_t fd); +void SIMIX_pre_file_set_data(smx_simcall_t simcall, smx_file_t fd, void *data); +void SIMIX_pre_file_read(smx_simcall_t simcall, size_t size, smx_file_t fd); +void SIMIX_pre_file_write(smx_simcall_t simcall, size_t size, smx_file_t fd); +void SIMIX_pre_file_open(smx_simcall_t simcall, const char* mount, + const char* path); +void SIMIX_pre_file_close(smx_simcall_t simcall, smx_file_t fd); +int SIMIX_pre_file_unlink(smx_simcall_t simcall, smx_file_t fd); +void SIMIX_pre_file_ls(smx_simcall_t simcall, + const char* mount, const char* path); +size_t SIMIX_pre_file_get_size(smx_simcall_t simcall, smx_file_t fd); +xbt_dynar_t SIMIX_pre_file_get_info(smx_simcall_t simcall, smx_file_t fd); + +void* SIMIX_file_get_data(smx_file_t fd); +void SIMIX_file_set_data(smx_file_t fd, void *data); +smx_action_t SIMIX_file_read(smx_process_t process, size_t size, + smx_file_t fd); +smx_action_t SIMIX_file_write(smx_process_t process, size_t size, + smx_file_t fd); +smx_action_t SIMIX_file_open(smx_process_t process, const char* storage, + const char* path); +smx_action_t SIMIX_file_close(smx_process_t process, smx_file_t fd); +int SIMIX_file_unlink(smx_process_t process, smx_file_t fd); +smx_action_t SIMIX_file_ls(smx_process_t process, const char *mount, + const char *path); +size_t SIMIX_file_get_size(smx_process_t process, smx_file_t fd); +xbt_dynar_t SIMIX_file_get_info(smx_process_t process, smx_file_t fd); + +size_t SIMIX_pre_storage_get_free_size(smx_simcall_t simcall,const char* name); +size_t SIMIX_storage_get_free_size(smx_process_t process,const char* name); + +size_t SIMIX_pre_storage_get_used_size(smx_simcall_t simcall,const char* name); +size_t SIMIX_storage_get_used_size(smx_process_t process,const char* name); + +xbt_dict_t SIMIX_storage_get_properties(smx_storage_t storage); +xbt_dict_t SIMIX_pre_storage_get_properties(smx_simcall_t, smx_storage_t); + +void SIMIX_pre_storage_set_data(smx_simcall_t, smx_storage_t, void*); +void* SIMIX_pre_storage_get_data(smx_simcall_t, smx_storage_t); + +xbt_dict_t SIMIX_pre_storage_get_content(smx_simcall_t simcall, smx_storage_t storage); +xbt_dict_t SIMIX_storage_get_content(smx_storage_t storage); void SIMIX_post_io(smx_action_t action); void SIMIX_io_destroy(smx_action_t action); void SIMIX_io_finish(smx_action_t action); +// pre prototypes + #endif