X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/558cfc9fc06c8d1a7206b5995d3736cc11319529..656d24a575ca26a64c94174ff3573272979e081d:/src/surf/network_interface.cpp diff --git a/src/surf/network_interface.cpp b/src/surf/network_interface.cpp index 6034eaeea1..d18f218fe2 100644 --- a/src/surf/network_interface.cpp +++ b/src/surf/network_interface.cpp @@ -95,35 +95,12 @@ namespace simgrid { simgrid::xbt::signal Link::onDestruction; simgrid::xbt::signal Link::onStateChange; - simgrid::xbt::signal networkActionStateChangedCallbacks; - simgrid::xbt::signal networkCommunicateCallbacks; + simgrid::xbt::signal networkActionStateChangedCallbacks; + simgrid::xbt::signal Link::onCommunicate; } } -void netlink_parse_init(sg_platf_link_cbarg_t link){ - std::vector names; - - if (link->policy == SURF_LINK_FULLDUPLEX) { - names.push_back(bprintf("%s_UP", link->id)); - names.push_back(bprintf("%s_DOWN", link->id)); - } else { - names.push_back(xbt_strdup(link->id)); - } - for (auto link_name : names) { - Link *l = surf_network_model->createLink(link_name, link->bandwidth, link->latency, link->policy, link->properties); - - if (link->latency_trace) - l->setLatencyTrace(link->latency_trace); - if (link->bandwidth_trace) - l->setBandwidthTrace(link->bandwidth_trace); - if (link->state_trace) - l->setStateTrace(link->state_trace); - - xbt_free(link_name); - } -} - /********* * Model * *********/ @@ -156,8 +133,8 @@ namespace simgrid { for(ActionList::iterator it(runningActions->begin()), itend(runningActions->end()) ; it != itend ; ++it) { action = static_cast(&*it); - if (action->m_latency > 0) { - minRes = (minRes < 0) ? action->m_latency : std::min(minRes, action->m_latency); + if (action->latency_ > 0) { + minRes = (minRes < 0) ? action->latency_ : std::min(minRes, action->latency_); } } @@ -185,6 +162,9 @@ namespace simgrid { : Resource(model, name, constraint), PropertyHolder(props) { + if (strcmp(name,"__loopback__")) + xbt_assert(!Link::byName(name), "Link '%s' declared several times in the platform.", name); + m_latency.scale = 1; m_bandwidth.scale = 1; @@ -262,8 +242,8 @@ namespace simgrid { * Action * **********/ - void NetworkAction::setState(e_surf_action_state_t state){ - e_surf_action_state_t old = getState(); + void NetworkAction::setState(Action::State state){ + Action::State old = getState(); Action::setState(state); networkActionStateChangedCallbacks(this, old, state); }