- surf_action_parallel_task_CSL05_t action = NULL;
- surf_action_parallel_task_CSL05_t next_action = NULL;
- xbt_swag_t running_actions =
- surf_workstation_resource->common_public->states.running_action_set;
- /* FIXME: unused
- xbt_swag_t failed_actions =
- surf_workstation_resource->common_public->states.failed_action_set;
- */
-
- xbt_swag_foreach_safe(action, next_action, running_actions) {
- double_update(&(action->generic_action.remains),
- lmm_variable_getvalue(action->variable) * delta);
- if (action->generic_action.max_duration != NO_MAX_DURATION)
- double_update(&(action->generic_action.max_duration), delta);
- if ((action->generic_action.remains <= 0) &&
- (lmm_get_variable_weight(action->variable)>0)) {
- action->generic_action.finish = surf_get_clock();
- action_change_state((surf_action_t) action, SURF_ACTION_DONE);
- } else if ((action->generic_action.max_duration != NO_MAX_DURATION) &&
- (action->generic_action.max_duration <= 0)) {
- action->generic_action.finish = surf_get_clock();
- action_change_state((surf_action_t) action, SURF_ACTION_DONE);
- } else { /* Need to check that none of the resource has failed */
- lmm_constraint_t cnst = NULL;
- int i = 0;
- surf_resource_t resource = NULL;
-
- while ((cnst =
- lmm_get_cnst_from_var(maxmin_system, action->variable,
- i++))) {
- resource = (surf_resource_t) lmm_constraint_id(cnst);
- if(resource== (surf_resource_t) surf_cpu_resource) {
- cpu_Cas01_t cpu = lmm_constraint_id(cnst);
- if (cpu->state_current == SURF_CPU_OFF) {
- action->generic_action.finish = surf_get_clock();
- action_change_state((surf_action_t) action, SURF_ACTION_FAILED);
- break;
- }
- } else if (resource== (surf_resource_t) surf_network_resource) {
- network_link_CM02_t nw_link = lmm_constraint_id(cnst);
-
- if (nw_link->state_current == SURF_NETWORK_LINK_OFF) {
- action->generic_action.finish = surf_get_clock();
- action_change_state((surf_action_t) action, SURF_ACTION_FAILED);
- break;
- }
- }
- }
- }
- }
-
- return;
-}
-
-#ifdef USE_GTNETS
-/* KF. For GTNetS. This is the same as surf_actions_state_gtnets except for
- the network resource update.
-*/
-static void update_actions_state_gtnets(double now, double delta)
-{
- surf_action_parallel_task_CSL05_t action = NULL;
- surf_action_parallel_task_CSL05_t next_action = NULL;
- xbt_swag_t running_actions =
- surf_workstation_resource->common_public->states.running_action_set;
- /* FIXME: unused
- xbt_swag_t failed_actions =
- surf_workstation_resource->common_public->states.failed_action_set;
- */
-
- xbt_swag_foreach_safe(action, next_action, running_actions) {
- double_update(&(action->generic_action.remains),
- lmm_variable_getvalue(action->variable) * delta);
- if (action->generic_action.max_duration != NO_MAX_DURATION)
- double_update(&(action->generic_action.max_duration), delta);
- if ((action->generic_action.remains <= 0) &&
- (lmm_get_variable_weight(action->variable)>0)) {
- action->generic_action.finish = surf_get_clock();
- action_change_state((surf_action_t) action, SURF_ACTION_DONE);
- } else if ((action->generic_action.max_duration != NO_MAX_DURATION) &&
- (action->generic_action.max_duration <= 0)) {
- action->generic_action.finish = surf_get_clock();
- action_change_state((surf_action_t) action, SURF_ACTION_DONE);
- } else { /* Need to check that none of the resource has failed */
- lmm_constraint_t cnst = NULL;
- int i = 0;
- surf_resource_t resource = NULL;
-
- while ((cnst =
- lmm_get_cnst_from_var(maxmin_system, action->variable,
- i++))) {
- resource = (surf_resource_t) lmm_constraint_id(cnst);
- if(resource== (surf_resource_t) surf_cpu_resource) {
- cpu_Cas01_t cpu = lmm_constraint_id(cnst);
- if (cpu->state_current == SURF_CPU_OFF) {
- action->generic_action.finish = surf_get_clock();
- action_change_state((surf_action_t) action, SURF_ACTION_FAILED);
- break;
- }
- } else if (resource== (surf_resource_t) surf_network_resource) {
- /**
- network_link_GTNETS_t nw_link = lmm_constraint_id(cnst);
-
- if (nw_link->state_current == SURF_NETWORK_LINK_OFF) {
- action->generic_action.finish = surf_get_clock();
- action_change_state((surf_action_t) action, SURF_ACTION_FAILED);
- break;
- }
- **/
- }
- }
- }
- }
-