Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
Merge pull request #2 from mquinson/master
[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,
48                                      tmgr_trace_t bw_trace,
49                                      double lat_initial,
50                                      tmgr_trace_t lat_trace,
51                                      int initiallyOn,
52                                      tmgr_trace_t state_trace,
53                                      e_surf_link_sharing_policy_t policy,
54                                      xbt_dict_t properties);
55   xbt_dynar_t getRoute(NetCard *src, NetCard *dst);
56   Action *communicate(NetCard *src, NetCard *dst, double size, double rate);
57   double next_occuring_event(double now) override;
58   bool next_occuring_event_isIdempotent() {return false;}
59   void updateActionsState(double now, double delta) override;
60 };
61
62 /************
63  * Resource *
64  ************/
65 class NetworkNS3Link : public Link {
66 public:
67   NetworkNS3Link(NetworkNS3Model *model, const char *name, xbt_dict_t props,
68                double bw_initial, double lat_initial);
69   ~NetworkNS3Link();
70
71   void apply_event(tmgr_trace_iterator_t event, double value) override;
72   void updateBandwidth(double value) override {THROW_UNIMPLEMENTED;}
73   void updateLatency(double value) override {THROW_UNIMPLEMENTED;}
74
75 //private:
76  int m_created;
77 };
78
79 /**********
80  * Action *
81  **********/
82 class NetworkNS3Action : public NetworkAction {
83 public:
84   NetworkNS3Action(Model *model, double cost, bool failed);
85
86 #ifdef HAVE_LATENCY_BOUND_TRACKING
87   int getLatencyLimited();
88 #endif
89
90 bool isSuspended();
91 int unref();
92 void suspend();
93 void resume();
94
95 //private:
96   double m_lastSent;
97   NetCard *p_srcElm;
98   NetCard *p_dstElm;
99 };
100
101 }
102 }
103
104 #endif /* NETWORK_NS3_HPP_ */