[mpiwg-abi] MPI_Fint in the ABI

Jeff Hammond jeff.science at gmail.com
Fri Aug 18 05:20:32 CDT 2023


I just realized that option 3 doesn’t work for MPI_Status f2c/c2f, so it must be rejected.  We have to choose 1 or 2.

We are building an ABI to allow people to write libraries that just work with all of the implementations.  This includes enabling programmers to write C libraries that interoperate with arbitrary MPI Fortran code.  This code needs a way to know what MPI_Fint is without interacting with the Fortran environment.  That is why we need to either prescribe the value of MPI_Fint or make it queryable from C code using MPI features.

As far as ABI information, the proposal includes the following:
int MPI_Abi_supported(int *flag)

Int MPI_Abi_version(int *major, int *minor)

int MPI_Abi_sizes(int *aint_size, int *offset_size, int *count_size, int *fint_size)
int MPI_Abi_details(int *buflen, char *details)
My intent with MPI_Abi_details was to allow implementations to disclose their non-standard ABI info there when flag=false.  I’m happy to add an MPI_Info there if people prefer that method of including data.  The struct design you propose isn’t really the MPI Way (TM).  I’m not personally opposed but we don’t have a nice way to expose that in Fortran.

I do not understand the need for MPIABI_info_t.  We have MPI_TYPE_SIZE to query what the size of the MPI types arrow, which is what one needs to know when interacting with the ABI.  Can you describe the use case where non-C code needs to know the size of a C long double, for example?  If Julia is going to pass long double data into MPI, what matters if MPI_LONG_DOUBLE.

Jeff


> On 17. Aug 2023, at 17.35, Erik Schnetter <schnetter at gmail.com> wrote:
> 
> Jeff
> 
> As per the Fortran standard, the sizes of integer and real need to be
> the same. In practice this means that integers have 4 bytes. If
> someone chooses to change this – either changing the size of real as
> well or not – then they are breaking the Fortran standard, and
> probably know what they are doing, and are aware of the various
> incompatibilities and problems this will introduce. I would thus
> suggest keeping things simple for the common case. I would not expect
> there to be some code that interoperates with Fortran, and which is
> unaware of the Fortran integer size and still expects to get things
> right. People will either assume that integer = int, or will know the
> Fortran ABI details.
> 
> In the MPI ABI we assume that the caller knows sizeof(int) and
> sizeof(void*), and I would also assume that they know sizeof(integer).
> I would keep `MPI_Fint` a fixed type.
> 
> To cover all bases I also suggest that we provide a global constant
> struct with as much ABI information as we can think of, such as
> 
> const struct MPIABI_info_t {
>  int32_t MPIABI_version_major, MPIABI_version_minor;
>  int32_t sizeof_bool;
>  int32_t sizeof_char;
>  int32_t sizeof_short;
>  int32_t sizeof_int;
>  int32_t sizeof_long;
>  int32_t sizeof_long_long;
>  int32_t sizeof_float;
>  int32_t sizeof_double;
>  int32_t sizeof_long_double;
>  int32_t sizeof_void_p;
>  int32_t sizeof_logical;
>  int32_t sizeof_integer;
>  int32_t sizeof_real;
>  int32_t sizeof_char;
> } MPIABI_info;
> 
> This information would not be necessary to use the ABI, but it will be
> convenient to check assumptions. Unsupported types report a size of
> -1.
> 
> This struct can be extended in the future.
> 
> -erik
> 
> On Wed, Aug 16, 2023 at 4:09 AM Jeff Hammond <jeff.science at gmail.com> wrote:
>> 
>> As we all know, Fortran users are permitted to change the size of INTEGER with compiler flags.  This creates a problem for the MPI C ABI.
>> 
>> I have considered three options and would like your opinions on them:
>> 
>> 1. MPI_Fint is defined to be a C int in the standard ABI.  This means MPI implementations that elect to provide an ILP64 MPI Fortran ABI on an I32LP64 system, for example, must not call this an implementation of the standard ABI.
>> 
>> This would make a lot of things easier, but it might cause problems in the rare cases where users are using ILP64 in Fortran and using C code that actually uses MPI_Fint.
>> 
>> 2. MPI_Fint ceases to be a compile-time fixed type in the standard ABI.  The C code that uses MPI_Fint must make an MPI library call to figure out the size and do all of the necessary things to call the correct size.
>> 
>> 3. MPI_Fint is not a fixed size but the standard ABI specifies that Fortran handle values must always fit into the range of a C int and we rely on the pass-by-value behavior of all the f2c/c2f APIs to behave properly when they are truncated.
>> 
>> This is my preference but it breaks Example 19.11 in a serious way, because that user code makes use of a MPI_Fint pointer.  However, this code isn't standard-compliant and relies on universal but non-standard argument passing conventions in Fortran.  Writing a standard-compliant interface from Fortran to C - by doing the cast to INTEGER(kind=c_int) in Fortran - would resolve this.
>> 
>> Example 19.11 is awful (https://github.com/mpi-forum/mpi-issues/issues/739) but it is nonetheless important to instruct users that if Option 3 is implemented, they need to do the casting to INTEGER(kind=c_int) and know that this is safe with the standard ABI.
>> 
>> 
>> None of these options is perfect.  I'm not sure how much code is even impacted by MPI_Fint so it's hard to know which option breaks the most stuff, although Option 2 seems the least desirable in any case.
>> 
>> Thanks,
>> 
>> Jeff
>> 
>> --
>> Jeff Hammond
>> jeff.science at gmail.com
>> http://jeffhammond.github.io/
>> --
>> mpiwg-abi mailing list
>> mpiwg-abi at lists.mpi-forum.org
>> https://lists.mpi-forum.org/mailman/listinfo/mpiwg-abi
> 
> 
> 
> -- 
> Erik Schnetter <schnetter at gmail.com>
> http://www.perimeterinstitute.ca/personal/eschnetter/

-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.mpi-forum.org/pipermail/mpiwg-abi/attachments/20230818/c2df6f72/attachment-0001.html>


More information about the mpiwg-abi mailing list