Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
478b5092a09e01a86fef1fd3a1586389bbed2516
[simgrid.git] / src / surf / vm_hl13.hpp
1 /* Copyright (c) 2013-2015. The SimGrid Team.
2  * All rights reserved.                                                     */
3
4 /* This program is free software; you can redistribute it and/or modify it
5  * under the terms of the license (GNU LGPL) which comes with this package. */
6
7 #include "xbt/base.h"
8
9 #include "host_clm03.hpp"
10 #include "virtual_machine.hpp"
11
12 #ifndef SURF_VM_HPP_
13 #define SURF_VM_HPP_
14
15 #define GUESTOS_NOISE 100 // This value corresponds to the cost of the global action associated to the VM
16                           // It corresponds to the cost of a VM running no tasks.
17
18 namespace simgrid {
19 namespace surf {
20
21 /***********
22  * Classes *
23  ***********/
24
25 class XBT_PRIVATE VMHL13Model;
26 class XBT_PRIVATE VMHL13;
27
28 /*********
29  * Model *
30  *********/
31 class VMHL13Model : public VMModel {
32 public:
33   VMHL13Model();
34   ~VMHL13Model(){};
35
36   VirtualMachine *createVM(const char *name, sg_host_t host_PM) override;
37   double next_occuring_event(double now) override;
38   void adjustWeightOfDummyCpuActions() override {};
39   void updateActionsState(double /*now*/, double /*delta*/) override;
40 };
41
42 /************
43  * Resource *
44  ************/
45
46 class VMHL13 : public VirtualMachine {
47 public:
48   VMHL13(VMModel *model, const char* name, sg_host_t host_PM);
49   ~VMHL13();
50
51   void suspend() override;
52   void resume() override;
53
54   void save() override;
55   void restore() override;
56
57   void migrate(sg_host_t ind_dst_pm) override;
58
59   void setBound(double bound) override;
60 };
61
62 /**********
63  * Action *
64  **********/
65
66 }
67 }
68
69 #endif /* SURF_VM_HPP_ */