X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/9b9103db7f7aac95d28b162b7f78c6a946bba864..045febe057cdab268bf1d2aedae1f6db9333672d:/src/surf/network.c diff --git a/src/surf/network.c b/src/surf/network.c index f5712f1eed..c3cfc6580e 100644 --- a/src/surf/network.c +++ b/src/surf/network.c @@ -269,19 +269,19 @@ static void update_actions_state(double now, double delta) deltap = delta; if (action->latency > 0) { if (action->latency > deltap) { - action->latency -= deltap; + surf_double_update(&(action->latency),deltap); deltap = 0.0; } else { - deltap -= action->latency; + surf_double_update(&(deltap), action->latency); action->latency = 0.0; } - if (action->latency == 0.0) + if ((action->latency == 0.0) && !(action->suspended)) lmm_update_variable_weight(maxmin_system, action->variable, 1.0); } - action->generic_action.remains -= - lmm_variable_getvalue(action->variable) * deltap; + surf_double_update(&(action->generic_action.remains), + lmm_variable_getvalue(action->variable) * deltap); if (action->generic_action.max_duration != NO_MAX_DURATION) - action->generic_action.max_duration -= delta; + surf_double_update(&(action->generic_action.max_duration), delta); /* if(action->generic_action.remains<.00001) action->generic_action.remains=0; */ @@ -339,8 +339,12 @@ static void update_resource_state(void *id, while (lmm_get_var_from_cnst(maxmin_system, nw_link->constraint, &var)) { action = lmm_variable_id(var); action->lat_current += delta; - lmm_update_variable_bound(maxmin_system, var, - 1 / (action->lat_current)); + if(action->rate<0) + lmm_update_variable_bound(maxmin_system, action->variable, + SG_TCP_CTE_GAMMA / action->lat_current); + else + lmm_update_variable_bound(maxmin_system, action->variable, + min(action->rate,SG_TCP_CTE_GAMMA / action->lat_current)); } } else if (event_type == nw_link->state_event) { if (value > 0) @@ -355,7 +359,7 @@ static void update_resource_state(void *id, return; } -static surf_action_t communicate(void *src, void *dst, double size) +static surf_action_t communicate(void *src, void *dst, double size, double rate) { surf_action_network_t action = NULL; network_card_t card_src = src; @@ -378,6 +382,7 @@ static surf_action_t communicate(void *src, void *dst, double size) surf_network_resource->common_public->states.running_action_set; xbt_swag_insert(action, action->generic_action.state_set); + action->rate = rate; action->latency = 0.0; for (i = 0; i < route_size; i++) @@ -391,8 +396,12 @@ static surf_action_t communicate(void *src, void *dst, double size) action->variable = lmm_variable_new(maxmin_system, action, 1.0, -1.0, route_size); - lmm_update_variable_bound(maxmin_system, action->variable, - SG_TCP_CTE_GAMMA / action->lat_current); + if(action->rate<0) + lmm_update_variable_bound(maxmin_system, action->variable, + SG_TCP_CTE_GAMMA / action->lat_current); + else + lmm_update_variable_bound(maxmin_system, action->variable, + min(action->rate,SG_TCP_CTE_GAMMA / action->lat_current)); for (i = 0; i < route_size; i++) lmm_expand(maxmin_system, route[i]->constraint, action->variable, 1.0); @@ -400,6 +409,25 @@ static surf_action_t communicate(void *src, void *dst, double size) return (surf_action_t) action; } +static void action_suspend(surf_action_t action) +{ + ((surf_action_network_t) action)->suspended = 1; + lmm_update_variable_weight(maxmin_system, + ((surf_action_network_t) action)->variable, 0.0); +} + +static void action_resume(surf_action_t action) +{ + lmm_update_variable_weight(maxmin_system, + ((surf_action_network_t) action)->variable, 1.0); + ((surf_action_network_t) action)->suspended = 0; +} + +static int action_is_suspended(surf_action_t action) +{ + return ((surf_action_network_t) action)->suspended; +} + static void finalize(void) { int i,j; @@ -474,6 +502,10 @@ static void surf_network_resource_init_internal(void) update_resource_state; surf_network_resource->common_private->finalize = finalize; + surf_network_resource->common_public->suspend = action_suspend; + surf_network_resource->common_public->resume = action_resume; + surf_network_resource->common_public->is_suspended = action_is_suspended; + surf_network_resource->extension_public->communicate = communicate; network_link_set = xbt_dict_new();