Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
Merge branches 'auto_restart' and 'auto_restart' of framagit.org:simgrid/simgrid
[simgrid.git] / include / simgrid / s4u / Io.hpp
1 /* Copyright (c) 2017-2018. 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 #ifndef SIMGRID_S4U_IO_HPP
7 #define SIMGRID_S4U_IO_HPP
8
9 #include <simgrid/forward.h>
10 #include <simgrid/s4u/Activity.hpp>
11
12 #include <atomic>
13 #include <string>
14
15 namespace simgrid {
16 namespace s4u {
17
18 /** I/O Activity, representing the asynchronous disk access.
19  *
20  * They are generated from simgrid::s4u::Storage::read() and simgrid::s4u::Storage::write().
21  */
22
23 class XBT_PUBLIC Io : public Activity {
24 public:
25   enum class OpType { READ, WRITE };
26
27 private:
28   explicit Io(sg_size_t size, OpType type) : Activity(), size_(size), type_(type) {}
29 public:
30   friend XBT_PUBLIC void intrusive_ptr_release(simgrid::s4u::Io* i);
31   friend XBT_PUBLIC void intrusive_ptr_add_ref(simgrid::s4u::Io* i);
32   friend Storage; // Factory of IOs
33
34   ~Io() = default;
35
36   Activity* start() override;
37   Activity* wait() override;
38   Activity* wait(double timeout) override;
39   Activity* cancel() override;
40
41   double get_remaining() override;
42   sg_size_t get_performed_ioops();
43
44 private:
45   sg_size_t size_       = 0;
46   sg_storage_t storage_ = nullptr;
47   std::string name_     = "";
48   OpType type_          = OpType::READ;
49   std::atomic_int_fast32_t refcount_{0};
50 }; // class
51 }
52 }; // Namespace simgrid::s4u
53
54 #endif /* SIMGRID_S4U_IO_HPP */