X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/b9945098e2ba4e7b639e0c2245835d44800c1b29..d0d1912b2262e2aaf06b39115de5f846e2a86efe:/src/simix/smx_private.hpp diff --git a/src/simix/smx_private.hpp b/src/simix/smx_private.hpp index d6a15bb23b..ddf9816859 100644 --- a/src/simix/smx_private.hpp +++ b/src/simix/smx_private.hpp @@ -1,4 +1,4 @@ -/* Copyright (c) 2007-2019. The SimGrid Team. All rights reserved. */ +/* Copyright (c) 2007-2021. The SimGrid Team. All rights reserved. */ /* 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. */ @@ -21,8 +21,6 @@ namespace simgrid { namespace simix { class Global { - friend XBT_PUBLIC bool simgrid::s4u::this_actor::is_maestro(); - public: /** * Garbage collection @@ -30,12 +28,10 @@ public: * Should be called some time to time to free the memory allocated for actors that have finished (or killed). */ void empty_trash(); - void run_all_actors(); + void display_all_actor_status() const; - smx_context_factory_t context_factory = nullptr; - std::vector actors_to_run; - std::vector actors_that_ran; - std::map process_list; + kernel::context::ContextFactory* context_factory = nullptr; + std::map process_list; boost::intrusive::list, &kernel::actor::ActorImpl::smx_destroy_list_hook>> @@ -49,23 +45,12 @@ 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; - - // Maps function names to actor code: - std::unordered_map registered_functions; - - // This might be used when no corresponding function name is registered: - simgrid::simix::ActorCodeFactory default_function; + kernel::actor::ActorImpl* maestro_ = nullptr; std::mutex mutex; - - std::vector> tasks; - std::vector> tasksTemp; - - std::vector daemons; }; } } @@ -74,16 +59,4 @@ XBT_PUBLIC_DATA std::unique_ptr simix_global; XBT_PUBLIC void SIMIX_clean(); -/******************************** Exceptions *********************************/ -/** @brief Ask to the provided ActorImpl to raise the provided exception */ -#define SMX_EXCEPTION(issuer, cat, val, msg) \ - if (1) { \ - simgrid::kernel::actor::ActorImpl* _smx_throw_issuer = (issuer); /* evaluate only once */ \ - xbt_ex e(XBT_THROW_POINT, msg); \ - e.category = cat; \ - e.value = val; \ - _smx_throw_issuer->exception_ = std::make_exception_ptr(e); \ - } else \ - ((void)0) - #endif