e_surf_resource_state_t state_initial_link = SURF_RESOURCE_ON;
e_surf_link_sharing_policy_t policy_initial_link = SURF_LINK_SHARED;
tmgr_trace_t state_trace;
-
+ DEBUG0("link_CM02");
name_link = xbt_strdup(A_surfxml_link_id);
surf_parse_get_double(&bw_initial, A_surfxml_link_bandwidth);
bw_trace = tmgr_trace_new(A_surfxml_link_bandwidth_file);
else if (A_surfxml_link_state == A_surfxml_link_state_OFF)
state_initial_link = SURF_RESOURCE_OFF;
- if (A_surfxml_link_sharing_policy ==
- A_surfxml_link_sharing_policy_SHARED)
+ if (A_surfxml_link_sharing_policy == A_surfxml_link_sharing_policy_SHARED)
policy_initial_link = SURF_LINK_SHARED;
- else if (A_surfxml_link_sharing_policy ==
- A_surfxml_link_sharing_policy_FATPIPE)
- policy_initial_link = SURF_LINK_FATPIPE;
+ else
+ {
+ if (A_surfxml_link_sharing_policy == A_surfxml_link_sharing_policy_FATPIPE)
+ policy_initial_link = SURF_LINK_FATPIPE;
+ else if (A_surfxml_link_sharing_policy == A_surfxml_link_sharing_policy_FULLDUPLEX)
+ policy_initial_link = SURF_LINK_FULLDUPLEX;
+ }
state_trace = tmgr_trace_new(A_surfxml_link_state_file);
- net_link_new(name_link, bw_initial, bw_trace,
- lat_initial, lat_trace, state_initial_link, state_trace,
- policy_initial_link, xbt_dict_new());
+ if(policy_initial_link == SURF_LINK_FULLDUPLEX)
+ {
+ net_link_new(bprintf("%s_UP",name_link), bw_initial, bw_trace,
+ lat_initial, lat_trace, state_initial_link, state_trace,
+ policy_initial_link, xbt_dict_new());
+ net_link_new(bprintf("%s_DOWN",name_link), bw_initial, bw_trace,
+ lat_initial, lat_trace, state_initial_link, state_trace,
+ policy_initial_link, xbt_dict_new());
+ }
+ else
+ {
+ net_link_new(name_link, bw_initial, bw_trace,
+ lat_initial, lat_trace, state_initial_link, state_trace,
+ policy_initial_link, xbt_dict_new());
+ }
}
Add a link_CM02_t *link and a int link_nb to network_card_CM02_t. It will represent local links for this node
Use the cluster_id for ->id */
- xbt_dynar_t route = global_routing->get_route(src_name, dst_name);
xbt_dynar_t back_route = NULL;
int constraints_per_variable = 0;
+ // I will need this route for some time so let's call get_route_no_cleanup
+ xbt_dynar_t route = global_routing->get_route_no_cleanup(src_name, dst_name);
+
if (sg_network_fullduplex == 1) {
- back_route = global_routing->get_route(src_name, dst_name);
+ back_route = global_routing->get_route(dst_name, src_name);
}
/* LARGE PLATFORMS HACK:
strncpy(action->dst_name, dst_name, strlen(dst_name) + 1);
#endif
+ xbt_dynar_free(&route);
XBT_OUT;
return (surf_action_t) action;