X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/2be0e4648c5b7055580df1c265b7c43ee6763a46..b8ba0bc2f48c6b9b96dfedd8fd383b941d5fdd0b:/src/msg/msg_task.c diff --git a/src/msg/msg_task.c b/src/msg/msg_task.c index f453edcbde..6698d82373 100644 --- a/src/msg/msg_task.c +++ b/src/msg/msg_task.c @@ -110,7 +110,15 @@ void MSG_task_set_data(m_task_t task, void *data) */ void MSG_task_set_copy_callback(void (*callback) (m_task_t task, m_process_t sender, m_process_t receiver)) { + msg_global->task_copy_callback = callback; + + if (callback) { + SIMIX_comm_set_copy_data_callback(MSG_comm_copy_data_from_SIMIX); + } + else { + SIMIX_comm_set_copy_data_callback(SIMIX_comm_copy_pointer_callback); + } } /** \ingroup m_task_management @@ -186,7 +194,7 @@ MSG_error_t MSG_task_destroy(m_task_t task) action = task->simdata->compute; if (action) - SIMIX_req_host_execution_destroy(action); + simcall_host_execution_destroy(action); /* parallel tasks only */ xbt_free(task->simdata->host_list); @@ -209,10 +217,10 @@ MSG_error_t MSG_task_cancel(m_task_t task) xbt_assert((task != NULL), "Invalid parameter"); if (task->simdata->compute) { - SIMIX_req_host_execution_cancel(task->simdata->compute); + simcall_host_execution_cancel(task->simdata->compute); } else if (task->simdata->comm) { - SIMIX_req_comm_cancel(task->simdata->comm); + simcall_comm_cancel(task->simdata->comm); task->simdata->isused = 0; } return MSG_OK; @@ -253,7 +261,7 @@ double MSG_task_get_remaining_computation(m_task_t task) && (task->simdata != NULL), "Invalid parameter"); if (task->simdata->compute) { - return SIMIX_req_host_execution_get_remains(task->simdata->compute); + return simcall_host_execution_get_remains(task->simdata->compute); } else { return task->simdata->computation_amount; } @@ -269,9 +277,9 @@ double MSG_task_get_remaining_communication(m_task_t task) { xbt_assert((task != NULL) && (task->simdata != NULL), "Invalid parameter"); - XBT_DEBUG("calling SIMIX_req_communication_get_remains(%p)", + XBT_DEBUG("calling simcall_communication_get_remains(%p)", task->simdata->comm); - return SIMIX_req_comm_get_remains(task->simdata->comm); + return simcall_comm_get_remains(task->simdata->comm); } #ifdef HAVE_LATENCY_BOUND_TRACKING @@ -283,9 +291,9 @@ int MSG_task_is_latency_bounded(m_task_t task) { xbt_assert((task != NULL) && (task->simdata != NULL), "Invalid parameter"); - XBT_DEBUG("calling SIMIX_req_communication_is_latency_bounded(%p)", + XBT_DEBUG("calling simcall_communication_is_latency_bounded(%p)", task->simdata->comm); - return SIMIX_req_comm_is_latency_bounded(task->simdata->comm); + return simcall_comm_is_latency_bounded(task->simdata->comm); } #endif @@ -316,6 +324,6 @@ void MSG_task_set_priority(m_task_t task, double priority) task->simdata->priority = 1 / priority; if (task->simdata->compute) - SIMIX_req_host_execution_set_priority(task->simdata->compute, + simcall_host_execution_set_priority(task->simdata->compute, task->simdata->priority); }