static void action_suspend(surf_action_t action)
{
XBT_IN1("(%p))",action);
- ((surf_action_workstation_KCCFLN05_t) action)->suspended = 1;
- lmm_update_variable_weight(maxmin_system,
- ((surf_action_workstation_KCCFLN05_t)
- action)->variable, 0.0);
+ if(((surf_action_workstation_KCCFLN05_t) action)->suspended != 2) {
+ ((surf_action_workstation_KCCFLN05_t) action)->suspended = 1;
+ lmm_update_variable_weight(maxmin_system,
+ ((surf_action_workstation_KCCFLN05_t)
+ action)->variable, 0.0);
+ }
XBT_OUT;
}
static void action_resume(surf_action_t action)
{
XBT_IN1("(%p)",action);
- if(((surf_action_workstation_KCCFLN05_t)action)->lat_current==0.0)
- lmm_update_variable_weight(maxmin_system,
- ((surf_action_workstation_KCCFLN05_t)
- action)->variable, 1.0);
- else
- lmm_update_variable_weight(maxmin_system,
- ((surf_action_workstation_KCCFLN05_t) action)->variable,
- ((surf_action_workstation_KCCFLN05_t) action)->lat_current);
-
- ((surf_action_workstation_KCCFLN05_t) action)->suspended = 0;
+ if(((surf_action_workstation_KCCFLN05_t) action)->suspended !=2) {
+ if(((surf_action_workstation_KCCFLN05_t)action)->lat_current==0.0)
+ lmm_update_variable_weight(maxmin_system,
+ ((surf_action_workstation_KCCFLN05_t)
+ action)->variable, 1.0);
+ else
+ lmm_update_variable_weight(maxmin_system,
+ ((surf_action_workstation_KCCFLN05_t) action)->variable,
+ ((surf_action_workstation_KCCFLN05_t) action)->lat_current);
+
+ ((surf_action_workstation_KCCFLN05_t) action)->suspended = 0;
+ }
XBT_OUT;
}
static int action_is_suspended(surf_action_t action)
{
- return (((surf_action_workstation_KCCFLN05_t) action)->suspended);
+ return (((surf_action_workstation_KCCFLN05_t) action)->suspended==1);
}
static void action_set_max_duration(surf_action_t action, double duration)
xbt_swag_foreach(action, running_actions) {
if(action->latency>0) {
- if(min<0) min = action->latency;
- else if (action->latency<min) min = action->latency;
+ if(min<0) {
+ min = action->latency;
+ DEBUG3("Updating min (value) with %p (start %f): %f",action,
+ action->generic_action.start, min);
+ }
+ else if (action->latency<min) {
+ min = action->latency;
+ DEBUG3("Updating min (latency) with %p (start %f): %f",action,
+ action->generic_action.start, min);
+ }
}
}
+ DEBUG1("min value : %f",min);
+
return min;
-/* return generic_maxmin_share_resources(surf_workstation_resource->common_public-> */
-/* states.running_action_set, */
-/* xbt_swag_offset(action, variable)); */
}
static void update_actions_state(double now, double delta)
double_update(&(deltap), action->latency);
action->latency = 0.0;
}
- if ((action->latency == 0.0) && !(action->suspended)) {
+ if ((action->latency == 0.0) && (action->suspended==0)) {
if((action)->lat_current==0.0)
lmm_update_variable_weight(maxmin_system,action->variable, 1.0);
else
else
lmm_update_variable_bound(maxmin_system, action->variable,
min(action->rate,SG_TCP_CTE_GAMMA / (2.0 * action->lat_current)));
- if(!(action->suspended))
+ if(action->suspended==0)
lmm_update_variable_weight(maxmin_system, action->variable,
action->lat_current);
}
action = (surf_action_workstation_KCCFLN05_t) execute(cpu, 1.0);
action->generic_action.max_duration = duration;
+ action->suspended = 2;
lmm_update_variable_weight(maxmin_system, action->variable, 0.0);
XBT_OUT;