Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
Merge branch 'master' of git+ssh://scm.gforge.inria.fr//gitroot/simgrid/simgrid
[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   xbt_dynar_t getRoute(NetCard *src, NetCard *dst);
53   Action *communicate(NetCard *src, NetCard *dst, double size, double rate);
54   double next_occuring_event(double now) override;
55   bool next_occuring_event_isIdempotent() {return false;}
56   void updateActionsState(double now, double delta) override;
57 };
58
59 /************
60  * Resource *
61  ************/
62 class NetworkNS3Link : public Link {
63 public:
64   NetworkNS3Link(NetworkNS3Model *model, const char *name, xbt_dict_t props,
65                double bw_initial, double lat_initial);
66   ~NetworkNS3Link();
67
68   void apply_event(tmgr_trace_iterator_t event, double value) override;
69   void updateBandwidth(double value) override {THROW_UNIMPLEMENTED;}
70   void updateLatency(double value) override {THROW_UNIMPLEMENTED;}
71
72 //private:
73  int m_created;
74 };
75
76 /**********
77  * Action *
78  **********/
79 class NetworkNS3Action : public NetworkAction {
80 public:
81   NetworkNS3Action(Model *model, double cost, bool failed);
82
83 #ifdef HAVE_LATENCY_BOUND_TRACKING
84   int getLatencyLimited();
85 #endif
86
87 bool isSuspended();
88 int unref();
89 void suspend();
90 void resume();
91
92 //private:
93   double m_lastSent;
94   NetCard *p_srcElm;
95   NetCard *p_dstElm;
96 };
97
98 }
99 }
100
101 #endif /* NETWORK_NS3_HPP_ */