X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/a96adb51dabc0c759af11e60c770355f22a54ef3..9fd6cbc6c3b06f4b09e3c3339ffb3cc8a68f9bfa:/src/simix/smx_private.hpp diff --git a/src/simix/smx_private.hpp b/src/simix/smx_private.hpp index 8fd641fcf4..ea586f129a 100644 --- a/src/simix/smx_private.hpp +++ b/src/simix/smx_private.hpp @@ -1,4 +1,4 @@ -/* Copyright (c) 2007-2017. The SimGrid Team. All rights reserved. */ +/* Copyright (c) 2007-2018. 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. */ @@ -8,9 +8,12 @@ #include "simgrid/s4u/Actor.hpp" #include "src/kernel/context/Context.hpp" -#include +#include "src/simix/ActorImpl.hpp" +#include -#include +#include +#include +#include #include /********************************** Simix Global ******************************/ @@ -19,25 +22,30 @@ namespace simgrid { namespace simix { class Global { - friend bool simgrid::s4u::this_actor::isMaestro(); + friend XBT_PUBLIC bool simgrid::s4u::this_actor::is_maestro(); public: smx_context_factory_t context_factory = nullptr; std::vector process_to_run; std::vector process_that_ran; std::map process_list; + boost::intrusive::list, + &kernel::actor::ActorImpl::smx_destroy_list_hook>> + process_to_destroy; #if SIMGRID_HAVE_MC - /* MCer cannot read the std::map above in the remote process, so we copy the info it needs in a dynar. + /* MCer cannot read members process_list and process_to_destroy above in the remote process, so we copy the info it + * needs in a dynar. * FIXME: This is supposed to be a temporary hack. * A better solution would be to change the split between MCer and MCed, where the responsibility * to compute the list of the enabled transitions goes to the MCed. * 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 actors_vector = xbt_dynar_new(sizeof(smx_actor_t), nullptr); + xbt_dynar_t dead_actors_vector = xbt_dynar_new(sizeof(smx_actor_t), nullptr); #endif - xbt_swag_t process_to_destroy = nullptr; - smx_actor_t maestro_process = nullptr; + smx_actor_t maestro_process = nullptr; // Maps function names to actor code: std::unordered_map registered_functions; @@ -49,33 +57,30 @@ public: void_pfn_smxprocess_t kill_process_function = nullptr; /** Callback used when killing a SMX_process */ void_pfn_smxprocess_t cleanup_process_function = nullptr; - xbt_os_mutex_t mutex = nullptr; + std::mutex mutex; std::vector> tasks; std::vector> tasksTemp; - std::vector daemons; + std::vector daemons; }; - } } -extern "C" { - -XBT_PUBLIC_DATA(std::unique_ptr) simix_global; +XBT_PUBLIC_DATA std::unique_ptr simix_global; -XBT_PUBLIC(void) SIMIX_clean(); +XBT_PUBLIC void SIMIX_clean(); /******************************** Exceptions *********************************/ -/** @brief Ask to the provided simix process to raise the provided exception */ -#define SMX_EXCEPTION(issuer, cat, val, msg) \ - if (1) { \ - smx_actor_t _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) -} +/** @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