Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
working version.
[simgrid.git] / src / s4u / s4u_Io.cpp
index 4dfbfa2..5f6303f 100644 (file)
@@ -6,6 +6,7 @@
 #include "simgrid/s4u/Io.hpp"
 #include "simgrid/s4u/Storage.hpp"
 #include "src/kernel/activity/IoImpl.hpp"
+#include "src/simix/smx_io_private.hpp"
 #include "xbt/log.h"
 
 XBT_LOG_NEW_DEFAULT_SUBCATEGORY(s4u_io, s4u_activity, "S4U asynchronous IOs");
@@ -15,7 +16,7 @@ namespace s4u {
 
 Activity* Io::start()
 {
-  pimpl_ = simcall_io_start("", size_, storage_);
+  pimpl_ = simix::simcall([this] { return SIMIX_io_start(name_, size_, storage_, type_); });
   state_ = State::STARTED;
   return this;
 }
@@ -29,7 +30,7 @@ Activity* Io::cancel()
 
 Activity* Io::wait()
 {
-  //  simcall_execution_wait(pimpl_);
+  simcall_io_wait(pimpl_);
   state_ = State::FINISHED;
   return this;
 }
@@ -39,51 +40,38 @@ Activity* Io::wait(double timeout)
   THROW_UNIMPLEMENTED;
   return this;
 }
-//
-///** @brief Returns whether the state of the exec is finished */
-// bool Exec::test()
-//{
-//  xbt_assert(state_ == State::INITED || state_ == State::STARTED || state_ == State::FINISHED);
-//
-//  if (state_ == State::FINISHED)
-//    return true;
-//
-//  if (state_ == State::INITED)
-//    this->start();
-//
-//  if (simcall_execution_test(pimpl_)) {
-//    state_ = State::FINISHED;
-//    return true;
-//  }
-//
-//  return false;
-//}
 
 /** @brief Returns the amount of flops that remain to be done */
 double Io::get_remaining()
 {
   return simgrid::simix::simcall(
-      [this]() { return boost::static_pointer_cast<simgrid::kernel::activity::IoImpl>(pimpl_)->get_remaining(); });
+      [this]() { return boost::static_pointer_cast<kernel::activity::IoImpl>(pimpl_)->get_remaining(); });
 }
 
-// double Io::get_remaining_ratio()
-//{
-//  return simgrid::simix::simcall([this]() {
-//    return boost::static_pointer_cast<simgrid::kernel::activity::IoImpl>(pimpl_)->get_remaining_ratio();
-//  });
-//}
+sg_size_t Io::get_performed_ioops()
+{
+  return simgrid::simix::simcall(
+      [this]() { return boost::static_pointer_cast<kernel::activity::IoImpl>(pimpl_)->get_performed_ioops(); });
+}
+
+IoPtr Io::set_io_type(OpType type)
+{
+  xbt_assert(state_ == State::INITED, "Cannot change the name of an exec after its start");
+  type_ = type;
+  return this;
+}
 
-void intrusive_ptr_release(simgrid::s4u::Io* e)
+void intrusive_ptr_release(simgrid::s4u::Io* i)
 {
-  if (e->refcount_.fetch_sub(1, std::memory_order_release) == 1) {
+  if (i->refcount_.fetch_sub(1, std::memory_order_release) == 1) {
     std::atomic_thread_fence(std::memory_order_acquire);
-    delete e;
+    delete i;
   }
 }
 
-void intrusive_ptr_add_ref(simgrid::s4u::Io* e)
+void intrusive_ptr_add_ref(simgrid::s4u::Io* i)
 {
-  e->refcount_.fetch_add(1, std::memory_order_relaxed);
+  i->refcount_.fetch_add(1, std::memory_order_relaxed);
 }
 } // namespace s4u
 } // namespace simgrid