X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/6d0a1577e793ff234e7f12de5f13572685538d10..6bc18b576fa4a890d8b9916d292ca67dfbf60dd3:/include/simgrid/s4u/Io.hpp diff --git a/include/simgrid/s4u/Io.hpp b/include/simgrid/s4u/Io.hpp index ea92b923ff..72b5ea2296 100644 --- a/include/simgrid/s4u/Io.hpp +++ b/include/simgrid/s4u/Io.hpp @@ -10,18 +10,27 @@ #include #include +#include namespace simgrid { namespace s4u { +/** I/O Activity, representing the asynchronous disk access. + * + * They are generated from simgrid::s4u::Storage::read() and simgrid::s4u::Storage::write(). + */ + class XBT_PUBLIC Io : public Activity { - Io() : Activity() {} +public: + enum class OpType { READ, WRITE }; + +private: + explicit Io(sg_size_t size, OpType type) : Activity(), size_(size), type_(type) {} public: friend XBT_PUBLIC void intrusive_ptr_release(simgrid::s4u::Io* i); friend XBT_PUBLIC void intrusive_ptr_add_ref(simgrid::s4u::Io* i); friend Storage; // Factory of IOs - enum class OpType { READ, WRITE }; ~Io() = default; Activity* start() override; @@ -31,7 +40,6 @@ public: double get_remaining() override; sg_size_t get_performed_ioops(); - IoPtr set_io_type(OpType type); private: sg_size_t size_ = 0;