Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
Merge branch 'master' of framagit.org:simgrid/simgrid
[simgrid.git] / examples / cpp / io-disk-raw / s4u-io-disk-raw.cpp
1 /* Copyright (c) 2017-2021. The SimGrid Team. All rights reserved.          */
2
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. */
5
6 #include "simgrid/s4u.hpp"
7 #include <string>
8 #include <unordered_map>
9
10 XBT_LOG_NEW_DEFAULT_CATEGORY(disk_test, "Messages specific for this simulation");
11
12 static void host()
13 {
14   /* -Add an extra disk in a programmatic way */
15   simgrid::s4u::Host::current()->create_disk()
16        ->set_name("Disk3")
17        ->set_read_bandwidth(9.6e7)
18        ->set_write_bandwidth(6.4e7)
19        ->seal();
20
21   /* - Display information on the disks mounted by the current host */
22   XBT_INFO("*** Storage info on %s ***", simgrid::s4u::Host::current()->get_cname());
23
24   /* - Retrieve all disks from current host */
25   std::vector<simgrid::s4u::Disk*> const& disk_list = simgrid::s4u::Host::current()->get_disks();
26
27   /* - For each disk mounted on host, display disk name and mount point */
28   for (auto const& disk : disk_list)
29     XBT_INFO("Disk name: %s (read: %.0f B/s -- write: %.0f B/s ", disk->get_cname(), disk->get_read_bandwidth(),
30              disk->get_write_bandwidth());
31
32   /* - Write 400,000 bytes on Disk1 */
33   simgrid::s4u::Disk* disk = disk_list.front();
34   sg_size_t write          = disk->write(400000);
35   XBT_INFO("Wrote %llu bytes on '%s'", write, disk->get_cname());
36
37   /*  - Now read 200,000 bytes */
38   sg_size_t read = disk->read(200000);
39   XBT_INFO("Read %llu bytes on '%s'", read, disk->get_cname());
40
41   /* - Write 800,000 bytes on Disk3 */
42   simgrid::s4u::Disk* disk3 = disk_list.back();
43   sg_size_t write_on_disk3  = disk3->write(800000);
44   XBT_INFO("Wrote %llu bytes on '%s'", write_on_disk3, disk3->get_cname());
45
46   /* - Attach some user data to disk1 */
47   XBT_INFO("*** Get/set data for storage element: Disk1 ***");
48
49   const auto* data = static_cast<std::string*>(disk->get_data());
50
51   XBT_INFO("Get storage data: '%s'", data ? data->c_str() : "No user data");
52
53   disk->set_data(new std::string("Some user data"));
54   data = static_cast<std::string*>(disk->get_data());
55   XBT_INFO("Set and get data: '%s'", data->c_str());
56   delete data;
57 }
58
59 int main(int argc, char** argv)
60 {
61   simgrid::s4u::Engine e(&argc, argv);
62   e.load_platform(argv[1]);
63
64   /* - Display Host properties */
65   for (auto h : e.get_all_hosts()) {
66     XBT_INFO("*** %s properties ****", h->get_cname());
67     for (auto const& kv : *h->get_properties())
68       XBT_INFO("  %s -> %s", kv.first.c_str(), kv.second.c_str());
69   }
70
71
72   simgrid::s4u::Actor::create("", simgrid::s4u::Host::by_name("bob"), host);
73
74   e.run();
75   XBT_INFO("Simulated time: %g", simgrid::s4u::Engine::get_clock());
76
77   return 0;
78 }