+XBT_LOG_NEW_DEFAULT_SUBCATEGORY(simix_io, simix, "Logging specific to SIMIX (io)");
+
+void simcall_HANDLER_io_wait(smx_simcall_t simcall, simgrid::kernel::activity::IoImpl* synchro)
+{
+ XBT_DEBUG("Wait for execution of synchro %p, state %d", synchro, (int)synchro->state_);
+
+ /* Associate this simcall to the synchro */
+ synchro->register_simcall(simcall);
+
+ if (MC_is_active() || MC_record_replay_is_active())
+ synchro->state_ = simgrid::kernel::activity::State::DONE;
+
+ /* If the synchro is already finished then perform the error handling */
+ if (synchro->state_ != simgrid::kernel::activity::State::RUNNING)
+ synchro->finish();
+}
+