File: mpir-tools.rst

package info (click to toggle)
openmpi 5.0.8-4
  • links: PTS, VCS
  • area: main
  • in suites:
  • size: 201,684 kB
  • sloc: ansic: 613,078; makefile: 42,353; sh: 11,194; javascript: 9,244; f90: 7,052; java: 6,404; perl: 5,179; python: 1,859; lex: 740; fortran: 61; cpp: 20; tcl: 12
file content (127 lines) | stat: -rw-r--r-- 4,313 bytes parent folder | download | duplicates (8)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
.. _using-mpir-based-tools-label:

Using MPIR-based tools with Open MPI
====================================

The `legacy MPIR specification
<https://www.mpi-forum.org/docs/mpir-specification-03-01-2018.pdf>`_
is the specification of an interface that debuggers and others tools
can use to obtain the PID, hostname, and executable name for each MPI
application process.

This specification has been replaced by the PMIx tools API that is part of the
`OpenPMIx project <https://openpmix.github.io/>`_.

Debuggers and tools which use the legacy MPIR specification can
continue functioning correctly with the `MPIR shim module
<https://github.com/hpc/mpir-to-pmix-guide>`_ described in this
section.

Obtaining Application Process Mapping Information
-------------------------------------------------

The `MPIR shim module <https://github.com/hpc/mpir-to-pmix-guide>`_ is
a stand-alone module which can be used by debuggers and tools that
still utilize the legacy MPIR interface to attach to parallel MPI
applications.  The debugger or tool launches the shim module as an
intermediate process between it and the application's :ref:`mpirun(1)
<man1-mpirun>` command.

The MPIR shim module implements the ``MPIR_Breakpoint`` function, as a
hook where debuggers and tools can set a breakpoint to read the MPIR
processing mapping when it is available.

Instructions for use of the shim module are available at
https://github.com/hpc/mpir-to-pmix-guide/blob/master/README.md.

You may need to build this shim module before you can use it. The
source code for this module can be downloaded from
`MPIR to PMIx Shim repository <https://github.com/hpc/mpir-to-pmix-guide>`_.

Once you have the MPIR shim module built and installed, follow the
instructions included with the debugger or tool to tell it where to
find the MPIR shim module.

/////////////////////////////////////////////////////////////////////////

Building the MPIR Shim Module
-----------------------------

Here is an example shell script that builds the MPIR shim module
|mdash| you may need to customize it for your specific environment:

.. code-block:: bash

    #!/usr/bin/env bash

    set -euxo pipefail

    cd $HOME
    mkdir -p git
    cd git

    git clone https://github.com/hpc/mpir-to-pmix-guide.git
    cd mpir-to-pmix-guide

    # PMIX_ROOT must be set to your PMIx install root directory
    # (which may be the same as your Open MPI installation directory)
    if test -z "$PMIX_ROOT" -o ! -d "$PMIX_ROOT"; then
        echo "Set the env variable PMIX_ROOT to the location of your PMIx installation"
        exit 1
    fi
    
    ./autogen.sh
    ./configure --prefix=$HOME/MPIR --with-pmix=$PMIX_ROOT
    make
    make install


/////////////////////////////////////////////////////////////////////////

Verification of MPIR shim functionality using Open MPI
------------------------------------------------------

Once installed, you may want to verify that the MPIR shim is
functioning correctly.  Below is a shell script that builds and runs a
trivial MPI application, and tests the MPIR shim with it.  Just like
the prior shell script example, this script may need to be adapted for
your environment.

.. code-block:: bash

    #!/usr/bin/env bash

    set -euxo pipefail

    # This script assumes the same directories and locations as the
    # prior script.
    BUILD_DIR=$HOME/git/mpir-to-pmix-guide

    # Add the previously-installed MPIR shim into PATH and
    # LD_LIBRARY_PATH (we assume that all relevant Open MPI / PMIx /
    # etc. values already exist in PATH and LD_LIBRARY_PATH)
    export PATH=$HOME/MPIR/bin:$PATH
    export LD_LIBRARY_PATH=$HOME/MPIR/lib:$LD_LIBRARY_PATH

    cat > testprog.c <<EOF
    #include <mpi.h>
    #include <unistd.h>
    int main(int argc, char **argv) {
        MPI_Init(&argc, &argv);
        sleep(60);
        MPI_Finalize();
        return 0;
    }
    EOF
    mpicc -o testprog testprog.c

    # Test the shim in proxy mode.
    # Manually verify that displayed process mapping is correct.
    $BUILD_DIR/test/mpirshim_test mpirun -n 2 ./testprog
    
    # Launch mpirun for attach test and get its PID
    mpirun -n 2 ./testprog &
    PID=$!
    # Test shim attach mode.
    # Manually verify that displayed process mapping is correct.
    $BUILD_DIR/test/mpirshim_test -c $PID