1
1

Merge pull request #3822 from tjcw/tjcw-fix-mpi-sizeof

Fix MPI_SIZEOF for gfortran 4.8
Этот коммит содержится в:
Jeff Squyres 2017-07-07 13:49:52 -04:00 коммит произвёл GitHub
родитель b2f90e5d1b 3e6a196714
Коммит 83746fba71
3 изменённых файлов: 16 добавлений и 6 удалений

10
README
Просмотреть файл

@ -19,6 +19,7 @@ Copyright (c) 2013-2015 Intel, Inc. All rights reserved
Copyright (c) 2015 NVIDIA Corporation. All rights reserved.
Copyright (c) 2017 Los Alamos National Security, LLC. All rights
reserved.
Copyright (c) 2017 IBM Corporation. All rights reserved
$COPYRIGHT$
@ -370,8 +371,13 @@ Compiler Notes
- All Fortran compilers support the mpif.h/shmem.fh-based bindings,
with one exception: the MPI_SIZEOF interfaces will only be present
when Open MPI is built with a Fortran compiler that support the
INTERFACE keyword and ISO_FORTRAN_ENV. Most notably, this
excludes the GNU Fortran compiler suite before version 4.9.
INTERFACE keyword and ISO_FORTRAN_ENV.
*** The Open MPI team has not tested to determine exactly which
version of the GNU Fortran compiler suite started supporting
what is required for MPI_SIZEOF. We know that gfortran v4.8
(bundled in RHEL 7.x) supports the MPI_SIZEOF interfaces.
However, gfortran 4.4 (bundled in RHEL 6.x) does not.
- The level of support provided by the mpi module is based on your
Fortran compiler.

Просмотреть файл

@ -11,6 +11,7 @@ dnl University of Stuttgart. All rights reserved.
dnl Copyright (c) 2004-2005 The Regents of the University of California.
dnl All rights reserved.
dnl Copyright (c) 2010-2014 Cisco Systems, Inc. All rights reserved.
dnl Copyright (c) 2017 IBM Corporation. All rights reserved.
dnl $COPYRIGHT$
dnl
dnl Additional copyrights may follow
@ -61,7 +62,7 @@ SUBROUTINE storage_size_complex32_r1(x, size)
COMPLEX(REAL32), DIMENSION(*)::x
INTEGER, INTENT(OUT) :: size
size = storage_size(x) / 8
size = storage_size(x(1)) / 8
END SUBROUTINE storage_size_complex32_r1
SUBROUTINE storage_size_int32_scalar(x, size)
@ -77,7 +78,7 @@ SUBROUTINE storage_size_int32_r1(x, size)
INTEGER(INT32), DIMENSION(*)::x
INTEGER, INTENT(OUT) :: size
size = storage_size(x) / 8
size = storage_size(x(1)) / 8
END SUBROUTINE storage_size_int32_r1
SUBROUTINE storage_size_real32_scalar(x, size)
@ -93,7 +94,7 @@ SUBROUTINE storage_size_real32_r1(x, size)
REAL(REAL32), DIMENSION(*)::x
INTEGER, INTENT(OUT) :: size
size = storage_size(x) / 8
size = storage_size(x(1)) / 8
END SUBROUTINE storage_size_real32_r1
]])],
[AS_VAR_SET(fortran_storage_size_var, yes)],

Просмотреть файл

@ -3,6 +3,7 @@
# Copyright (c) 2014-2015 Cisco Systems, Inc. All rights reserved.
# Copyright (c) 2015 Research Organization for Information Science
# and Technology (RIST). All rights reserved.
# Copyright (c) 2017 IBM Corporation. All rights reserved.
# $COPYRIGHT$
#
# Script to generate the overloaded MPI_SIZEOF interfaces and
@ -97,7 +98,7 @@ sub queue_sub {
${indent} INTEGER, INTENT(OUT) :: size
${indent} INTEGER$optional_ierror_param, INTENT(OUT) :: ierror";
$subr->{start} = $start;
$subr->{middle} = "${indent} size = storage_size(x) / 8
$subr->{middle} = "${indent} size = storage_size(xSUBSCRIPT) / 8
${indent} ${optional_ierror_statement}ierror = 0";
$subr->{end} = "${indent}END SUBROUTINE ^PREFIX^$sub_name^RANK^";
@ -126,6 +127,7 @@ sub generate {
if (0 == $rank) {
$str =~ s/\^RANK\^/_scalar/g;
$str =~ s/\^DIMENSION\^//;
$str =~ s/SUBSCRIPT//;
} else {
$str =~ s/\^RANK\^/_r$rank/g;
my $dim;
@ -135,6 +137,7 @@ sub generate {
--$d;
}
$str =~ s/\^DIMENSION\^/, DIMENSION($dim*)/;
$str =~ s/SUBSCRIPT/($dim 1)/;
}
# All done