Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
STFU you dawn VM - The lovingly handmade tests
[simgrid.git] / src / surf / network_ns3.hpp
1 /* Copyright (c) 2004-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 "network_interface.hpp"
10 #include "src/surf/ns3/ns3_interface.h"
11
12 #ifndef NETWORK_NS3_HPP_
13 #define NETWORK_NS3_HPP_
14
15 /***********
16  * Classes *
17  ***********/
18
19 namespace simgrid {
20 namespace surf {
21
22 class XBT_PRIVATE NetworkNS3Model;
23 class XBT_PRIVATE NetworkNS3Action;
24
25 }
26 }
27
28 /*********
29  * Tools *
30  *********/
31
32 XBT_PRIVATE void net_define_callbacks(void);
33
34 /*********
35  * Model *
36  *********/
37
38 namespace simgrid {
39 namespace surf {
40
41 class NetworkNS3Model : public NetworkModel {
42 public:
43   NetworkNS3Model();
44
45   ~NetworkNS3Model();
46   Link* createLink(const char *name,
47       double bw_initial, tmgr_trace_t bw_trace,
48       double lat_initial, tmgr_trace_t lat_trace,
49       tmgr_trace_t state_trace,
50       e_surf_link_sharing_policy_t policy,
51       xbt_dict_t properties) override;
52   Action *communicate(NetCard *src, NetCard *dst, double size, double rate);
53   double next_occuring_event(double now) override;
54   bool next_occuring_event_isIdempotent() {return false;}
55   void updateActionsState(double now, double delta) override;
56 };
57
58 /************
59  * Resource *
60  ************/
61 class NetworkNS3Link : public Link {
62 public:
63   NetworkNS3Link(NetworkNS3Model *model, const char *name, xbt_dict_t props,
64                double bw_initial, double lat_initial);
65   ~NetworkNS3Link();
66
67   void apply_event(tmgr_trace_iterator_t event, double value) override;
68   void updateBandwidth(double value) override {THROW_UNIMPLEMENTED;}
69   void updateLatency(double value) override {THROW_UNIMPLEMENTED;}
70
71 //private:
72  int m_created;
73 };
74
75 /**********
76  * Action *
77  **********/
78 class NetworkNS3Action : public NetworkAction {
79 public:
80   NetworkNS3Action(Model *model, double cost, bool failed);
81
82 #ifdef HAVE_LATENCY_BOUND_TRACKING
83   int getLatencyLimited();
84 #endif
85
86 bool isSuspended();
87 int unref();
88 void suspend();
89 void resume();
90
91 //private:
92   double m_lastSent;
93   NetCard *p_srcElm;
94   NetCard *p_dstElm;
95 };
96
97 }
98 }
99
100 #endif /* NETWORK_NS3_HPP_ */