<div dir="ltr"><div class="gmail_default" style="font-size:small">No I certainly do not hope so, </div><div class="gmail_default" style="font-size:small"><br></div><div class="gmail_default" style="font-size:small">I would suggest that only an MPI implementation with a "pedantic" mode would check for this. For any production level implementation the check for MPI_PROC_NULL (if present in the implementation) will be sufficient. If MPI_TAG_NULL is provided with a valid processor argument (against the suggested standard wording) the probe code will run through all pending messages and not find any matching tag since MPI_TAG_NULL is not inside the 0..MPI_TAG_UB range. Just as a probe for MPI_PROC_NULL today could (should?) be scanning all messages. </div><div class="gmail_default" style="font-size:small"><br></div><div class="gmail_default" style="font-size:small">Probes with either MPI_PROC_NULL or MPI_TAG_NONE should not need fast lanes. Let them suffer by checking every message and find that there is nothing for them. Then, if you are nice, you can raise an error before returning.</div><div class="gmail_default" style="font-size:small"><br></div><div class="gmail_default" style="font-size:small">If tags are implemented as signed integers MPI_TAG_NULL would most likely be implemented as a negative value (which by the standard is not in the valid tag range). If tags are implemented using unsigned int values, the implementation could set MPI_TAG_NULL to "huge(unsigned 0)" and MPI_TAB_UB to MPI_TAG_NULL-1. Either way it should not break existing implementations (famous last words, I know...).</div><div class="gmail_default" style="font-size:small"><br></div><div class="gmail_default" style="font-size:small"> </div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Fri, Oct 22, 2021 at 3:02 PM Rolf Rabenseifner <<a href="mailto:rabenseifner@hlrs.de">rabenseifner@hlrs.de</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">Do I understand correctly, that this proposal must add an additional <br>
lateny (internal if statement) to MPI_PROBE for *all* messages<br>
and also in most implementations (that do not want to ignore the error-checking <br>
when MPI_TAG_NULL is passed) for *all* point-to-point messages,<br>
but<br>
it this new MPI_TAG_NULL feature may be rearely used and extremly rarely used<br>
in MPI_PROBE?<br>
<br>
----- Original Message -----<br>
> From: "Comments on the MPI Standard" <<a href="mailto:mpi-comments@lists.mpi-forum.org" target="_blank">mpi-comments@lists.mpi-forum.org</a>><br>
> To: "Comments on the MPI Standard" <<a href="mailto:mpi-comments@lists.mpi-forum.org" target="_blank">mpi-comments@lists.mpi-forum.org</a>><br>
> Cc: "Nils Smeds" <<a href="mailto:nils.smeds@gmail.com" target="_blank">nils.smeds@gmail.com</a>><br>
> Sent: Friday, October 22, 2021 2:33:36 PM<br>
> Subject: Re: [Mpi-comments] Pt2pt messaging with MPI_PROC_NULL (and MPI_TAG_NULL, MPI_ADDRESS_NULL)<br>
<br>
> Dan,<br>
> <br>
> Thank you for your encouraging response.<br>
> <br>
> Firstly, let me state that I have no strong feelings for either MPI_ADDRESS_NULL<br>
> nor MPI_COMM_NULL other than they would satisfy my sense of "symmetry" or<br>
> "closure". In my own programming I rarely find myself unclear what buffer<br>
> address or communicator a specific code section is targeting. Most often it is<br>
> the pt2pt matching triad (proc,tag,comm) that needs to be tailored to express<br>
> the "intent" of the code so that an unimplemented fringe case does not pass by<br>
> unnoticed. (Merely causes a dead-lock - as if that is any help - I know...)<br>
> <br>
> My view of the MPI_*_NULL entities in the standard is that they are comparable<br>
> to NaN in floating point. MPI_TAG_NULL is not a member of the set of valid<br>
> tags, and can not be matched in any tag comparison operation, not even itself<br>
> or as "not a member of". MPI_TAG_ANY should not match a message with<br>
> MPI_TAG_NULL, and there should indeed be no way to create a "real" message with<br>
> MPI_TAG_NULL. So a statement as you suggested<br>
> <br>
> <br>
> <br>
> " W hen the tag argument is MPI_TAG_NULL the only allowed processor argument is<br>
> MPI_PROC_NULL"<br>
> <br>
> preferably in section 3.2.4 just before the last sentence describing the use of<br>
> dest=MPI_PROC_NULL would be all that is needed. A probe for such a message<br>
> (that can never be created as a "real" message) will thus return a status<br>
> object with a count of 0 and a tag of MPI_TAG_ANY and no change in behaviour to<br>
> existing implementations.<br>
> <br>
> So the updated suggested changes to the standards are:<br>
> <br>
>    1.<br>
> Insert into appendix "A1 Assorted constants": MPI_TAG_NULL<br>
> <br>
>    2.<br>
> Insert into section "9.1.2 Environmental Inquiries"<br>
> <br>
> <br>
> <br>
> (Line 34, end of first paragraph) [... is also a valid value for MPITAG_UB]. The<br>
> constant MPI_TAG_NULL shall have a value outside of the 0...MPI_TAG_UB range.<br>
> <br>
>    3.<br>
> Insert into section 3.2.4 before the last sentence (line 42.5):<br>
> <br>
> " W hen the tag argument is MPI_TAG_NULL the only allowed processor argument is<br>
> MPI_PROC_NULL"<br>
> <br>
>    4.<br>
> Add to section 3.10 "Null processes", last in the section:<br>
> <br>
> " Advice to users: Note that MPI_TAG_NULL is not a valid tag in the<br>
> 0..MPI_TAG_UB range. Thus MPI_TAG_NULL is only allowed when the associated<br>
> processor argument is MPI_PROC_NULL"<br>
> <br>
> To avoid a lengthy discussion into what probes of non-existing messages should<br>
> return as a result, I suggest that the committee sees any triad (proc,tag,comm)<br>
> where either component has a "NULL" value as defined in the standard (currently<br>
> only MPI_PROC_NULL exists) is in essence a "NaN"-triad, and returns the already<br>
> defined result of 0 elements of (MPI_PROC_NULL,MPI_ANY_TAG) as of section 3.10.<br>
> Also, just by chance, this would not conflict with an introduction of an<br>
> MPI_COMM_NULL item in the future.<br>
> <br>
> <br>
> <br>
> On Thu, Oct 21, 2021 at 7:14 PM Dan Holmes <danholmes@chi.scot> wrote:<br>
> <br>
> <br>
> <br>
> Hi Nils,<br>
> <br>
> In general, I like the idea of having default/invalid values for these<br>
> MPI-related user variables.<br>
> <br>
> Would MPI_TAG_NULL be valid for a point-to-point send operation that does NOT<br>
> use MPI_PROC_NULL but is matched with receive operation at the destination MPI<br>
> process that uses MPI_ANY_TAG? Or should this be an MPI_ERR_ARG/MPI_ERR_TAG<br>
> error condition? Commonly, codes that use MPI_ANY_TAG in receive operations<br>
> must choose an arbitrary valid tag value to use in the send operations at the<br>
> source MPI process(es). Permitting the use of MPI_TAG_NULL in combination with<br>
> MPI_ANY_TAG might aid debugging when the matching does not go the way the user<br>
> expected. However, it would add complexity to the matching<br>
> rules/implementation. There is an interaction here with INFO key assertions<br>
> such as `mpi_assert_no_any_tag` — which means the error could be discovered at<br>
> the sender process -- and `mpi_assert_only_any_tag` (if that one ever gets<br>
> accepted into MPI).<br>
> <br>
> There is already an MPI constant that is commonly set to `(void*)0` (in C),<br>
> which is MPI_BOTTOM. Defining MPI_ADDRESS_NULL to be the same value is not a<br>
> good idea because MPI_BOTTOM is a valid address; although attempting to<br>
> read/write at that address is likely to cause trouble, using it as a base for a<br>
> user-defined datatype or a window offset is common/accepted practice. Would it<br>
> be sufficient for your purposes to use MPI_BOTTOM as your “not valid” value?<br>
> <br>
> IMHO, there would need to be a statement that, “when the comm argument is<br>
> MPI_COMM_NULL, the only acceptable value for the source/dest argument is<br>
> MPI_PROC_NULL” because asking for the 3rd item from an empty set (for example)<br>
> is clearly an error. Your proposal tries to treat MPI_COMM_NULL as if it is a<br>
> valid MPI intra-communicator that has size zero, or a valid inter-communicator<br>
> that has a remote group of size zero. I think I would prefer to create<br>
> MPI_COMM_EMPTY for that purpose, and continue to use MPI_COMM_NULL for<br>
> situations that call for an invalid communicator, i.e. something that can never<br>
> be used as a communicator without causing an error condition.<br>
> <br>
> The phrase used elsewhere in the MPI Standard is “XYZ parameter is significant<br>
> only <when condition>”<br>
> <br>
> Cheers,<br>
> Dan.<br>
> —<br>
> Dr Daniel Holmes PhD<br>
> Executive Director<br>
> Chief Technology Officer<br>
> CHI Ltd<br>
> [ mailto:<a href="mailto:danholmes@chi.scot" target="_blank">danholmes@chi.scot</a> | danholmes@chi.scot ]<br>
> <br>
> <br>
> <br>
> <br>
> <br>
> <br>
> On 21 Oct 2021, at 11:35, Nils Smeds via mpi-comments < [<br>
> mailto:<a href="mailto:mpi-comments@lists.mpi-forum.org" target="_blank">mpi-comments@lists.mpi-forum.org</a> | <a href="mailto:mpi-comments@lists.mpi-forum.org" target="_blank">mpi-comments@lists.mpi-forum.org</a> ] ><br>
> wrote:<br>
> <br>
> Summary:<br>
> - Suggestion to introduce MPI_TAG_NULL in the standard with an obviously illegal<br>
> value (i.e. <0)<br>
> - Explicitly allow Point-to-Point messages to have one of more of: tag<br>
> MPI_TAG_NULL, datatype MPI_DATATYPE_NULL, invalid buffer addresses (including<br>
> MPI_ADDRESS_NULL) and communicator MPI_COMM_NULL, if (and only if) the<br>
> corresponding send or receive argument is MPI_PROC_NULL.<br>
> <br>
> Argument:<br>
> When writing code it is useful if it goes off with a bang when you do something<br>
> wrong. To catch matching errors in sends and receives I looked for a<br>
> MPI_TAG_NULL to use as a default value to catch cases where the tag was not set<br>
> correctly. I found that there was no such item. Referring to the standard I<br>
> found that tag values are restricted to the values 0...MPI_TAG_UB, where<br>
> MPI_TAG_UB (>=32767) can be found using the MPI_Comm_get_attr() function.<br>
> <br>
> So I used my own value for MPI_TAG_NULL as -1 and coded away. However, the MPI<br>
> implementation I was using blew up when I used it in a MPI_Sendrecv with the<br>
> remote task being MPI_PROC_NULL throwing an error message "illegal tag value",<br>
> which was no surprise to me since I had set it to this value explicitly.<br>
> <br>
> The workaround is of course to put a if( PartnerTask != MPI_PROC_NULL ) { ... }<br>
> around every point-to-point call, but I find it unnecessary and makes the code<br>
> look more complex. I think that MPI_PROC_NULL was invented for exactly this<br>
> purpose, to be a transparent if(...) clause for the operation. Is there really<br>
> a need to be restrictive on datat ype, tag or any other argument when the P2P<br>
> operation is with MPI_PROC_NULL?<br>
> <br>
> I would expect implementations to choose MPI_ADDRESS_NULL be equal to (*) 0 in C<br>
> and 0_MPI_ADDRESS_KIND in Fortran and MPI_TAG_NULL to be default integer kind<br>
> -1.<br>
> <br>
> Implementation:<br>
> Append to section "3.10 Null processes" text along the lines of:<br>
> <br>
> <br>
> <br>
> A call to any point-to-point messaging function with a process argument of<br>
> MPI_PROC_NULL is allowed to have any value for buffer address, data type, tag<br>
> and communicator including MPI_ADDRESS_NULL, MPI_DATATYPE_NULL, MPI_TAG_NULL<br>
> and MPI_COMM_NULL without causing an error condition in the execution.<br>
> <br>
> Insert into appendix "A1 Assorted constants"<br>
> <br>
> <br>
> <br>
> MPI_TAG_NULL and MPI_ADDRESS_NULL<br>
> <br>
> Insert into section "9.1.2 Environmental Inquiries" (which is an odd place where<br>
> Tag values are specified in the standard):<br>
> <br>
> <br>
> <br>
> (Line 34, end of first paragraph) [... is also a valid value for MPITAG_UB]. The<br>
> constant MPI_TAG_NULL shall have a value outside of the 0...MPI_TAG_UB range.<br>
> The value MPI_TAG_NULL is erroneous to use in any communication unless the<br>
> associated process argument is MPI_PROC_NULL.<br>
> <br>
> Add to section "15.3.3 Convention for Returning Strings"<br>
> <br>
> <br>
> <br>
> The constant MPI_ADDRESS_NULL can be used as an equivalent to the null pointer.<br>
> <br>
> <br>
> <br>
> /Nils Smeds<br>
> <br>
> _______________________________________________<br>
> mpi-comments mailing list<br>
> [ mailto:<a href="mailto:mpi-comments@lists.mpi-forum.org" target="_blank">mpi-comments@lists.mpi-forum.org</a> | <a href="mailto:mpi-comments@lists.mpi-forum.org" target="_blank">mpi-comments@lists.mpi-forum.org</a> ]<br>
> [ <a href="https://lists.mpi-forum.org/mailman/listinfo/mpi-comments" rel="noreferrer" target="_blank">https://lists.mpi-forum.org/mailman/listinfo/mpi-comments</a> |<br>
> <a href="https://lists.mpi-forum.org/mailman/listinfo/mpi-comments" rel="noreferrer" target="_blank">https://lists.mpi-forum.org/mailman/listinfo/mpi-comments</a> ]<br>
> <br>
> <br>
> _______________________________________________<br>
> mpi-comments mailing list<br>
> <a href="mailto:mpi-comments@lists.mpi-forum.org" target="_blank">mpi-comments@lists.mpi-forum.org</a><br>
> <a href="https://lists.mpi-forum.org/mailman/listinfo/mpi-comments" rel="noreferrer" target="_blank">https://lists.mpi-forum.org/mailman/listinfo/mpi-comments</a><br>
<br>
-- <br>
Dr. Rolf Rabenseifner . . . . . . . . . .. email <a href="mailto:rabenseifner@hlrs.de" target="_blank">rabenseifner@hlrs.de</a> .<br>
High Performance Computing Center (HLRS) . phone ++49(0)711/685-65530 .<br>
University of Stuttgart . . . . . . . . .. fax ++49(0)711 / 685-65832 .<br>
Head of Dpmt Parallel Computing . . . <a href="http://www.hlrs.de/people/rabenseifner" rel="noreferrer" target="_blank">www.hlrs.de/people/rabenseifner</a> .<br>
Nobelstr. 19, D-70550 Stuttgart, Germany . . . . (Office: Room 1.307) .<br>
</blockquote></div>