+ std::vector<kernel::activity::IoImpl*> rios(ios.size());
+ std::transform(begin(ios), end(ios), begin(rios),
+ [](const IoPtr& io) { return static_cast<kernel::activity::IoImpl*>(io->pimpl_.get()); });
+
+ kernel::actor::ActorImpl* issuer = kernel::actor::ActorImpl::self();
+ kernel::actor::IoWaitanySimcall observer{issuer, rios, timeout};
+ ssize_t changed_pos = kernel::actor::simcall_blocking(
+ [&observer] {
+ kernel::activity::IoImpl::wait_any_for(observer.get_issuer(), observer.get_ios(), observer.get_timeout());
+ },
+ &observer);
+ if (changed_pos != -1)
+ ios.at(changed_pos)->complete(State::FINISHED);
+ return changed_pos;
+}
+
+IoPtr Io::set_disk(const_sg_disk_t disk)
+{
+ xbt_assert(state_ == State::INITED || state_ == State::STARTING, "Cannot set disk once the Io is started");
+
+ kernel::actor::simcall(
+ [this, disk] { boost::static_pointer_cast<kernel::activity::IoImpl>(pimpl_)->set_disk(disk->get_impl()); });
+
+ // Setting the disk may allow to start the activity, let's try
+ if (state_ == State::STARTING)
+ vetoable_start();
+
+ return this;