<html><head><meta http-equiv="content-type" content="text/html; charset=utf-8"></head><body style="overflow-wrap: break-word; -webkit-nbsp-mode: space; line-break: after-white-space;"><div>"All MPI calls are thread-safe, i.e., two concurrently running threads may make MPI calls and the outcome will be as if the calls executed in some order, even if their execution is interleaved."</div><div><br></div>I’m going to continue to die on the hill that “as if executed in some order” constrains the implementation behavior to something equivalent to “MPI operations are initiated atomically” because otherwise one cannot be guaranteed that some ordering exists. The text about logically concurrent merely explains the obvious to users: it is impossible to know in what order unsynchronized threads execute operations. The previous sentence makes it clear what is meant by logically concurrent, and it is consistent with Chapter 11, i.e. it logically unordered:<div><br></div><div>“...if the process is multithreaded, then the <u>semantics of thread execution may not define a relative order between two send operations executed by two distinct threads</u>. The operations are logically concurrent..."<div><br>I can’t provide the full history of the Intel instruction <a href="https://community.intel.com/legacyfs/online/drupal_files/managed/c5/15/architecture-instruction-set-extensions-programming-reference.pdf">ENQCMD</a> but it appears to address the problem of a large number of semi-independent HW units initiating MPI operations in a manner compliant with the text above.<br></div><div><br></div><div>As I have stated previously, it is possible to relax the constraint “as if executed in some order” with the addition of a new threading level, which Pavan proposed years ago as <a href="https://github.com/mpiwg-sessions/sessions-issues/wiki/2016-06-07-forum#notes-from-meeting-bold--specific-work-to-do">MPI_THREAD_CONCURRENT</a> (although details are impossible to find at this point).<br><div><br></div><div>Jeff<br><br><blockquote type="cite">On 9. May 2023, at 17.41, Holmes, Daniel John via mpiwg-hybridpm <mpiwg-hybridpm@lists.mpi-forum.org> wrote:<br><br class="Apple-interchange-newline">Hi all,<br> Unfortunately, I am double-booked for tomorrow’s HACC WG time slot – so my answer to the implied question below is “not yet”.<br> The “logically concurrent isn’t” issue #117 is now accepted and merged into MPI-4.1 (take a moment to celebrate!) – but it just says “here be dragons”.<br> Do we care enough to defeat those dragons?<br> Argument FOR: as systems become more heterogeneous, an MPI process is likely to abstractly “contain” more semi-independent HW units that will want to communicate with other MPI processes, which will result in lots of logically concurrent MPI communication operations – exactly the territory in which these dragons live.<br> Argument AGAINST: we’ve been throwing brave warriors into this particular dragon fire for about a decade and we’ve only now convinced ourselves that the dragons do, in fact, exist. How many more volunteers do we have and do they have sufficiently pointy sticks?<br> Best wishes,<br>Dan.<br> From: mpiwg-hybridpm <mpiwg-hybridpm-bounces@lists.mpi-forum.org> On Behalf Of Jim Dinan via mpiwg-hybridpm<br>Sent: 09 May 2023 15:15<br>To: Hybrid working group mailing list <mpiwg-hybridpm@lists.mpi-forum.org><br>Cc: Jim Dinan <james.dinan@gmail.com><br>Subject: [mpiwg-hybridpm] Meeting Tomorrow<br> Hi All,<br> We had to reschedule the topic planned for tomorrow's meeting, so the agenda is now open. Please let me know if you have a topic you'd like to discuss. If we don't have a topic ahead of time, we will cancel.<br> Thanks,<br> ~Jim.<br>_______________________________________________<br>mpiwg-hybridpm mailing list<br>mpiwg-hybridpm@lists.mpi-forum.org<br>https://lists.mpi-forum.org/mailman/listinfo/mpiwg-hybridpm</blockquote><br><br></div></div></div></body></html>