Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
c3c23f013b6ace81f66a067e960df45af2096da7
[simgrid.git] / src / surf / network_constant.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 #ifndef NETWORK_CONSTANT_HPP_
8 #define NETWORK_CONSTANT_HPP_
9
10 #include <xbt/base.h>
11
12 #include "network_interface.hpp"
13
14 namespace simgrid {
15   namespace surf {
16
17     /***********
18      * Classes *
19      ***********/
20
21     class XBT_PRIVATE NetworkConstantModel;
22     class XBT_PRIVATE NetworkConstantAction;
23
24     /*********
25      * Model *
26      *********/
27     class NetworkConstantModel : public NetworkModel {
28     public:
29       NetworkConstantModel()  : NetworkModel() { };
30       ~NetworkConstantModel() { }
31
32       Action *communicate(NetCard *src, NetCard *dst, double size, double rate) override;
33       double next_occuring_event(double now) override;
34       bool next_occuring_event_isIdempotent() override {return true;}
35       void updateActionsState(double now, double delta) override;
36
37       Link*
38       createLink(const char *name,
39           double bw_initial, tmgr_trace_t bw_trace,
40           double lat_initial, tmgr_trace_t lat_trace,
41           e_surf_link_sharing_policy_t policy,
42           xbt_dict_t properties)          override { DIE_IMPOSSIBLE; }
43     };
44
45     /**********
46      * Action *
47      **********/
48     class NetworkConstantAction : public NetworkAction {
49     public:
50       NetworkConstantAction(NetworkConstantModel *model_, double size, double latency)
51     : NetworkAction(model_, size, false)
52     , m_latInit(latency)
53     {
54         m_latency = latency;
55         if (m_latency <= 0.0) {
56           p_stateSet = getModel()->getDoneActionSet();
57           p_stateSet->push_back(*this);
58         }
59         p_variable = NULL;
60     };
61       int unref() override;
62       void cancel() override;
63       double m_latInit;
64     };
65
66   }
67 }
68
69 #endif /* NETWORK_CONSTANT_HPP_ */