<html><head></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space; "><div>Unfortunately Bill may have a point (though it pains me greatly to admit to this :-).</div><div><br></div><div>Tobias' original acceptable possibilities are (with comments):</div><div><br></div><div>(a) LOGICAL(C_Bool)</div><div><br></div><div>This would require modifying the MPI-3 standard.</div><div><br></div><div>(c) Using LOGICAL without BIND(C)</div><div><br></div><div>This is attractive from the purely Fortran perspective but it breaks the interface for the MPI tools.</div><div><br></div><div>(4d) Last, handling dummy arguments/result variables of BIND(C) procedures differently. That probably would work, but it requires a bunch of the careful addition of additional constraints. For instance, to prohibit the TARGET/POINTER attribute for those.</div><div><br></div><div>This would require changes in the Fortran standard. Who knows if this is possible to accomplish or when it would occur, if at all.</div><div><br></div><div>Thus it seems to me that (a) is really the only option.</div><div><br></div><div>In general the MPI-3 interfaces were written to make it relatively painless for existing codes to be upgraded. Thus default INTEGER and default LOGICAL dummy argument types were not changed. However, it will be necessary for users to change integer handles like MPI_COMM to derived types like TYPE(MPI_COMM). We could additionally require them to change LOGICAL to LOGICAL(C_Bool).</div><div><br></div><div>As I count there are only 31 MPI routines that use LOGICAL arguments. It doesn't seem too onerous to require programmers to switch to LOGICAL(C_Bool). We could even provide constants like MPI_TRUE and MPI_FALSE for convenience.</div><div><br></div><div>Rolf, I assume you are paying attention to this thread, could you comment? In particular, what about (evil) users who stuff everything in common blocks.</div><br><div apple-content-edited="true">
<span class="Apple-style-span" style="border-collapse: separate; color: rgb(0, 0, 0); font-family: Helvetica; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; line-height: normal; orphans: 2; text-align: -webkit-auto; text-indent: 0px; text-transform: none; white-space: normal; widows: 2; word-spacing: 0px; -webkit-border-horizontal-spacing: 0px; -webkit-border-vertical-spacing: 0px; -webkit-text-decorations-in-effect: none; -webkit-text-size-adjust: auto; -webkit-text-stroke-width: 0px; font-size: medium; "><span class="Apple-style-span" style="border-collapse: separate; color: rgb(0, 0, 0); font-family: Helvetica; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; line-height: normal; orphans: 2; text-align: -webkit-auto; text-indent: 0px; text-transform: none; white-space: normal; widows: 2; word-spacing: 0px; -webkit-border-horizontal-spacing: 0px; -webkit-border-vertical-spacing: 0px; -webkit-text-decorations-in-effect: none; -webkit-text-size-adjust: auto; -webkit-text-stroke-width: 0px; font-size: medium; "><div style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space; "><div>Craig Rasmussen</div><div>CAS Scientific Programmer</div><div><a href="mailto:rasmus@cas.uoregon.edu">rasmus@cas.uoregon.edu</a></div><div><br></div></div></span><br class="Apple-interchange-newline"></span><br class="Apple-interchange-newline">
</div>
<br><div><div>On Feb 28, 2013, at 12:52 PM, Bill Long wrote:</div><br class="Apple-interchange-newline"><blockquote type="cite"><div>In C when any scalar value is converted to _Bool, the result is 0 if the value compares equal to 0; otherwise the result is 1. (6.3.1.3 Boolean type).<br><br>The value of C_BOOL as a Fortran KIND type for LOGICAL is such that<br><br>1) The bitsize of LOGICAL(C_BOOL) matches the bitsize of _Bool in C for the companion processor.<br><br>2) The Fortran processor uses the internal bit pattern in LOGICAL (C_BOOL) of 0 to represent false, and 1 to represent true.<br><br>If both of these is true (which is the case for many implementations) then C_BOOL > 0. Otherwise C_BOOL will be negative, and there is no interoperability with C for LOGICAL.<br><br><br>The fatal flaw in the MPI interface here is that the corresponding C formal parameter is not _Bool or anything that looks like LOGICAL. Instead it is 'int'.<br><br>There is no concept of a Fortran argument of type LOGICAL interoperating with a C formal parameter of type int. Usage of that sort in an MPI interface is simply wrong. One side or the other of the call needs to be fixed. I would vote for changing the Fortran side to be type INTEGER(C_INT).<br><br>Cheers,<br>Bill<br><br><br><br>On 2/28/13 12:29 PM, Craig Rasmussen wrote:<br><blockquote type="cite"><br></blockquote><blockquote type="cite">Ack....<br></blockquote><blockquote type="cite"><br></blockquote><blockquote type="cite">I just did a quick rereading of clause 15, Interoperability with C, and<br></blockquote><blockquote type="cite">it appears ill defined to me. Consider the following:<br></blockquote><blockquote type="cite"><br></blockquote><blockquote type="cite">1. Suppose a compiler has a default logical size equivalent to a default<br></blockquote><blockquote type="cite">integer. Since the standard only requires one logical kind, this<br></blockquote><blockquote type="cite">compiler may not have a type that is interoperable with a _Bool C type.<br></blockquote><blockquote type="cite"> In this instance C_BOOL would be a negative value.<br></blockquote><blockquote type="cite">2. If a compiler does support LOGICAL(kind=C_BOOL), what values of a C<br></blockquote><blockquote type="cite">type _Bool map to .TRUE.? What values map to .FALSE.? These mappings<br></blockquote><blockquote type="cite">may be in clause 15 but I didn't see them at first glance.<br></blockquote><blockquote type="cite">3. Suppose a Fortran compiler has the following mapping:<br></blockquote><blockquote type="cite"><br></blockquote><blockquote type="cite"> _Bool flag = 0; /* flag maps to .FALSE. */<br></blockquote><blockquote type="cite"><br></blockquote><blockquote type="cite"> if (flag != 0) ...; /* flag maps to .TRUE. */<br></blockquote><blockquote type="cite"><br></blockquote><blockquote type="cite">This seems to me to be the sane way to map values from C to Fortran.<br></blockquote><blockquote type="cite"> The same mapping can be done for any C integer type to an equivalently<br></blockquote><blockquote type="cite">sized Fortran LOGICAL.<br></blockquote><blockquote type="cite"><br></blockquote><br>-- <br>Bill Long <a href="mailto:longb@cray.com">longb@cray.com</a><br>Fortran Technical Support & voice: 651-605-9024<br>Bioinformatics Software Development fax: 651-605-9142<br>Cray Inc./Cray Plaza, Suite 210/380 Jackson St./St. Paul, MN 55101<br><br><br>_______________________________________________<br>mpi3-fortran mailing list<br><a href="mailto:mpi3-fortran@lists.mpi-forum.org">mpi3-fortran@lists.mpi-forum.org</a><br>http://lists.mpi-forum.org/mailman/listinfo.cgi/mpi3-fortran<br></div></blockquote></div><br></body></html>