X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/121e8462d6b912a252a9016683d2e3e021cde9a0..1d381feb9b44e9d94e608c9b389c453128d44dff:/src/kernel/activity/IoImpl.hpp diff --git a/src/kernel/activity/IoImpl.hpp b/src/kernel/activity/IoImpl.hpp index a4288e0743..8d8f04c8c6 100644 --- a/src/kernel/activity/IoImpl.hpp +++ b/src/kernel/activity/IoImpl.hpp @@ -14,25 +14,30 @@ namespace simgrid { namespace kernel { namespace activity { -class XBT_PUBLIC IoImpl : public ActivityImpl { +class XBT_PUBLIC IoImpl : public ActivityImpl_T { + resource::StorageImpl* storage_ = nullptr; + resource::DiskImpl* disk_ = nullptr; + sg_size_t size_ = 0; + s4u::Io::OpType type_ = s4u::Io::OpType::READ; + sg_size_t performed_ioops_ = 0; + public: - ~IoImpl() override; - explicit IoImpl(std::string name, surf::StorageImpl* storage); + IoImpl& set_size(sg_size_t size); + IoImpl& set_type(s4u::Io::OpType type); + IoImpl& set_storage(resource::StorageImpl* storage); + IoImpl& set_disk(resource::DiskImpl* disk); + + sg_size_t get_performed_ioops() { return performed_ioops_; } - IoImpl* start(sg_size_t size, simgrid::s4u::Io::OpType type); + IoImpl* start(); void post() override; void finish() override; - void cancel(); - double get_remaining(); - sg_size_t get_performed_ioops() { return performed_ioops_; } - surf::StorageImpl* storage_ = nullptr; - sg_size_t performed_ioops_ = 0; - static simgrid::xbt::signal on_start; - static simgrid::xbt::signal on_completion; + static xbt::signal on_start; + static xbt::signal on_completion; }; -} -} -} // namespace simgrid::kernel::activity +} // namespace activity +} // namespace kernel +} // namespace simgrid #endif