X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/cdf6a962eb4e88efbed3df9c41343adabcf09e6c..1a4f00ba0c403c20a7eae8bea566371a4f131b3e:/src/simix/smx_private.hpp diff --git a/src/simix/smx_private.hpp b/src/simix/smx_private.hpp index 26893347ab..c1cb4fce30 100644 --- a/src/simix/smx_private.hpp +++ b/src/simix/smx_private.hpp @@ -21,8 +21,6 @@ namespace simgrid { namespace simix { class Global { - friend XBT_PUBLIC bool simgrid::s4u::this_actor::is_maestro(); - public: bool execute_tasks(); /** @@ -32,11 +30,12 @@ public: */ void empty_trash(); void run_all_actors(); + void wake_all_waiting_actors(); smx_context_factory_t context_factory = nullptr; - std::vector actors_to_run; - std::vector actors_that_ran; - std::map process_list; + std::vector actors_to_run; + std::vector actors_that_ran; + std::map process_list; boost::intrusive::list, &kernel::actor::ActorImpl::smx_destroy_list_hook>> @@ -50,23 +49,23 @@ public: * That way, the MCer would not need to have the list of actors on its side. * These info could be published by the MCed to the MCer in a way inspired of vd.so */ - xbt_dynar_t actors_vector = xbt_dynar_new(sizeof(smx_actor_t), nullptr); - xbt_dynar_t dead_actors_vector = xbt_dynar_new(sizeof(smx_actor_t), nullptr); + xbt_dynar_t actors_vector = xbt_dynar_new(sizeof(kernel::actor::ActorImpl*), nullptr); + xbt_dynar_t dead_actors_vector = xbt_dynar_new(sizeof(kernel::actor::ActorImpl*), nullptr); #endif - smx_actor_t maestro_process = nullptr; + kernel::actor::ActorImpl* maestro_process = nullptr; // Maps function names to actor code: - std::unordered_map registered_functions; + std::unordered_map registered_functions; // This might be used when no corresponding function name is registered: - simgrid::simix::ActorCodeFactory default_function; + simix::ActorCodeFactory default_function; std::mutex mutex; - std::vector> tasks; - std::vector> tasksTemp; + std::vector> tasks; + std::vector> tasksTemp; - std::vector daemons; + std::vector daemons; }; } }