#ifndef NETWORK_INTERFACE_CPP_
#define NETWORK_INTERFACE_CPP_
+XBT_LOG_NEW_DEFAULT_SUBCATEGORY(surf_network, surf,
+ "Logging specific to the SURF network module");
NetworkModelPtr surf_network_model = NULL;
return rate;
}
-bool NetworkLinkLmm::isUsed()
+NetworkLink::NetworkLink(NetworkModelPtr model, const char *name, xbt_dict_t props)
+: p_latEvent(NULL)
+{}
+
+NetworkLink::NetworkLink(NetworkModelPtr model, const char *name, xbt_dict_t props,
+ lmm_constraint_t constraint,
+ tmgr_history_t history,
+ tmgr_trace_t state_trace)
+: Resource(model, name, props, constraint),
+ p_latEvent(NULL)
+{
+ if (state_trace)
+ p_stateEvent = tmgr_history_add_trace(history, state_trace, 0.0, 0, static_cast<ResourcePtr>(this));
+}
+
+bool NetworkLink::isUsed()
{
- return lmm_constraint_used(p_model->p_maxminSystem, p_constraint);
+ return lmm_constraint_used(getModel()->getMaxminSystem(), getConstraint());
}
double NetworkLink::getLatency()
return m_latCurrent;
}
-double NetworkLinkLmm::getBandwidth()
+double NetworkLink::getBandwidth()
{
return p_power.peak * p_power.scale;
}
-bool NetworkLinkLmm::isShared()
+bool NetworkLink::isShared()
{
- return lmm_constraint_is_shared(p_constraint);
+ return lmm_constraint_is_shared(getConstraint());
}
#endif /* NETWORK_INTERFACE_CPP_ */