- simdata_process_t simdata = xbt_new0(s_simdata_process_t, 1);
- m_process_t process = xbt_new0(s_m_process_t, 1);
- xbt_assert0(((code != NULL) && (host != NULL)), "Invalid parameters");
-
- /* Simulator Data */
- simdata->PID = msg_global->PID++;
- simdata->waiting_task = NULL;
- simdata->m_host = host;
- simdata->argc = argc;
- simdata->argv = argv;
- simdata->s_process = SIMIX_process_create(name, code,
- (void *) process, host->name,
- argc, argv, NULL);
-
- if (SIMIX_process_self()) {
- simdata->PPID = MSG_process_get_PID(SIMIX_process_self()->data);
- } else {
- simdata->PPID = -1;
- }
- simdata->last_errno = MSG_OK;
-
-
- /* Process structure */
- process->name = xbt_strdup(name);
- process->simdata = simdata;
- process->data = data ;
-
- xbt_fifo_unshift(msg_global->process_list, process);
-
- return process;
+ return MSG_process_create_with_environment(name, code, data, host,
+ argc, argv, NULL);