X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/cdcfa50107cc897b89de650afa5c7447c21d87d3..1c6ecd7825422241dd932318a4ba03c3df1de985:/src/simix/smx_process.c?ds=sidebyside diff --git a/src/simix/smx_process.c b/src/simix/smx_process.c index f45d326155..c698c7ca61 100644 --- a/src/simix/smx_process.c +++ b/src/simix/smx_process.c @@ -30,7 +30,16 @@ XBT_INLINE smx_process_t SIMIX_process_self(void) } /** - * \brief Move a process to the list of processes to destroy. + * \brief Returns whether a process has pending asynchronous communications. + * \return true if there are asynchronous communications in this process + */ +int SIMIX_process_has_pending_comms(smx_process_t process) { + + return xbt_fifo_size(process->comms) > 0; +} + +/** + * \brief Moves a process to the list of processes to destroy. */ void SIMIX_process_cleanup(smx_process_t process) { @@ -41,9 +50,9 @@ void SIMIX_process_cleanup(smx_process_t process) smx_action_t action; while ((action = xbt_fifo_pop(process->comms))) { - /* make sure no one will finish the comm after this process is destroyed (unless it's detached) */ - if (!action->comm.detached || action->comm.src_proc != process) - SIMIX_comm_cancel(action); + /* make sure no one will finish the comm after this process is destroyed, + * because src_proc or dst_proc would be an invalid pointer */ + SIMIX_comm_cancel(action); if (action->comm.src_proc == process) { XBT_DEBUG("Found an unfinished send comm %p (detached = %d), state %d, src = %p, dst = %p", @@ -58,7 +67,9 @@ void SIMIX_process_cleanup(smx_process_t process) action->comm.refcount++; SIMIX_comm_destroy(action); } - XBT_DEBUG("Don't destroy it since its refcount is %d",action->comm.refcount); + else { + XBT_DEBUG("Don't destroy it since its refcount is %d", action->comm.refcount); + } } else { SIMIX_comm_destroy(action); } @@ -259,6 +270,7 @@ void SIMIX_process_kill(smx_process_t process) { break; case SIMIX_ACTION_COMMUNICATE: + xbt_fifo_remove(process->comms, process->waiting_action); SIMIX_comm_destroy(process->waiting_action); break;