1 /* Copyright (c) 2006-2016. The SimGrid Team. All rights reserved. */
3 /* This program is free software; you can redistribute it and/or modify it
4 * under the terms of the license (GNU LGPL) which comes with this package. */
6 #include "simgrid/msg.h"
8 XBT_LOG_NEW_DEFAULT_CATEGORY(storage,"Messages specific for this simulation");
10 static int host(int argc, char *argv[]){
11 const char* host_name = MSG_host_get_name(MSG_host_self());
13 /* - Display information on the disks mounted by the current host */
14 XBT_INFO("*** Storage info on %s ***", host_name);
16 xbt_dict_cursor_t cursor = NULL;
20 /* - Retrieve all mount points of current host */
21 xbt_dict_t storage_list = MSG_host_get_mounted_storage_list(MSG_host_self());
23 /* - For each disk mounted on host, display disk name and mount point */
24 xbt_dict_foreach (storage_list, cursor, mount_name, storage_name)
25 XBT_INFO("Storage name: %s, mount name: %s", storage_name, mount_name);
27 xbt_dict_free(&storage_list);
29 /* - Write 200,000 bytes on Disk4 */
30 msg_storage_t storage = MSG_storage_get_by_name("Disk4");
31 sg_size_t write = MSG_storage_write(storage, 200000); // Write 200,000 bytes
32 XBT_INFO("Wrote %llu bytes on 'Disk4'", write);
34 /* - Now read 200,000 bytes */
35 sg_size_t read = MSG_storage_read(storage, 200000);
36 XBT_INFO("Read %llu bytes on 'Disk4'", read);
38 /* - Attach some user data to disk1 */
39 XBT_INFO("*** Get/set data for storage element: Disk4 ***");
41 char* data = MSG_storage_get_data(storage);
43 XBT_INFO("Get storage data: '%s'", data);
45 MSG_storage_set_data(storage, xbt_strdup("Some user data"));
46 data = MSG_storage_get_data(storage);
47 XBT_INFO("Set and get data: '%s'", data);
53 int main(int argc, char *argv[])
55 MSG_init(&argc, argv);
57 MSG_create_environment(argv[1]);
58 MSG_function_register("host", host);
59 xbt_dynar_t hosts = MSG_hosts_as_dynar();
60 MSG_process_create(NULL, host, NULL, xbt_dynar_get_as(hosts, 3, msg_host_t));
61 xbt_dynar_free(&hosts);
63 msg_error_t res = MSG_main();
64 XBT_INFO("Simulated time: %g", MSG_get_clock());