Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
Merge branch 'master' into CRTP
[simgrid.git] / examples / s4u / io-disk-raw / s4u-io-disk-raw.cpp
1 /* Copyright (c) 2017-2019. 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, "Messages specific for this simulation");
11
12 static void host()
13 {
14   /* - Display information on the disks mounted by the current host */
15   XBT_INFO("*** Storage info on %s ***", simgrid::s4u::Host::current()->get_cname());
16
17   /* - Retrieve all disks from current host */
18   std::vector<simgrid::s4u::Disk*> const& disk_list = simgrid::s4u::Host::current()->get_disks();
19
20   /* - For each disk mounted on host, display disk name and mount point */
21   for (auto disk : disk_list)
22     XBT_INFO("Disk name: %s", disk->get_cname());
23
24   /* - Write 400,000 bytes on Disk1 */
25   simgrid::s4u::Disk* disk = disk_list.front();
26   sg_size_t write          = disk->write(400000);
27   XBT_INFO("Wrote %llu bytes on '%s'", write, disk->get_cname());
28
29   /*  - Now read 200,000 bytes */
30   sg_size_t read = disk->read(200000);
31   XBT_INFO("Read %llu bytes on '%s'", read, disk->get_cname());
32
33   /* - Attach some user data to disk1 */
34   XBT_INFO("*** Get/set data for storage element: Disk1 ***");
35
36   std::string* data = static_cast<std::string*>(disk->get_data());
37
38   XBT_INFO("Get storage data: '%s'", data ? data->c_str() : "No user data");
39
40   disk->set_data(new std::string("Some user data"));
41   data = static_cast<std::string*>(disk->get_data());
42   XBT_INFO("Set and get data: '%s'", data->c_str());
43   delete data;
44 }
45
46 int main(int argc, char** argv)
47 {
48   simgrid::s4u::Engine e(&argc, argv);
49   e.load_platform(argv[1]);
50
51   simgrid::s4u::Actor::create("", simgrid::s4u::Host::by_name("bob"), host);
52
53   e.run();
54   XBT_INFO("Simulated time: %g", simgrid::s4u::Engine::get_clock());
55
56   return 0;
57 }