Merge pull request #3843 from jjhursey/revert/gfortran-sizeof
Revert MPI_SIZEOF fix for gfortran 4.8
Этот коммит содержится в:
Коммит
6570374238
10
README
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
|
||||||
|
Загрузка…
x
Ссылка в новой задаче
Block a user