simgrid::simix::simcall([this, key, value] { this->pimpl_->set_property(key, value); });
}
-IoPtr Storage::io_init(sg_size_t size)
+IoPtr Storage::io_init(sg_size_t size, Io::OpType type)
{
- IoPtr res = IoPtr(new Io(size));
+ IoPtr res = IoPtr(new Io(size, type));
res->storage_ = this;
return res;
}
+IoPtr Storage::read_async(sg_size_t size)
+{
+
+ IoPtr res = io_init(size, Io::OpType::READ);
+ res->start();
+ return res;
+}
+
sg_size_t Storage::read(sg_size_t size)
{
- IoPtr i = io_init(size);
- i->set_io_type(Io::OpType::READ);
+ IoPtr i = io_init(size, Io::OpType::READ);
i->start()->wait();
return i->get_performed_ioops();
}
-sg_size_t Storage::write(sg_size_t size)
+IoPtr Storage::write_async(sg_size_t size)
{
- IoPtr i = io_init(size);
- i->set_io_type(Io::OpType::WRITE);
- i->start()->wait();
- return i->get_performed_ioops();
+
+ IoPtr res = io_init(size, Io::OpType::WRITE);
+ res->start();
+ return res;
}
-// Deprecated functions
-void getStorageList(std::map<std::string, Storage*>* whereTo)
+sg_size_t Storage::write(sg_size_t size)
{
- for (auto const& s : simgrid::s4u::Engine::get_instance()->get_all_storages())
- whereTo->insert({s->get_name(), s});
+ IoPtr i = io_init(size, Io::OpType::WRITE);
+ i->start()->wait();
+ return i->get_performed_ioops();
}
} /* namespace s4u */