Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
6bc4328dfda0325506a3398575dad9f4093c4284
[simgrid.git] / src / surf / network_interface.cpp
1 /*
2  * network_interface.cpp
3  *
4  *  Created on: Nov 29, 2013
5  *      Author: bedaride
6  */
7 #include "network_interface.hpp"
8 #include "simgrid/sg_config.h"
9
10 #ifndef NETWORK_INTERFACE_CPP_
11 #define NETWORK_INTERFACE_CPP_
12
13 XBT_LOG_NEW_DEFAULT_SUBCATEGORY(surf_network, surf,
14                                 "Logging specific to the SURF network module");
15
16 NetworkModelPtr surf_network_model = NULL;
17
18 xbt_dynar_t NetworkModel::getRoute(RoutingEdgePtr src, RoutingEdgePtr dst)
19 {
20   xbt_dynar_t route = NULL;
21   routing_platf->getRouteAndLatency(src, dst, &route, NULL);
22   return route;
23 }
24
25 double NetworkModel::latencyFactor(double /*size*/) {
26   return sg_latency_factor;
27 }
28
29 double NetworkModel::bandwidthFactor(double /*size*/) {
30   return sg_bandwidth_factor;
31 }
32
33 double NetworkModel::bandwidthConstraint(double rate, double /*bound*/, double /*size*/) {
34   return rate;
35 }
36
37 NetworkLinkLmm::NetworkLinkLmm(lmm_constraint_t constraint,
38                                    tmgr_history_t history,
39                                    tmgr_trace_t state_trace)
40 : ResourceLmm(constraint)
41 {
42   if (state_trace)
43     p_stateEvent = tmgr_history_add_trace(history, state_trace, 0.0, 0, static_cast<ResourcePtr>(this));
44 }
45
46 bool NetworkLinkLmm::isUsed()
47 {
48   return lmm_constraint_used(getModel()->getMaxminSystem(), constraint());
49 }
50
51 double NetworkLink::getLatency()
52 {
53   return m_latCurrent;
54 }
55
56 double NetworkLinkLmm::getBandwidth()
57 {
58   return p_power.peak * p_power.scale;
59 }
60
61 bool NetworkLinkLmm::isShared()
62 {
63   return lmm_constraint_is_shared(constraint());
64 }
65
66 #endif /* NETWORK_INTERFACE_CPP_ */