1 /* Copyright (c) 2004-2014. The SimGrid Team.
2 * All rights reserved. */
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. */
7 #include "network_interface.hpp"
8 #include "surf/ns3/ns3_interface.h"
10 #ifndef NETWORK_NS3_HPP_
11 #define NETWORK_NS3_HPP_
16 class NetworkNS3Model;
17 class NetworkNS3Action;
23 void net_define_callbacks(void);
29 class NetworkNS3Model : public NetworkModel {
34 Link* createLink(const char *name,
36 tmgr_trace_t bw_trace,
38 tmgr_trace_t lat_trace,
39 e_surf_resource_state_t state_initial,
40 tmgr_trace_t state_trace,
41 e_surf_link_sharing_policy_t policy,
42 xbt_dict_t properties);
43 xbt_dynar_t getRoute(RoutingEdge *src, RoutingEdge *dst);
44 Action *communicate(RoutingEdge *src, RoutingEdge *dst,
45 double size, double rate);
46 double shareResources(double now);
47 void updateActionsState(double now, double delta);
48 void addTraces(){DIE_IMPOSSIBLE;}
49 bool shareResourcesIsIdempotent() {return false;}
55 class NetworkNS3Link : public Link {
57 NetworkNS3Link(NetworkNS3Model *model, const char *name, xbt_dict_t props,
58 double bw_initial, double lat_initial);
61 void updateState(tmgr_trace_event_t event_type, double value, double date);
62 double getLatency(){THROW_UNIMPLEMENTED;}
63 double getBandwidth(){THROW_UNIMPLEMENTED;}
64 void updateBandwidth(double value, double date=surf_get_clock()){THROW_UNIMPLEMENTED;}
65 void updateLatency(double value, double date=surf_get_clock()){THROW_UNIMPLEMENTED;}
77 class NetworkNS3Action : public NetworkAction {
79 NetworkNS3Action(Model *model, double cost, bool failed);
81 #ifdef HAVE_LATENCY_BOUND_TRACKING
82 int getLatencyLimited();
92 RoutingEdge *p_srcElm;
93 RoutingEdge *p_dstElm;
97 #endif /* NETWORK_NS3_HPP_ */