Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
Merge branch 'dev/s4u_tuto_fixes' into 'master'
[simgrid.git] / include / simgrid / s4u / VirtualMachine.hpp
1 /* Copyright (c) 2015-2022. The SimGrid Team. All rights reserved.          */
2
3 /* This program is free software; you can redistribute it and/or modify it
4  * under the terms of the license (GNU LGPL) which comes with this package. */
5
6 #ifndef SIMGRID_S4U_VM_HPP
7 #define SIMGRID_S4U_VM_HPP
8
9 #include <simgrid/forward.h>
10 #include <simgrid/s4u/Host.hpp>
11 #include <xbt/utility.hpp>
12
13 namespace simgrid {
14 namespace s4u {
15
16 /** @brief Host extension for the VMs */
17 class VmHostExt {
18 public:
19   static xbt::Extension<s4u::Host, VmHostExt> EXTENSION_ID;
20
21   sg_size_t ramsize = 0;    /* available ramsize (0= not taken into account) */
22   bool overcommit   = true; /* Whether the host allows overcommiting more VM than the avail ramsize allows */
23   static void ensureVmExtInstalled();
24 };
25
26 /** @ingroup s4u_api
27  *
28  * @tableofcontents
29  *
30  * A VM represents a virtual machine (or a container) that hosts actors.
31  * The total computing power that the contained actors can get is constrained to the virtual machine size.
32  *
33  */
34 class XBT_PUBLIC VirtualMachine : public s4u::Host {
35   kernel::resource::VirtualMachineImpl* const pimpl_vm_;
36
37   /* Signals about the life cycle of the VM */
38   static xbt::signal<void(VirtualMachine&)> on_creation;
39   static xbt::signal<void(VirtualMachine const&)> on_start;
40   static xbt::signal<void(VirtualMachine const&)> on_started;
41   static xbt::signal<void(VirtualMachine const&)> on_shutdown;
42   static xbt::signal<void(VirtualMachine const&)> on_suspend;
43   static xbt::signal<void(VirtualMachine const&)> on_resume;
44   static xbt::signal<void(VirtualMachine const&)> on_migration_start;
45   static xbt::signal<void(VirtualMachine const&)> on_migration_end;
46   static xbt::signal<void(VirtualMachine const&)> on_destruction;
47
48 #ifndef DOXYGEN
49   friend kernel::resource::VirtualMachineImpl; // calls signals from Impl
50 #endif
51
52 public:
53   explicit VirtualMachine(const std::string& name, Host* physical_host, int core_amount, size_t ramsize);
54
55 #ifndef DOXYGEN
56   // No copy/move
57   VirtualMachine(VirtualMachine const&) = delete;
58   VirtualMachine& operator=(VirtualMachine const&) = delete;
59 #endif
60
61   // enum class State { ... }
62   XBT_DECLARE_ENUM_CLASS(State,
63     CREATED, /**< created, but not yet started */
64     RUNNING,
65     SUSPENDED, /**< Suspend/resume does not involve disk I/O, so we assume there is no transition states. */
66     DESTROYED
67   );
68
69   kernel::resource::VirtualMachineImpl* get_vm_impl() const { return pimpl_vm_; }
70   void start();
71   void suspend();
72   void resume();
73   void shutdown();
74   void destroy() override;
75
76   Host* get_pm() const;
77   VirtualMachine* set_pm(Host* pm);
78   size_t get_ramsize() const;
79   VirtualMachine* set_ramsize(size_t ramsize);
80   VirtualMachine* set_bound(double bound);
81   void start_migration() const;
82   void end_migration() const;
83
84   State get_state() const;
85
86   /* Callbacks on signals */
87   static void on_creation_cb(const std::function<void(VirtualMachine&)>& cb) { on_creation.connect(cb); }
88   static void on_start_cb(const std::function<void(VirtualMachine const&)>& cb) { on_start.connect(cb); }
89   static void on_started_cb(const std::function<void(VirtualMachine const&)>& cb) { on_started.connect(cb); }
90   static void on_shutdown_cb(const std::function<void(VirtualMachine const&)>& cb) { on_shutdown.connect(cb); }
91   static void on_suspend_cb(const std::function<void(VirtualMachine const&)>& cb) { on_suspend.connect(cb); }
92   static void on_resume_cb(const std::function<void(VirtualMachine const&)>& cb) { on_resume.connect(cb); }
93   static void on_destruction_cb(const std::function<void(VirtualMachine const&)>& cb) { on_destruction.connect(cb); }
94   static void on_migration_start_cb(const std::function<void(VirtualMachine const&)>& cb)
95   {
96     on_migration_start.connect(cb);
97   }
98   static void on_migration_end_cb(const std::function<void(VirtualMachine const&)>& cb)
99   {
100     on_migration_end.connect(cb);
101   }
102 };
103 } // namespace s4u
104 } // namespace simgrid
105
106 #endif