+void suspend()
+{
+ if (TRACE_actor_is_enabled())
+ instr::Container::byName(getName() + "-" + std::to_string(getPid()))
+ ->getState("MSG_PROCESS_STATE")
+ ->pushEvent("suspend");
+ simcall_process_suspend(SIMIX_process_self());
+}
+
+void resume()
+{
+ smx_actor_t process = SIMIX_process_self();
+ simgrid::simix::kernelImmediate([process] { process->resume(); });
+
+ if (TRACE_actor_is_enabled())
+ instr::Container::byName(getName() + "-" + std::to_string(getPid()))->getState("MSG_PROCESS_STATE")->popEvent();
+}
+
+bool isSuspended()
+{
+ smx_actor_t process = SIMIX_process_self();
+ return simgrid::simix::kernelImmediate([process] { return process->suspended; });
+}
+
+void kill()
+{
+ smx_actor_t process = SIMIX_process_self();
+ simgrid::simix::kernelImmediate([process] { SIMIX_process_kill(process, process); });
+}
+
+void onExit(int_f_pvoid_pvoid_t fun, void* data)
+{
+ simcall_process_on_exit(SIMIX_process_self(), fun, data);
+}
+
+/** @brief Moves the current actor to another host
+ *
+ * @see simgrid::s4u::Actor::migrate() for more information
+ */