X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/e22da6010c6499813ff88c76041cf499ffbf2b67..1d047f5a110cfd542b0aedeb72f680e03f8709cd:/src/kernel/EngineImpl.hpp?ds=sidebyside diff --git a/src/kernel/EngineImpl.hpp b/src/kernel/EngineImpl.hpp index 4599d925fc..1857b85936 100644 --- a/src/kernel/EngineImpl.hpp +++ b/src/kernel/EngineImpl.hpp @@ -10,8 +10,10 @@ #include #include #include +#include #include +#include #include #include @@ -24,9 +26,13 @@ class EngineImpl { std::unordered_map netpoints_; std::unordered_map registered_functions; // Maps function names to actor code actor::ActorCodeFactory default_function; // Function to use as a fallback when the provided name matches nothing - std::vector> models_; - std::unordered_map> - models_by_type_; + std::vector models_; + std::unordered_map> models_prio_; + routing::NetZoneImpl* netzone_root_ = nullptr; + std::set daemons_; + + std::vector> tasks; + std::vector> tasksTemp; friend s4u::Engine; @@ -44,35 +50,15 @@ public: /** * @brief Add a model to engine list * - * @param type Model type (network, disk, etc) * @param model Pointer to model - * @param is_default Is this the default model for this type of resource in this exp - */ - void add_model(simgrid::kernel::resource::Model::Type type, std::unique_ptr model, - bool is_default = false); - /** - * @brief Add a model (specific for ptask) - * - * Ptask is special. The CPU and NETWORK models need to be in the managed - * resources by surf_solve (model_by_type) but cannot be in the list of - * all models (old all_existing_models global variable) - * - * This methods does this job while we cannot handle ptask as the remaining models + * @param list List of dependencies for this model */ - void add_model_ptask(simgrid::kernel::resource::Model::Type type, simgrid::kernel::resource::Model* model, - bool is_default); - /** @brief Get current default model for a resource type */ - simgrid::kernel::resource::Model* get_default_model(simgrid::kernel::resource::Model::Type type); + void add_model(std::shared_ptr model, + const std::vector& dep_models = {}); - /** @brief Get list of models created for a resource type */ - const std::vector& get_model_list(simgrid::kernel::resource::Model::Type type) - { - return models_by_type_[type]; - } /** @brief Get list of all models managed by this engine */ - const std::vector>& get_all_models() { return models_; } + const std::vector& get_all_models() const { return models_; } - routing::NetZoneImpl* netzone_root_ = nullptr; static EngineImpl* get_instance() { return simgrid::s4u::Engine::get_instance()->pimpl; } actor::ActorCodeFactory get_function(const std::string& name) { @@ -82,6 +68,16 @@ public: else return res->second; } + void add_daemon(actor::ActorImpl* d) { daemons_.insert(d); } + void rm_daemon(actor::ActorImpl* d); + + bool execute_tasks(); + void add_task(xbt::Task&& t) { tasks.push_back(std::move(t)); } + void wake_all_waiting_actors() const; + void display_all_actor_status() const; + + /** @brief Run the main simulation loop. */ + void run(); }; } // namespace kernel