X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/b8df87e176f27b25534f27d7e240defa32ca35bc..778ef0bf09f58678e4cd2bad3e57cdfeb716dd45:/src/kernel/activity/IoImpl.hpp diff --git a/src/kernel/activity/IoImpl.hpp b/src/kernel/activity/IoImpl.hpp index 456b325189..a4288e0743 100644 --- a/src/kernel/activity/IoImpl.hpp +++ b/src/kernel/activity/IoImpl.hpp @@ -8,6 +8,7 @@ #include "src/kernel/activity/ActivityImpl.hpp" #include "surf/surf.hpp" +#include namespace simgrid { namespace kernel { @@ -16,19 +17,18 @@ namespace activity { class XBT_PUBLIC IoImpl : public ActivityImpl { public: ~IoImpl() override; - explicit IoImpl(std::string name, resource::Action* surf_action, s4u::Storage* storage); + explicit IoImpl(std::string name, surf::StorageImpl* storage); - void suspend() override; - void resume() override; + IoImpl* start(sg_size_t size, simgrid::s4u::Io::OpType type); void post() override; + void finish() override; void cancel(); double get_remaining(); sg_size_t get_performed_ioops() { return performed_ioops_; } - s4u::Storage* storage_ = nullptr; - simgrid::kernel::resource::Action* surf_action_ = nullptr; + surf::StorageImpl* storage_ = nullptr; sg_size_t performed_ioops_ = 0; - static simgrid::xbt::signal on_creation; + static simgrid::xbt::signal on_start; static simgrid::xbt::signal on_completion; }; }