Cleanup the communicator cid allocation function. The value of the old_com
that has been temporarily stored in the communicator_array should be removed or the finalization will segfault (the same communicator will be released twice). This commit was SVN r28214.
Этот коммит содержится в:
родитель
a856f926de
Коммит
1c281a224c
@ -223,8 +223,8 @@ int ompi_comm_nextcid ( ompi_communicator_t* newcomm,
|
|||||||
OPAL_THREAD_UNLOCK(&ompi_cid_lock);
|
OPAL_THREAD_UNLOCK(&ompi_cid_lock);
|
||||||
|
|
||||||
for (i=start; i < mca_pml.pml_max_contextid ; i++) {
|
for (i=start; i < mca_pml.pml_max_contextid ; i++) {
|
||||||
flag=opal_pointer_array_test_and_set_item(&ompi_mpi_communicators,
|
flag = opal_pointer_array_test_and_set_item(&ompi_mpi_communicators,
|
||||||
i, comm);
|
i, comm);
|
||||||
if (true == flag) {
|
if (true == flag) {
|
||||||
nextlocal_cid = i;
|
nextlocal_cid = i;
|
||||||
break;
|
break;
|
||||||
@ -234,10 +234,8 @@ int ompi_comm_nextcid ( ompi_communicator_t* newcomm,
|
|||||||
ret = (allredfnct)(&nextlocal_cid, &nextcid, 1, MPI_MAX, comm, bridgecomm,
|
ret = (allredfnct)(&nextlocal_cid, &nextcid, 1, MPI_MAX, comm, bridgecomm,
|
||||||
local_leader, remote_leader, send_first );
|
local_leader, remote_leader, send_first );
|
||||||
if( OMPI_SUCCESS != ret ) {
|
if( OMPI_SUCCESS != ret ) {
|
||||||
OPAL_THREAD_LOCK(&ompi_cid_lock);
|
opal_pointer_array_set_item(&ompi_mpi_communicators, nextlocal_cid, NULL);
|
||||||
ompi_comm_unregister_cid (comm->c_contextid);
|
goto release_and_return;
|
||||||
OPAL_THREAD_UNLOCK(&ompi_cid_lock);
|
|
||||||
return ret;
|
|
||||||
}
|
}
|
||||||
if (nextcid == nextlocal_cid) {
|
if (nextcid == nextlocal_cid) {
|
||||||
response = 1; /* fine with me */
|
response = 1; /* fine with me */
|
||||||
@ -259,7 +257,8 @@ int ompi_comm_nextcid ( ompi_communicator_t* newcomm,
|
|||||||
ret = (allredfnct)(&response, &glresponse, 1, MPI_MIN, comm, bridgecomm,
|
ret = (allredfnct)(&response, &glresponse, 1, MPI_MIN, comm, bridgecomm,
|
||||||
local_leader, remote_leader, send_first );
|
local_leader, remote_leader, send_first );
|
||||||
if( OMPI_SUCCESS != ret ) {
|
if( OMPI_SUCCESS != ret ) {
|
||||||
return ret;
|
opal_pointer_array_set_item(&ompi_mpi_communicators, nextcid, NULL);
|
||||||
|
goto release_and_return;
|
||||||
}
|
}
|
||||||
if (1 == glresponse) {
|
if (1 == glresponse) {
|
||||||
done = 1; /* we are done */
|
done = 1; /* we are done */
|
||||||
@ -280,11 +279,12 @@ int ompi_comm_nextcid ( ompi_communicator_t* newcomm,
|
|||||||
newcomm->c_f_to_c_index = newcomm->c_contextid;
|
newcomm->c_f_to_c_index = newcomm->c_contextid;
|
||||||
opal_pointer_array_set_item (&ompi_mpi_communicators, nextcid, newcomm);
|
opal_pointer_array_set_item (&ompi_mpi_communicators, nextcid, newcomm);
|
||||||
|
|
||||||
|
release_and_return:
|
||||||
OPAL_THREAD_LOCK(&ompi_cid_lock);
|
OPAL_THREAD_LOCK(&ompi_cid_lock);
|
||||||
ompi_comm_unregister_cid (comm->c_contextid);
|
ompi_comm_unregister_cid (comm->c_contextid);
|
||||||
OPAL_THREAD_UNLOCK(&ompi_cid_lock);
|
OPAL_THREAD_UNLOCK(&ompi_cid_lock);
|
||||||
|
|
||||||
return (MPI_SUCCESS);
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**************************************************************************/
|
/**************************************************************************/
|
||||||
|
Загрузка…
x
Ссылка в новой задаче
Block a user