X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/7444a715278a4bad33c0200162286c50f03bcaef..83d62d72a9468f9f8e97b677dd40d5a2bd60ba86:/src/simix/smx_private.hpp diff --git a/src/simix/smx_private.hpp b/src/simix/smx_private.hpp index e6cc998a0e..26893347ab 100644 --- a/src/simix/smx_private.hpp +++ b/src/simix/smx_private.hpp @@ -1,4 +1,4 @@ -/* Copyright (c) 2007-2018. The SimGrid Team. All rights reserved. */ +/* Copyright (c) 2007-2019. 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. */ @@ -7,11 +7,12 @@ #define SIMIX_PRIVATE_HPP #include "simgrid/s4u/Actor.hpp" +#include "src/kernel/actor/ActorImpl.hpp" #include "src/kernel/context/Context.hpp" -#include #include -#include +#include +#include #include /********************************** Simix Global ******************************/ @@ -20,19 +21,28 @@ namespace simgrid { namespace simix { class Global { - friend XBT_PUBLIC bool simgrid::s4u::this_actor::isMaestro(); + friend XBT_PUBLIC bool simgrid::s4u::this_actor::is_maestro(); public: + bool execute_tasks(); + /** + * Garbage collection + * + * 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(); + smx_context_factory_t context_factory = nullptr; - std::vector process_to_run; - std::vector process_that_ran; + std::vector actors_to_run; + std::vector actors_that_ran; std::map process_list; boost::intrusive::list, &kernel::actor::ActorImpl::smx_destroy_list_hook>> - process_to_destroy; + actors_to_destroy; #if SIMGRID_HAVE_MC - /* MCer cannot read members process_list and process_to_destroy above in the remote process, so we copy the info it + /* MCer cannot read members process_list and actors_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 @@ -51,11 +61,7 @@ public: // This might be used when no corresponding function name is registered: simgrid::simix::ActorCodeFactory default_function; - smx_creation_func_t create_process_function = nullptr; - 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; @@ -65,23 +71,8 @@ public: } } -extern "C" { - 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