<html xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:w="urn:schemas-microsoft-com:office:word" xmlns:m="http://schemas.microsoft.com/office/2004/12/omml" xmlns="http://www.w3.org/TR/REC-html40">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<meta name="Generator" content="Microsoft Word 15 (filtered medium)">
<style><!--
/* Font Definitions */
@font-face
        {font-family:Helvetica;
        panose-1:0 0 0 0 0 0 0 0 0 0;}
@font-face
        {font-family:Wingdings;
        panose-1:5 0 0 0 0 0 0 0 0 0;}
@font-face
        {font-family:"Cambria Math";
        panose-1:2 4 5 3 5 4 6 3 2 4;}
@font-face
        {font-family:Calibri;
        panose-1:2 15 5 2 2 2 4 3 2 4;}
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
        {margin:0in;
        margin-bottom:.0001pt;
        font-size:12.0pt;
        font-family:"Calibri",sans-serif;}
a:link, span.MsoHyperlink
        {mso-style-priority:99;
        color:#0563C1;
        text-decoration:underline;}
span.EmailStyle17
        {mso-style-type:personal-compose;
        font-family:"Calibri",sans-serif;
        color:windowtext;}
p.p1, li.p1, div.p1
        {mso-style-name:p1;
        margin:0in;
        margin-bottom:.0001pt;
        font-size:8.5pt;
        font-family:Helvetica;}
span.s1
        {mso-style-name:s1;
        color:blue;}
.MsoChpDefault
        {mso-style-type:export-only;}
@page WordSection1
        {size:8.5in 11.0in;
        margin:1.0in 1.0in 1.0in 1.0in;}
div.WordSection1
        {page:WordSection1;}
/* List Definitions */
@list l0
        {mso-list-id:2050375782;
        mso-list-type:hybrid;
        mso-list-template-ids:-625209662 943735926 67698691 67698693 67698689 67698691 67698693 67698689 67698691 67698693;}
@list l0:level1
        {mso-level-start-at:424;
        mso-level-number-format:bullet;
        mso-level-text:-;
        mso-level-tab-stop:none;
        mso-level-number-position:left;
        text-indent:-.25in;
        font-family:"Calibri",sans-serif;
        mso-fareast-font-family:Calibri;}
@list l0:level2
        {mso-level-number-format:bullet;
        mso-level-text:o;
        mso-level-tab-stop:none;
        mso-level-number-position:left;
        text-indent:-.25in;
        font-family:"Courier New";}
@list l0:level3
        {mso-level-number-format:bullet;
        mso-level-text:;
        mso-level-tab-stop:none;
        mso-level-number-position:left;
        text-indent:-.25in;
        font-family:Wingdings;}
@list l0:level4
        {mso-level-number-format:bullet;
        mso-level-text:;
        mso-level-tab-stop:none;
        mso-level-number-position:left;
        text-indent:-.25in;
        font-family:Symbol;}
@list l0:level5
        {mso-level-number-format:bullet;
        mso-level-text:o;
        mso-level-tab-stop:none;
        mso-level-number-position:left;
        text-indent:-.25in;
        font-family:"Courier New";}
@list l0:level6
        {mso-level-number-format:bullet;
        mso-level-text:;
        mso-level-tab-stop:none;
        mso-level-number-position:left;
        text-indent:-.25in;
        font-family:Wingdings;}
@list l0:level7
        {mso-level-number-format:bullet;
        mso-level-text:;
        mso-level-tab-stop:none;
        mso-level-number-position:left;
        text-indent:-.25in;
        font-family:Symbol;}
@list l0:level8
        {mso-level-number-format:bullet;
        mso-level-text:o;
        mso-level-tab-stop:none;
        mso-level-number-position:left;
        text-indent:-.25in;
        font-family:"Courier New";}
@list l0:level9
        {mso-level-number-format:bullet;
        mso-level-text:;
        mso-level-tab-stop:none;
        mso-level-number-position:left;
        text-indent:-.25in;
        font-family:Wingdings;}
ol
        {margin-bottom:0in;}
ul
        {margin-bottom:0in;}
--></style>
</head>
<body lang="EN-US" link="#0563C1" vlink="#954F72">
<div class="WordSection1">
<p class="MsoNormal"><span style="font-size:11.0pt">HI All,<o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt"><o:p> </o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt">Following up on the Session’s related discussions we had at yesterday’s virtual forum.<o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt"><o:p> </o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt">To review, we discussed three open issues:<o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt"><o:p> </o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt"><a href="https://github.com/mpi-forum/mpi-issues/issues/424">https://github.com/mpi-forum/mpi-issues/issues/424</a>
<br>
- Sessions: need to update sections of standard describing initial error handler<o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt"><o:p> </o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt"><a href="https://github.com/mpi-forum/mpi-issues/issues/434">https://github.com/mpi-forum/mpi-issues/issues/434</a><br>
- Sessions: need to clarify limitations when mixing the sessions model with dynamic process model <o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt"><o:p> </o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt"><a href="https://github.com/mpi-forum/mpi-issues/issues/435">https://github.com/mpi-forum/mpi-issues/issues/435</a><br>
- Is definition of local Session_init + collective Session_finalize pair broken?<o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt"><o:p> </o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt">424 is easy to address and I’ll rebase PR 519 on top of the rc branch and we can maybe get it added to the agenda for next week.<o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt">435 led to lots of lively conversation, but at the end of the day, my takeaway was that this is addressable via careful rewording and additional text plus some examples similar to the ones in 11.2.2 concerning
 MPI_Finalize.<o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt"><o:p> </o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt">I have a problem though with some of the discussion around 434.  I think it’s a big mistake to break with what had been our philosophy to date with sessions – that is don’t potentially break existing programs
 and library stacks.<o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt">The text near the beginning of chapter 11 currently has a blurb about interoperability:<o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt"><o:p> </o:p></span></p>
<p class="p1">An application can<o:p></o:p></p>
<p class="p1">employ both of these Process Models concurrently. In multi-component MPI applications,<o:p></o:p></p>
<p class="p1">for example, a component such as a library can make use of the Sessions Model to instantiate<o:p></o:p></p>
<p class="p1">MPI resources without impacting the rest of the application.<o:p></o:p></p>
<p class="MsoNormal"><span style="font-size:11.0pt"><o:p> </o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt">And this<o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt"><o:p> </o:p></span></p>
<p class="p1">Both of these models also support the Dynamic Process Model (see Section
<span class="s1">11.7</span>), which<o:p></o:p></p>
<p class="p1">provides for the creation and management of additional processes after an MPI application<o:p></o:p></p>
<p class="p1">has been started.<o:p></o:p></p>
<p class="MsoNormal"><span style="font-size:11.0pt"><o:p> </o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt">If we were going to say that a communicator derived via the sessions model can’t be used with MPI_Comm_spawn or MPI_Comm_spawn_multiple then potentially an existing library which under the covers uses these
 functions in its implementation,  would stop working if the consumer of this library’s functionality (which probably involves some kind of input MPI communicator as an initialization argument) was converted to using sessions and supplied a communicator derived
 via the sessions mechanism.  I suspect if we opened a PR to declare that such communicators can’t be used with these spawn functions, then someone will want us to add a function to test whether a communicator was associated with a session.  Then there would
 be questions about MPI_Comm_accept/connect and so on.<o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt"><o:p> </o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt">From an implementor’s point of view, I don’t see any major challenges supporting the dynamic process model with sessions – within the known limitations of having to use the world process model in the spawnee
 processes.<o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt"><o:p> </o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt">I’m most reluctant to start putting in disclaimers and caveats about using communicators derived via the sessions mechanism as it seems to open us up to problems like these.  Note  I think some clarifying
 text about limitations when using the dynamic process model in the context of sessions is definitely warranted, and will work on a PR to add such text to the chapter.
<o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt"><o:p> </o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt">Howard<o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt"><o:p> </o:p></span></p>
<p class="MsoNormal"><span style="font-size:11.0pt">-- <o:p></o:p></span></p>
<div>
<p class="MsoNormal"><span style="font-size:11.0pt"><o:p> </o:p></span></p>
<p class="MsoNormal"><span style="font-size:10.5pt;color:black">Howard Pritchard<o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-size:10.5pt;color:black">HPC-ENV<o:p></o:p></span></p>
<p class="MsoNormal"><span style="font-size:10.5pt;color:black">Los Alamos National Laboratory<o:p></o:p></span></p>
</div>
<p class="MsoNormal"><o:p> </o:p></p>
</div>
</body>
</html>