X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/cdcc6f10f0ba3de1b01e4c910fa1966114350ae6..5a469c9dca9ce25cee1a52682d7eb7bbd736a49b:/include/simgrid/s4u/Host.hpp diff --git a/include/simgrid/s4u/Host.hpp b/include/simgrid/s4u/Host.hpp index 9e79f60f21..4ce6a6aa8f 100644 --- a/include/simgrid/s4u/Host.hpp +++ b/include/simgrid/s4u/Host.hpp @@ -35,6 +35,8 @@ namespace s4u { * and actors can retrieve the host on which they run using simgrid::s4u::Host::current(). */ class XBT_PUBLIC Host : public simgrid::xbt::Extendable { + friend simgrid::vm::VMModel; // Use the pimpl_cpu to compute the VM sharing + friend simgrid::vm::VirtualMachineImpl; // creates the the pimpl_cpu public: explicit Host(const char* name); @@ -47,6 +49,16 @@ private: bool currentlyDestroying_ = false; public: + /*** Called on each newly created host */ + static simgrid::xbt::signal on_creation; + /*** Called just before destructing an host */ + static simgrid::xbt::signal on_destruction; + /*** Called when the machine is turned on or off (called AFTER the change) */ + static simgrid::xbt::signal on_state_change; + /*** Called when the speed of the machine is changed (called AFTER the change) + * (either because of a pstate switch or because of an external load event coming from the profile) */ + static simgrid::xbt::signal on_speed_change; + virtual void destroy(); // No copy/move Host(Host const&) = delete; @@ -63,12 +75,6 @@ public: /** Retrieves the host on which the current actor is running */ static s4u::Host* current(); - XBT_ATTRIB_DEPRECATED_v323("Please use Host::get_name()") simgrid::xbt::string const& getName() const - { - return name_; - } - XBT_ATTRIB_DEPRECATED_v323("Please use Host::get_cname()") const char* getCname() const { return name_.c_str(); } - /** Retrieves the name of that host as a C++ string */ simgrid::xbt::string const& get_name() const { return name_; } /** Retrieves the name of that host as a C string */ @@ -90,6 +96,7 @@ public: bool isOff() { return not isOn(); } double getSpeed(); + double get_available_speed(); int getCoreCount(); std::map* getProperties(); const char* getProperty(const char* key); @@ -129,27 +136,24 @@ public: */ double getLoad(); + // Deprecated functions + XBT_ATTRIB_DEPRECATED_v323("Please use Host::get_name()") simgrid::xbt::string const& getName() const + { + return name_; + } + XBT_ATTRIB_DEPRECATED_v323("Please use Host::get_cname()") const char* getCname() const { return name_.c_str(); } + private: simgrid::xbt::string name_{"noname"}; std::unordered_map* mounts_ = nullptr; // caching public: - // TODO, this could be a unique_ptr - surf::HostImpl* pimpl_ = nullptr; /** DO NOT USE DIRECTLY (@todo: these should be protected, once our code is clean) */ surf::Cpu* pimpl_cpu = nullptr; + // TODO, this could be a unique_ptr + surf::HostImpl* pimpl_ = nullptr; /** DO NOT USE DIRECTLY (@todo: these should be protected, once our code is clean) */ kernel::routing::NetPoint* pimpl_netpoint = nullptr; - - /*** Called on each newly created host */ - static simgrid::xbt::signal on_creation; - /*** Called just before destructing an host */ - static simgrid::xbt::signal on_destruction; - /*** Called when the machine is turned on or off (called AFTER the change) */ - static simgrid::xbt::signal on_state_change; - /*** Called when the speed of the machine is changed (called AFTER the change) - * (either because of a pstate switch or because of an external load event coming from the profile) */ - static simgrid::xbt::signal on_speed_change; }; } } // namespace simgrid::s4u