-smx_action_t SIMIX_pre_host_parallel_execute(smx_simcall_t simcall, const char *name,
- int host_nb, smx_host_t *host_list,
- double *computation_amount, double *communication_amount,
- double amount, double rate){
- return SIMIX_host_parallel_execute(name, host_nb, host_list, computation_amount,
- communication_amount, amount, rate);
-}
-smx_action_t SIMIX_host_parallel_execute(const char *name,
- int host_nb, smx_host_t *host_list,
- double *computation_amount, double *communication_amount,
- double amount, double rate){
-
- void **workstation_list = NULL;
- int i;
-
- /* alloc structures and initialize */
- smx_action_t action = xbt_mallocator_get(simix_global->action_mallocator);
- action->type = SIMIX_ACTION_PARALLEL_EXECUTE;
- action->name = xbt_strdup(name);
- action->state = SIMIX_RUNNING;
- action->execution.host = NULL; /* FIXME: do we need the list of hosts? */
-
-#ifdef HAVE_TRACING
- action->category = NULL;
-#endif
-
- /* set surf's action */
- workstation_list = xbt_new0(void *, host_nb);
- for (i = 0; i < host_nb; i++)
- workstation_list[i] = host_list[i];
-
- /* set surf's action */
- if (!MC_is_active()) {
- action->execution.surf_exec =
- surf_workstation_model->extension.workstation.
- execute_parallel_task(host_nb, workstation_list, computation_amount,
- communication_amount, rate);
-
- surf_workstation_model->action_data_set(action->execution.surf_exec, action);
- }
- XBT_DEBUG("Create parallel execute action %p", action);
-
- return action;