- surf_action_cpu_t action = NULL;
- xbt_swag_t running_actions= surf_cpu_resource->resource.states.running_action_set;
- xbt_maxmin_float_t min = -1;
- xbt_maxmin_float_t value = -1;
- lmm_solve(sys);
-
- action = xbt_swag_getFirst(running_actions);
- if(!action) return 0.0;
- value = lmm_variable_getvalue(action->variable);
- min = action->generic_action.remains / value ;
+ surf_action_cpu_Cas01_t action = NULL;
+ cpu_Cas01_t CPU = cpu;
+
+ XBT_IN2("(%s,%g)", CPU->generic_resource.name, size);
+ action = xbt_new0(s_surf_action_cpu_Cas01_t, 1);
+
+ action->generic_action.refcount = 1;
+ action->generic_action.cost = size;
+ action->generic_action.remains = size;
+ action->generic_action.priority = 1.0;
+ action->generic_action.max_duration = NO_MAX_DURATION;
+ action->generic_action.start = surf_get_clock();
+ action->generic_action.finish = -1.0;
+ action->generic_action.model_type = surf_cpu_model;
+ action->suspended = 0; /* Should be useless because of the
+ calloc but it seems to help valgrind... */
+
+ if (CPU->state_current == SURF_CPU_ON)
+ action->generic_action.state_set =
+ surf_cpu_model->states.running_action_set;
+ else
+ action->generic_action.state_set =
+ surf_cpu_model->states.failed_action_set;
+
+ xbt_swag_insert(action, action->generic_action.state_set);
+
+ action->variable = lmm_variable_new(cpu_maxmin_system, action,
+ action->generic_action.priority,
+ -1.0, 1);
+ lmm_expand(cpu_maxmin_system, CPU->constraint, action->variable, 1.0);
+ XBT_OUT;
+ return (surf_action_t) action;
+}