1
1

Merge pull request #3843 from jjhursey/revert/gfortran-sizeof

Revert MPI_SIZEOF fix for gfortran 4.8
Этот коммит содержится в:
Geoff Paulsen 2017-07-11 14:10:19 -05:00 коммит произвёл GitHub
родитель 550e8c4afe 20ac03c063
Коммит 6570374238
3 изменённых файлов: 18 добавлений и 16 удалений

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

@ -19,7 +19,6 @@ Copyright (c) 2013-2015 Intel, Inc. All rights reserved
Copyright (c) 2015 NVIDIA Corporation. All rights reserved. Copyright (c) 2015 NVIDIA Corporation. All rights reserved.
Copyright (c) 2017 Los Alamos National Security, LLC. All rights Copyright (c) 2017 Los Alamos National Security, LLC. All rights
reserved. reserved.
Copyright (c) 2017 IBM Corporation. All rights reserved
$COPYRIGHT$ $COPYRIGHT$
@ -371,13 +370,8 @@ Compiler Notes
- All Fortran compilers support the mpif.h/shmem.fh-based bindings, - All Fortran compilers support the mpif.h/shmem.fh-based bindings,
with one exception: the MPI_SIZEOF interfaces will only be present with one exception: the MPI_SIZEOF interfaces will only be present
when Open MPI is built with a Fortran compiler that support the when Open MPI is built with a Fortran compiler that support the
INTERFACE keyword and ISO_FORTRAN_ENV. INTERFACE keyword and ISO_FORTRAN_ENV. Most notably, this
excludes the GNU Fortran compiler suite before version 4.9.
*** 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 - The level of support provided by the mpi module is based on your
Fortran compiler. Fortran compiler.

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

@ -28,6 +28,17 @@ dnl
AC_DEFUN([OMPI_FORTRAN_CHECK_STORAGE_SIZE],[ AC_DEFUN([OMPI_FORTRAN_CHECK_STORAGE_SIZE],[
AS_VAR_PUSHDEF([fortran_storage_size_var], [ompi_cv_fortran_have_storage_size]) AS_VAR_PUSHDEF([fortran_storage_size_var], [ompi_cv_fortran_have_storage_size])
# Re PR: https://github.com/open-mpi/ompi/pull/3822
# We explored correcting the following syntax to compile with gfortran 4.8
# - size = storage_size(x) / 8
# + size = storage_size(x(1)) / 8
# That allowed gfortran 4.8 to pass this configure test, but fail to
# correctly handle mpi_sizeof due to the weak test for INTERFACE in
# ompi_fortran_check_interface.m4. Until we can strengthen that configure
# check we reverted the commit from PR #3822 to keep the old logic here
# so that gfortran 4.8 will disqualify itself correctly for mpi_sizeof()
# support.
#
AC_CACHE_CHECK([if Fortran compiler supports STORAGE_SIZE for relevant types], AC_CACHE_CHECK([if Fortran compiler supports STORAGE_SIZE for relevant types],
fortran_storage_size_var, fortran_storage_size_var,
[AC_LANG_PUSH([Fortran]) [AC_LANG_PUSH([Fortran])
@ -62,7 +73,7 @@ SUBROUTINE storage_size_complex32_r1(x, size)
COMPLEX(REAL32), DIMENSION(*)::x COMPLEX(REAL32), DIMENSION(*)::x
INTEGER, INTENT(OUT) :: size INTEGER, INTENT(OUT) :: size
size = storage_size(x(1)) / 8 size = storage_size(x) / 8
END SUBROUTINE storage_size_complex32_r1 END SUBROUTINE storage_size_complex32_r1
SUBROUTINE storage_size_int32_scalar(x, size) SUBROUTINE storage_size_int32_scalar(x, size)
@ -78,7 +89,7 @@ SUBROUTINE storage_size_int32_r1(x, size)
INTEGER(INT32), DIMENSION(*)::x INTEGER(INT32), DIMENSION(*)::x
INTEGER, INTENT(OUT) :: size INTEGER, INTENT(OUT) :: size
size = storage_size(x(1)) / 8 size = storage_size(x) / 8
END SUBROUTINE storage_size_int32_r1 END SUBROUTINE storage_size_int32_r1
SUBROUTINE storage_size_real32_scalar(x, size) SUBROUTINE storage_size_real32_scalar(x, size)
@ -94,7 +105,7 @@ SUBROUTINE storage_size_real32_r1(x, size)
REAL(REAL32), DIMENSION(*)::x REAL(REAL32), DIMENSION(*)::x
INTEGER, INTENT(OUT) :: size INTEGER, INTENT(OUT) :: size
size = storage_size(x(1)) / 8 size = storage_size(x) / 8
END SUBROUTINE storage_size_real32_r1 END SUBROUTINE storage_size_real32_r1
]])], ]])],
[AS_VAR_SET(fortran_storage_size_var, yes)], [AS_VAR_SET(fortran_storage_size_var, yes)],

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

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