1
1
openmpi/ompi/mpi/tool
Jeff Squyres 35438ae9b5 mpi/finalized: revamp INITIALIZED/FINALIZED
Per MPI-3.1:8.7.1 p361:11-13, it's valid for MPI_FINALIZED to be
invoked during an attribute destruction callback (e.g., during the
destruction of keyvals on MPI_COMM_SELF during the very beginning of
MPI_FINALIZE).  In such cases, MPI_FINALIZED must return "false".

Prior to this commit, we hung in FINALIZED if it were invoked during
a COMM_SELF attribute destruction callback in FINALIZE.  See
https://github.com/open-mpi/ompi/issues/5084.

This commit converts the MPI_INITIALIZED / MPI_FINALIZED
infrastructure to use a single enum (ompi_mpi_state, set atomically)
to represent the state of MPI:

- not initialized
- init started
- init completed
- finalize started
- finalize past COMM_SELF destruction
- finalize completed

The "finalize past COMM_SELF destruction" state is what allows us to
return "false" from MPI_FINALIZED before COMM_SELF has been fully
destroyed / all attribute callbacks have been invoked.

Since this state is checked at nearly every MPI API call (to see if
we're outside of the INIT/FINALIZE epoch), care was taken to use
atomics to *set* the ompi_mpi_state value in ompi_mpi_init() and
ompi_mpi_finalize(), but performance-critical code paths can simply
read the variable without needing to use a slow call to an
opal_atomic_*() function.

Thanks to @AndrewGaspar for reporting the issue.

Signed-off-by: Jeff Squyres <jsquyres@cisco.com>
2018-06-01 13:36:29 -07:00
..
profile Revert "Update to sync with OMPI master and cleanup to build" 2016-11-22 15:03:20 -08:00
category_changed.c scripted symbol name change (ompi_ prefix) 2017-07-11 02:13:23 -04:00
category_get_categories.c scripted symbol name change (ompi_ prefix) 2017-07-11 02:13:23 -04:00
category_get_cvars.c scripted symbol name change (ompi_ prefix) 2017-07-11 02:13:23 -04:00
category_get_index.c scripted symbol name change (ompi_ prefix) 2017-07-11 02:13:23 -04:00
category_get_info.c scripted symbol name change (ompi_ prefix) 2017-07-11 02:13:23 -04:00
category_get_num.c scripted symbol name change (ompi_ prefix) 2017-07-11 02:13:23 -04:00
category_get_pvars.c scripted symbol name change (ompi_ prefix) 2017-07-11 02:13:23 -04:00
cvar_get_index.c scripted symbol name change (ompi_ prefix) 2017-07-11 02:13:23 -04:00
cvar_get_info.c scripted symbol name change (ompi_ prefix) 2017-07-11 02:13:23 -04:00
cvar_get_num.c scripted symbol name change (ompi_ prefix) 2017-07-11 02:13:23 -04:00
cvar_handle_alloc.c scripted symbol name change (ompi_ prefix) 2017-07-11 02:13:23 -04:00
cvar_handle_free.c Revert "Update to sync with OMPI master and cleanup to build" 2016-11-22 15:03:20 -08:00
cvar_read.c mca/base: add support for additional variable types 2018-03-01 20:42:27 -07:00
cvar_write.c scripted symbol name change (ompi_ prefix) 2017-07-11 02:13:23 -04:00
enum_get_info.c scripted symbol name change (ompi_ prefix) 2017-07-11 02:13:23 -04:00
enum_get_item.c scripted symbol name change (ompi_ prefix) 2017-07-11 02:13:23 -04:00
finalize.c mpi/finalized: revamp INITIALIZED/FINALIZED 2018-06-01 13:36:29 -07:00
init_thread.c scripted symbol name change (ompi_ prefix) 2017-07-11 02:13:23 -04:00
Makefile.am Revert "Update to sync with OMPI master and cleanup to build" 2016-11-22 15:03:20 -08:00
mpit_common.c mca/base: add support for additional variable types 2018-03-01 20:42:27 -07:00
mpit-internal.h scripted symbol name change (ompi_ prefix) 2017-07-11 02:13:23 -04:00
pvar_get_index.c scripted symbol name change (ompi_ prefix) 2017-07-11 02:13:23 -04:00
pvar_get_info.c scripted symbol name change (ompi_ prefix) 2017-07-11 02:13:23 -04:00
pvar_get_num.c Revert "Update to sync with OMPI master and cleanup to build" 2016-11-22 15:03:20 -08:00
pvar_handle_alloc.c scripted symbol name change (ompi_ prefix) 2017-07-11 02:13:23 -04:00
pvar_handle_free.c scripted symbol name change (ompi_ prefix) 2017-07-11 02:13:23 -04:00
pvar_read.c scripted symbol name change (ompi_ prefix) 2017-07-11 02:13:23 -04:00
pvar_readreset.c Revert "Update to sync with OMPI master and cleanup to build" 2016-11-22 15:03:20 -08:00
pvar_reset.c scripted symbol name change (ompi_ prefix) 2017-07-11 02:13:23 -04:00
pvar_session_create.c scripted symbol name change (ompi_ prefix) 2017-07-11 02:13:23 -04:00
pvar_session_free.c Add missing MPI_T_PVAR_SESSION_NULL to mpi.h 2017-03-05 09:03:30 -06:00
pvar_start.c scripted symbol name change (ompi_ prefix) 2017-07-11 02:13:23 -04:00
pvar_stop.c scripted symbol name change (ompi_ prefix) 2017-07-11 02:13:23 -04:00
pvar_write.c scripted symbol name change (ompi_ prefix) 2017-07-11 02:13:23 -04:00