X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/cf108868b4eeed4d0d9d343bc68557d7814e18c0..05a81a473f36ee2298730ccc85d4033affad4018:/teshsuite/msg/storage/concurrent_rw.c diff --git a/teshsuite/msg/storage/concurrent_rw.c b/teshsuite/msg/storage/concurrent_rw.c index 0e8c60ab39..df57ce86ec 100644 --- a/teshsuite/msg/storage/concurrent_rw.c +++ b/teshsuite/msg/storage/concurrent_rw.c @@ -5,53 +5,13 @@ * under the terms of the license (GNU LGPL) which comes with this package. */ #include "simgrid/msg.h" -#include "xbt/log.h" #include - #define FILENAME1 "/sd1/doc/simgrid/examples/cxx/autoDestination/Main.cxx" -int host(int argc, char *argv[]); -void storage_info(msg_host_t host); -void display_storage_properties(msg_storage_t storage); -void dump_storage_by_name(char *name); -void display_storage_content(msg_storage_t storage); - XBT_LOG_NEW_DEFAULT_CATEGORY(storage,"Messages specific for this simulation"); - - -void storage_info(msg_host_t host) -{ - const char* host_name = MSG_host_get_name(host); - XBT_INFO("*** Storage info on %s ***", host_name); - - xbt_dict_cursor_t cursor = NULL; - char* mount_name; - char* storage_name; - msg_storage_t storage; - - xbt_dict_t storage_list = MSG_host_get_mounted_storage_list(host); - - xbt_dict_foreach(storage_list,cursor,mount_name,storage_name) - { - XBT_INFO("\tStorage name: %s, mount name: %s", storage_name, mount_name); - - storage = MSG_storage_get_by_name(storage_name); - - sg_size_t free_size = MSG_storage_get_free_size(storage); - sg_size_t used_size = MSG_storage_get_used_size(storage); - - XBT_INFO("\t\tFree size: %llu bytes", free_size); - XBT_INFO("\t\tUsed size: %llu bytes", used_size); - - display_storage_properties(storage); - dump_storage_by_name(storage_name); - } - xbt_dict_free(&storage_list); -} - -void display_storage_properties(msg_storage_t storage){ +static void display_storage_properties(msg_storage_t storage){ xbt_dict_cursor_t cursor = NULL; char *key, *data; xbt_dict_t props = MSG_storage_get_properties(storage); @@ -59,24 +19,12 @@ void display_storage_properties(msg_storage_t storage){ XBT_INFO("\tProperties of mounted storage: %s", MSG_storage_get_name(storage)); xbt_dict_foreach(props, cursor, key, data) XBT_INFO("\t\t'%s' -> '%s'", key, data); - }else{ + } else { XBT_INFO("\tNo property attached."); } } -void dump_storage_by_name(char *name){ - XBT_INFO("*** Dump a storage element ***"); - msg_storage_t storage = MSG_storage_get_by_name(name); - - if(storage){ - display_storage_content(storage); - } - else{ - XBT_INFO("Unable to retrieve storage element by its name: %s.", name); - } -} - -void display_storage_content(msg_storage_t storage){ +static void display_storage_content(msg_storage_t storage){ XBT_INFO("Print the content of the storage element: %s",MSG_storage_get_name(storage)); xbt_dict_cursor_t cursor = NULL; char *file; @@ -91,11 +39,45 @@ void display_storage_content(msg_storage_t storage){ xbt_dict_free(&content); } +static void dump_storage_by_name(char *name){ + XBT_INFO("*** Dump a storage element ***"); + msg_storage_t storage = MSG_storage_get_by_name(name); + + if(storage){ + display_storage_content(storage); + } else{ + XBT_INFO("Unable to retrieve storage element by its name: %s.", name); + } +} +static void storage_info(msg_host_t host) +{ + const char* host_name = MSG_host_get_name(host); + XBT_INFO("*** Storage info on %s ***", host_name); + + xbt_dict_cursor_t cursor = NULL; + char* mount_name; + char* storage_name; + msg_storage_t storage; + + xbt_dict_t storage_list = MSG_host_get_mounted_storage_list(host); + xbt_dict_foreach(storage_list,cursor,mount_name,storage_name){ + XBT_INFO("\tStorage name: %s, mount name: %s", storage_name, mount_name); + storage = MSG_storage_get_by_name(storage_name); + sg_size_t free_size = MSG_storage_get_free_size(storage); + sg_size_t used_size = MSG_storage_get_used_size(storage); + XBT_INFO("\t\tFree size: %llu bytes", free_size); + XBT_INFO("\t\tUsed size: %llu bytes", used_size); -int host(int argc, char *argv[]) + display_storage_properties(storage); + dump_storage_by_name(storage_name); + } + xbt_dict_free(&storage_list); +} + +static int host(int argc, char *argv[]) { char name[2048]; sprintf(name,"%s%i", FILENAME1,MSG_process_self_PID()); @@ -109,24 +91,18 @@ int host(int argc, char *argv[]) return 1; } - int main(int argc, char **argv) { - - int res, i; MSG_init(&argc, argv); MSG_create_environment(argv[1]); MSG_function_register("host", host); storage_info(MSG_host_by_name(xbt_strdup("host"))); - for(i = 0 ; i<10; i++){ + for(int i = 0 ; i<10; i++){ MSG_process_create(xbt_strdup("host"), host, NULL, MSG_host_by_name(xbt_strdup("host"))); } - - - - res = MSG_main(); + int res = MSG_main(); storage_info(MSG_host_by_name(xbt_strdup("host"))); XBT_INFO("Simulation time %g", MSG_get_clock());