X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/c34ec0a9a237bf4befb762e35ab117731a8c3851..101c8b10d9965e115c9ff5c28954750a065cf155:/src/plugins/host_energy.cpp diff --git a/src/plugins/host_energy.cpp b/src/plugins/host_energy.cpp index bd348e2236..c7ea34026a 100644 --- a/src/plugins/host_energy.cpp +++ b/src/plugins/host_energy.cpp @@ -3,6 +3,7 @@ /* 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. */ +#include "simgrid/Exception.hpp" #include "simgrid/plugins/energy.h" #include "simgrid/s4u/Engine.hpp" #include "simgrid/s4u/Exec.hpp" @@ -124,7 +125,24 @@ public: }; class HostEnergy { + simgrid::s4u::Host* host_ = nullptr; + /*< List of (idle_power, epsilon_power, max_power) tuple corresponding to each cpu pstate */ + std::vector power_range_watts_list_; + + /* We need to keep track of what pstate has been used, as we will sometimes be notified only *after* a pstate has been + * used (but we need to update the energy consumption with the old pstate!) + */ + int pstate_ = 0; + const int pstate_off_ = -1; + + /* Only used to split total energy into unused/used hosts. + * If you want to get this info for something else, rather use the host_load plugin + */ + bool host_was_used_ = false; + + void init_watts_range_list(); friend void ::on_simulation_end(); // For access to host_was_used_ + public: static simgrid::xbt::Extension EXTENSION_ID; @@ -140,23 +158,6 @@ public: double get_power_range_slope_at(int pstate); void update(); -private: - void init_watts_range_list(); - simgrid::s4u::Host* host_ = nullptr; - /*< List of (idle_power, epsilon_power, max_power) tuple corresponding to each cpu pstate */ - std::vector power_range_watts_list_; - - /* We need to keep track of what pstate has been used, as we will sometimes be notified only *after* a pstate has been - * used (but we need to update the energy consumption with the old pstate!) - */ - int pstate_ = 0; - const int pstate_off_ = -1; - - /* Only used to split total energy into unused/used hosts. - * If you want to get this info for something else, rather use the host_load plugin - */ - bool host_was_used_ = false; -public: double watts_off_ = 0.0; /*< Consumption when the machine is turned off (shutdown) */ double total_energy_ = 0.0; /*< Total energy consumed by the host */ double last_updated_; /*< Timestamp of the last energy update event*/ @@ -471,7 +472,6 @@ static void on_action_state_change(simgrid::kernel::resource::CpuAction const& a for (simgrid::kernel::resource::Cpu* const& cpu : action.cpus()) { simgrid::s4u::Host* host = cpu->get_host(); if (host != nullptr) { - // If it's a VM, take the corresponding PM simgrid::s4u::VirtualMachine* vm = dynamic_cast(host); if (vm) // If it's a VM, take the corresponding PM @@ -515,7 +515,6 @@ static void on_simulation_end() double used_hosts_energy = 0.0; // Energy consumed by hosts that computed something for (size_t i = 0; i < hosts.size(); i++) { if (dynamic_cast(hosts[i]) == nullptr) { // Ignore virtual machines - double energy = hosts[i]->extension()->get_consumed_energy(); total_energy += energy; if (hosts[i]->extension()->host_was_used_) @@ -584,8 +583,8 @@ void sg_host_energy_update_all() static void ensure_plugin_inited() { if (not HostEnergy::EXTENSION_ID.valid()) - throw std::logic_error("The Energy plugin is not active. Please call sg_host_energy_plugin_init() before calling " - "any function related to that plugin."); + throw simgrid::xbt::InitializationError("The Energy plugin is not active. Please call sg_host_energy_plugin_init() " + "before calling any function related to that plugin."); } /** @ingroup plugin_host_energy