]> AND Public Git Repository - simgrid.git/blobdiff - src/kernel/activity/SleepImpl.cpp
Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
Use 'auto' with functions returning iterators [sonar].
[simgrid.git] / src / kernel / activity / SleepImpl.cpp
index 2630930f22b86403f95bf5e0f5bec3a9d580b02b..cec6de2d262a2e00bbaf53f22842c89926b35bfe 100644 (file)
@@ -3,15 +3,12 @@
 /* This program is free software; you can redistribute it and/or modify it
  * under the terms of the license (GNU LGPL) which comes with this package. */
 
+#include <simgrid/s4u/Host.hpp>
+
 #include "src/kernel/activity/SleepImpl.hpp"
-#include "simgrid/Exception.hpp"
-#include "simgrid/kernel/resource/Action.hpp"
-#include "simgrid/s4u/Host.hpp"
-#include "src/kernel/context/Context.hpp"
+#include "src/kernel/actor/ActorImpl.hpp"
 #include "src/simix/popping_private.hpp"
-#include "src/simix/smx_private.hpp"
 #include "src/surf/cpu_interface.hpp"
-#include "src/surf/surf_interface.hpp"
 
 XBT_LOG_EXTERNAL_DEFAULT_CATEGORY(simix_process);
 namespace simgrid {
@@ -32,7 +29,7 @@ SleepImpl& SleepImpl::set_duration(double duration)
 
 SleepImpl* SleepImpl::start()
 {
-  surf_action_ = host_->pimpl_cpu->sleep(duration_);
+  surf_action_ = host_->get_cpu()->sleep(duration_);
   surf_action_->set_activity(this);
   XBT_DEBUG("Create sleep synchronization %p", this);
   return this;
@@ -56,13 +53,14 @@ void SleepImpl::post()
 
 void SleepImpl::finish()
 {
+  XBT_DEBUG("SleepImpl::finish() in state %s", to_c_str(state_));
   while (not simcalls_.empty()) {
     const s_smx_simcall* simcall = simcalls_.front();
     simcalls_.pop_front();
 
     simcall->issuer_->waiting_synchro_ = nullptr;
     if (simcall->issuer_->is_suspended()) {
-      XBT_DEBUG("Wait! This process is suspended and can't wake up now.");
+      XBT_DEBUG("Wait! This actor is suspended and can't wake up now.");
       simcall->issuer_->suspended_ = false;
       simcall->issuer_->suspend();
     } else {