2003-11-22 16:36:58 +00:00
|
|
|
# -*- shell-script -*-
|
|
|
|
#
|
2009-05-26 20:49:35 +00:00
|
|
|
# Copyright (c) 2004-2009 The Trustees of Indiana University and Indiana
|
2005-11-05 19:57:48 +00:00
|
|
|
# University Research and Technology
|
|
|
|
# Corporation. All rights reserved.
|
2016-08-30 15:02:47 -04:00
|
|
|
# Copyright (c) 2004-2018 The University of Tennessee and The University
|
2005-11-05 19:57:48 +00:00
|
|
|
# of Tennessee Research Foundation. All rights
|
|
|
|
# reserved.
|
2015-02-09 11:45:54 -08:00
|
|
|
# Copyright (c) 2004-2007 High Performance Computing Center Stuttgart,
|
2004-11-28 20:09:25 +00:00
|
|
|
# University of Stuttgart. All rights reserved.
|
2005-03-24 12:43:37 +00:00
|
|
|
# Copyright (c) 2004-2005 The Regents of the University of California.
|
|
|
|
# All rights reserved.
|
2020-02-18 22:42:21 -08:00
|
|
|
# Copyright (c) 2006-2020 Cisco Systems, Inc. All rights reserved
|
2008-09-10 12:58:30 +00:00
|
|
|
# Copyright (c) 2006-2008 Sun Microsystems, Inc. All rights reserved.
|
2017-04-08 14:06:57 -06:00
|
|
|
# Copyright (c) 2006-2017 Los Alamos National Security, LLC. All rights
|
2011-04-07 19:52:19 +00:00
|
|
|
# reserved.
|
2012-06-27 01:28:28 +00:00
|
|
|
# Copyright (c) 2009 Oak Ridge National Labs. All rights reserved.
|
2013-07-17 22:12:29 +00:00
|
|
|
# Copyright (c) 2011-2013 NVIDIA Corporation. All rights reserved.
|
2012-10-04 14:39:51 +00:00
|
|
|
# Copyright (c) 2012 Oracle and/or its affiliates. All rights reserved.
|
2013-09-10 15:34:09 +00:00
|
|
|
# Copyright (c) 2013 Mellanox Technologies, Inc.
|
|
|
|
# All rights reserved.
|
2020-02-15 16:28:16 -08:00
|
|
|
# Copyright (c) 2013-2020 Intel, Inc. All rights reserved.
|
2016-05-25 09:16:35 +09:00
|
|
|
# Copyright (c) 2014-2017 Research Organization for Information Science
|
2014-07-17 05:12:50 +00:00
|
|
|
# and Technology (RIST). All rights reserved.
|
2017-03-28 19:51:44 -04:00
|
|
|
# Copyright (c) 2016-2017 IBM Corporation. All rights reserved.
|
2018-05-17 17:11:12 +00:00
|
|
|
# Copyright (c) 2018 Amazon.com, Inc. or its affiliates.
|
|
|
|
# All Rights reserved.
|
2018-11-21 19:54:08 +09:00
|
|
|
# Copyright (c) 2018 FUJITSU LIMITED. All rights reserved.
|
2019-02-04 20:20:37 -07:00
|
|
|
# Copyright (c) 2019 Triad National Security, LLC. All rights
|
|
|
|
# reserved.
|
build: Add third-party package infrastructure
With Open MPI 5.0, the decision was made to stop building 3rd-party
packages, such as Libevent, HWLOC, PMIx, and PRRTE as MCA components
and instead 1) start relying on external libraries whenever possible
and 2) Open MPI builds the 3rd party libraries (if needed) as
independent libraries, rather than linked into libopen-pal.
This patch is the first step in that process, providing foundational
changes required for supporting 3rd-party packages, such as changes
to autogen.pl, the top-level Makefile.am, and introducing two
Autoconf macros to support running sub-configure scripts; one
supporting source in tarball form and the other supporting
source in a sub-tree.
Signed-off-by: Brian Barrett <bbarrett@amazon.com>
2020-04-28 02:37:08 +00:00
|
|
|
# Copyright (c) 2020 Amazon.com, Inc. or its affiliates.
|
|
|
|
# All Rights reserved.
|
2004-11-22 01:38:40 +00:00
|
|
|
# $COPYRIGHT$
|
2015-02-09 11:45:54 -08:00
|
|
|
#
|
2004-11-22 01:38:40 +00:00
|
|
|
# Additional copyrights may follow
|
2015-02-09 11:45:54 -08:00
|
|
|
#
|
2004-01-07 07:49:23 +00:00
|
|
|
# $HEADER$
|
2003-11-22 16:36:58 +00:00
|
|
|
#
|
|
|
|
|
2016-11-22 15:03:20 -08:00
|
|
|
|
2003-11-22 16:36:58 +00:00
|
|
|
############################################################################
|
|
|
|
# Initialization, version number, and other random setup/init stuff
|
|
|
|
############################################################################
|
|
|
|
|
2010-09-17 23:04:06 +00:00
|
|
|
# Load in everything found by autogen.pl
|
|
|
|
m4_include([config/autogen_found_items.m4])
|
2014-10-02 07:31:47 -07:00
|
|
|
# Load the version number code
|
2010-09-17 23:04:06 +00:00
|
|
|
m4_include([config/opal_get_version.m4])
|
2010-09-28 22:24:25 +00:00
|
|
|
AC_LANG([C])
|
Make the hwloc paffinity component available for everyone. hwloc
supports a wide variety of operating systems and platforms; see the
opal/mca/paffinity/hwloc/hwloc/README file for details.
This component includes an embedded copy of hwloc, currently based on
hwloc-1.0rc6. But note that hwloc is properly SVN imported into the
/vendor branch, so it will be easy to update when 1.0 GA is released.
Note that the hwloc tree embedded in opal/mca/paffinity/hwloc/hwloc is
identical to a hwloc distribution tarball, except that much of the
documentation was rm -rf'ed (because we don't need it for the embedded
case).
Since the paffinity framework currently does not understand hardware
threads, the hwloc component compensates for this by identifying cores
by the "first" hardware thread on that core. Hopefully we'll update
paffinity someday to understand hardware threads. :-)
configure grew a --with-hwloc option, analogous to what we do for many
other external libraries that OMPI supports. However, there's a new
feature: due to the request of several distros, OMPI can be configured
to build with its internal copy of hwloc or with an external copy of
hwloc (e.g., a system-installed hwloc).
1. If --with-hwloc is not specified, Open MPI will try to use its
internal copy (but silently fail/ignore hwloc if that fails).
1. If --with-hwloc=<dir> is supplied, Open MPI looks for hwloc
support in <dir> (and --with-hwloc-libdir=<dir>, if specified).
1. If --with-hwloc=external is supplied, Open MPI will look for hwloc
in a compiler/linker default external location.
1. If --with-hwloc=internal is supplied, Open MPI will use its
internal copy of hwloc.
Some of OMPI's main configury had to be slightly re-arranged in the
bootstrapping phase to accomodate hwloc's configry needs.
This commit was SVN r23125.
2010-05-13 23:56:05 +00:00
|
|
|
|
2003-11-22 16:36:58 +00:00
|
|
|
# Init autoconf
|
2016-11-22 15:03:20 -08:00
|
|
|
|
2005-09-07 05:54:53 +00:00
|
|
|
# We don't have the version number to put in here yet, and we can't
|
2010-09-17 23:04:06 +00:00
|
|
|
# call OPAL_GET_VERSION (etc.) before AC_INIT. So use the shell
|
2009-10-20 23:44:20 +00:00
|
|
|
# version. project_name_* comes from config/project_list.m4, which
|
2014-05-14 15:31:39 +00:00
|
|
|
# was set during autogen.pl.
|
2005-09-07 05:54:53 +00:00
|
|
|
|
2009-10-20 23:44:20 +00:00
|
|
|
AC_INIT([project_name_long],
|
2014-10-02 07:31:47 -07:00
|
|
|
[m4_normalize(esyscmd([config/opal_get_version.sh VERSION --tarball]))],
|
2020-04-02 10:43:50 -04:00
|
|
|
[https://www.open-mpi.org/community/help/], [project_name_short])
|
2007-05-15 04:23:48 +00:00
|
|
|
AC_PREREQ(2.60)
|
2006-05-07 19:19:37 +00:00
|
|
|
AC_CONFIG_AUX_DIR(config)
|
|
|
|
AC_CONFIG_MACRO_DIR(config)
|
2016-11-22 15:03:20 -08:00
|
|
|
|
2016-07-25 17:44:27 +09:00
|
|
|
OPAL_CAPTURE_CONFIGURE_CLI([OPAL_CONFIGURE_CLI])
|
|
|
|
|
2016-11-22 15:03:20 -08:00
|
|
|
# Get our platform support file. This has to be done very, very early
|
|
|
|
# because it twiddles random bits of autoconf
|
|
|
|
OPAL_LOAD_PLATFORM
|
|
|
|
|
Make the hwloc paffinity component available for everyone. hwloc
supports a wide variety of operating systems and platforms; see the
opal/mca/paffinity/hwloc/hwloc/README file for details.
This component includes an embedded copy of hwloc, currently based on
hwloc-1.0rc6. But note that hwloc is properly SVN imported into the
/vendor branch, so it will be easy to update when 1.0 GA is released.
Note that the hwloc tree embedded in opal/mca/paffinity/hwloc/hwloc is
identical to a hwloc distribution tarball, except that much of the
documentation was rm -rf'ed (because we don't need it for the embedded
case).
Since the paffinity framework currently does not understand hardware
threads, the hwloc component compensates for this by identifying cores
by the "first" hardware thread on that core. Hopefully we'll update
paffinity someday to understand hardware threads. :-)
configure grew a --with-hwloc option, analogous to what we do for many
other external libraries that OMPI supports. However, there's a new
feature: due to the request of several distros, OMPI can be configured
to build with its internal copy of hwloc or with an external copy of
hwloc (e.g., a system-installed hwloc).
1. If --with-hwloc is not specified, Open MPI will try to use its
internal copy (but silently fail/ignore hwloc if that fails).
1. If --with-hwloc=<dir> is supplied, Open MPI looks for hwloc
support in <dir> (and --with-hwloc-libdir=<dir>, if specified).
1. If --with-hwloc=external is supplied, Open MPI will look for hwloc
in a compiler/linker default external location.
1. If --with-hwloc=internal is supplied, Open MPI will use its
internal copy of hwloc.
Some of OMPI's main configury had to be slightly re-arranged in the
bootstrapping phase to accomodate hwloc's configry needs.
This commit was SVN r23125.
2010-05-13 23:56:05 +00:00
|
|
|
#
|
|
|
|
# Start it up
|
|
|
|
#
|
2016-11-22 14:24:54 -08:00
|
|
|
|
2020-04-27 11:10:01 -07:00
|
|
|
OPAL_CONFIGURE_SETUP
|
|
|
|
opal_show_title "Configuring project_name_long"
|
|
|
|
opal_show_subtitle "Prerequisites"
|
|
|
|
|
2016-12-05 10:30:08 +09:00
|
|
|
AC_CHECK_PROG([PERL],[perl],[perl],[no])
|
|
|
|
AS_IF([test "X$PERL" = "Xno"],
|
|
|
|
[AC_MSG_ERROR(["Open MPI requires perl. Aborting"])])
|
|
|
|
|
Make the hwloc paffinity component available for everyone. hwloc
supports a wide variety of operating systems and platforms; see the
opal/mca/paffinity/hwloc/hwloc/README file for details.
This component includes an embedded copy of hwloc, currently based on
hwloc-1.0rc6. But note that hwloc is properly SVN imported into the
/vendor branch, so it will be easy to update when 1.0 GA is released.
Note that the hwloc tree embedded in opal/mca/paffinity/hwloc/hwloc is
identical to a hwloc distribution tarball, except that much of the
documentation was rm -rf'ed (because we don't need it for the embedded
case).
Since the paffinity framework currently does not understand hardware
threads, the hwloc component compensates for this by identifying cores
by the "first" hardware thread on that core. Hopefully we'll update
paffinity someday to understand hardware threads. :-)
configure grew a --with-hwloc option, analogous to what we do for many
other external libraries that OMPI supports. However, there's a new
feature: due to the request of several distros, OMPI can be configured
to build with its internal copy of hwloc or with an external copy of
hwloc (e.g., a system-installed hwloc).
1. If --with-hwloc is not specified, Open MPI will try to use its
internal copy (but silently fail/ignore hwloc if that fails).
1. If --with-hwloc=<dir> is supplied, Open MPI looks for hwloc
support in <dir> (and --with-hwloc-libdir=<dir>, if specified).
1. If --with-hwloc=external is supplied, Open MPI will look for hwloc
in a compiler/linker default external location.
1. If --with-hwloc=internal is supplied, Open MPI will use its
internal copy of hwloc.
Some of OMPI's main configury had to be slightly re-arranged in the
bootstrapping phase to accomodate hwloc's configry needs.
This commit was SVN r23125.
2010-05-13 23:56:05 +00:00
|
|
|
#
|
|
|
|
# Setup some things that must be done before AM-INIT-AUTOMAKE
|
|
|
|
#
|
|
|
|
|
2014-05-05 22:35:23 +00:00
|
|
|
opal_show_subtitle "Startup tests"
|
Make the hwloc paffinity component available for everyone. hwloc
supports a wide variety of operating systems and platforms; see the
opal/mca/paffinity/hwloc/hwloc/README file for details.
This component includes an embedded copy of hwloc, currently based on
hwloc-1.0rc6. But note that hwloc is properly SVN imported into the
/vendor branch, so it will be easy to update when 1.0 GA is released.
Note that the hwloc tree embedded in opal/mca/paffinity/hwloc/hwloc is
identical to a hwloc distribution tarball, except that much of the
documentation was rm -rf'ed (because we don't need it for the embedded
case).
Since the paffinity framework currently does not understand hardware
threads, the hwloc component compensates for this by identifying cores
by the "first" hardware thread on that core. Hopefully we'll update
paffinity someday to understand hardware threads. :-)
configure grew a --with-hwloc option, analogous to what we do for many
other external libraries that OMPI supports. However, there's a new
feature: due to the request of several distros, OMPI can be configured
to build with its internal copy of hwloc or with an external copy of
hwloc (e.g., a system-installed hwloc).
1. If --with-hwloc is not specified, Open MPI will try to use its
internal copy (but silently fail/ignore hwloc if that fails).
1. If --with-hwloc=<dir> is supplied, Open MPI looks for hwloc
support in <dir> (and --with-hwloc-libdir=<dir>, if specified).
1. If --with-hwloc=external is supplied, Open MPI will look for hwloc
in a compiler/linker default external location.
1. If --with-hwloc=internal is supplied, Open MPI will use its
internal copy of hwloc.
Some of OMPI's main configury had to be slightly re-arranged in the
bootstrapping phase to accomodate hwloc's configry needs.
This commit was SVN r23125.
2010-05-13 23:56:05 +00:00
|
|
|
AC_CANONICAL_HOST
|
|
|
|
AC_CANONICAL_TARGET
|
2016-11-22 15:03:20 -08:00
|
|
|
AC_DEFINE_UNQUOTED(OPAL_ARCH, "$target", [OMPI architecture string])
|
Make the hwloc paffinity component available for everyone. hwloc
supports a wide variety of operating systems and platforms; see the
opal/mca/paffinity/hwloc/hwloc/README file for details.
This component includes an embedded copy of hwloc, currently based on
hwloc-1.0rc6. But note that hwloc is properly SVN imported into the
/vendor branch, so it will be easy to update when 1.0 GA is released.
Note that the hwloc tree embedded in opal/mca/paffinity/hwloc/hwloc is
identical to a hwloc distribution tarball, except that much of the
documentation was rm -rf'ed (because we don't need it for the embedded
case).
Since the paffinity framework currently does not understand hardware
threads, the hwloc component compensates for this by identifying cores
by the "first" hardware thread on that core. Hopefully we'll update
paffinity someday to understand hardware threads. :-)
configure grew a --with-hwloc option, analogous to what we do for many
other external libraries that OMPI supports. However, there's a new
feature: due to the request of several distros, OMPI can be configured
to build with its internal copy of hwloc or with an external copy of
hwloc (e.g., a system-installed hwloc).
1. If --with-hwloc is not specified, Open MPI will try to use its
internal copy (but silently fail/ignore hwloc if that fails).
1. If --with-hwloc=<dir> is supplied, Open MPI looks for hwloc
support in <dir> (and --with-hwloc-libdir=<dir>, if specified).
1. If --with-hwloc=external is supplied, Open MPI will look for hwloc
in a compiler/linker default external location.
1. If --with-hwloc=internal is supplied, Open MPI will use its
internal copy of hwloc.
Some of OMPI's main configury had to be slightly re-arranged in the
bootstrapping phase to accomodate hwloc's configry needs.
This commit was SVN r23125.
2010-05-13 23:56:05 +00:00
|
|
|
AS_IF([test "$host" != "$target"],
|
|
|
|
[AC_MSG_WARN([Cross-compile detected])
|
|
|
|
AC_MSG_WARN([Cross-compiling is only partially supported])
|
|
|
|
AC_MSG_WARN([Proceed at your own risk!])])
|
2017-08-15 12:46:21 -04:00
|
|
|
|
2010-05-20 00:25:23 +00:00
|
|
|
# AC_USE_SYSTEM_EXTENSIONS alters CFLAGS (e.g., adds -g -O2)
|
2013-12-06 23:40:34 +00:00
|
|
|
OPAL_VAR_SCOPE_PUSH([CFLAGS_save])
|
2010-05-20 00:25:23 +00:00
|
|
|
CFLAGS_save=$CFLAGS
|
Make the hwloc paffinity component available for everyone. hwloc
supports a wide variety of operating systems and platforms; see the
opal/mca/paffinity/hwloc/hwloc/README file for details.
This component includes an embedded copy of hwloc, currently based on
hwloc-1.0rc6. But note that hwloc is properly SVN imported into the
/vendor branch, so it will be easy to update when 1.0 GA is released.
Note that the hwloc tree embedded in opal/mca/paffinity/hwloc/hwloc is
identical to a hwloc distribution tarball, except that much of the
documentation was rm -rf'ed (because we don't need it for the embedded
case).
Since the paffinity framework currently does not understand hardware
threads, the hwloc component compensates for this by identifying cores
by the "first" hardware thread on that core. Hopefully we'll update
paffinity someday to understand hardware threads. :-)
configure grew a --with-hwloc option, analogous to what we do for many
other external libraries that OMPI supports. However, there's a new
feature: due to the request of several distros, OMPI can be configured
to build with its internal copy of hwloc or with an external copy of
hwloc (e.g., a system-installed hwloc).
1. If --with-hwloc is not specified, Open MPI will try to use its
internal copy (but silently fail/ignore hwloc if that fails).
1. If --with-hwloc=<dir> is supplied, Open MPI looks for hwloc
support in <dir> (and --with-hwloc-libdir=<dir>, if specified).
1. If --with-hwloc=external is supplied, Open MPI will look for hwloc
in a compiler/linker default external location.
1. If --with-hwloc=internal is supplied, Open MPI will use its
internal copy of hwloc.
Some of OMPI's main configury had to be slightly re-arranged in the
bootstrapping phase to accomodate hwloc's configry needs.
This commit was SVN r23125.
2010-05-13 23:56:05 +00:00
|
|
|
AC_USE_SYSTEM_EXTENSIONS
|
2010-05-20 00:25:23 +00:00
|
|
|
# AC_USE_SYSTEM_EXTENSIONS will modify CFLAGS if nothing was in there
|
|
|
|
# beforehand. We don't want that. So if there was nothing in
|
|
|
|
# CFLAGS, put nothing back in there.
|
2010-05-20 00:41:36 +00:00
|
|
|
AS_IF([test -z "$CFLAGS_save"], [CFLAGS=])
|
2013-12-06 23:40:34 +00:00
|
|
|
OPAL_VAR_SCOPE_POP
|
Make the hwloc paffinity component available for everyone. hwloc
supports a wide variety of operating systems and platforms; see the
opal/mca/paffinity/hwloc/hwloc/README file for details.
This component includes an embedded copy of hwloc, currently based on
hwloc-1.0rc6. But note that hwloc is properly SVN imported into the
/vendor branch, so it will be easy to update when 1.0 GA is released.
Note that the hwloc tree embedded in opal/mca/paffinity/hwloc/hwloc is
identical to a hwloc distribution tarball, except that much of the
documentation was rm -rf'ed (because we don't need it for the embedded
case).
Since the paffinity framework currently does not understand hardware
threads, the hwloc component compensates for this by identifying cores
by the "first" hardware thread on that core. Hopefully we'll update
paffinity someday to understand hardware threads. :-)
configure grew a --with-hwloc option, analogous to what we do for many
other external libraries that OMPI supports. However, there's a new
feature: due to the request of several distros, OMPI can be configured
to build with its internal copy of hwloc or with an external copy of
hwloc (e.g., a system-installed hwloc).
1. If --with-hwloc is not specified, Open MPI will try to use its
internal copy (but silently fail/ignore hwloc if that fails).
1. If --with-hwloc=<dir> is supplied, Open MPI looks for hwloc
support in <dir> (and --with-hwloc-libdir=<dir>, if specified).
1. If --with-hwloc=external is supplied, Open MPI will look for hwloc
in a compiler/linker default external location.
1. If --with-hwloc=internal is supplied, Open MPI will use its
internal copy of hwloc.
Some of OMPI's main configury had to be slightly re-arranged in the
bootstrapping phase to accomodate hwloc's configry needs.
This commit was SVN r23125.
2010-05-13 23:56:05 +00:00
|
|
|
|
2005-09-07 05:54:53 +00:00
|
|
|
#
|
2007-05-15 04:23:48 +00:00
|
|
|
# Init automake
|
2005-09-07 05:54:53 +00:00
|
|
|
#
|
2018-09-15 13:29:30 -07:00
|
|
|
AM_INIT_AUTOMAKE([foreign dist-bzip2 subdir-objects no-define 1.13.4 tar-ustar])
|
2005-09-07 05:54:53 +00:00
|
|
|
|
2010-10-19 22:45:54 +00:00
|
|
|
# SILENT_RULES is new in AM 1.11, but we require 1.11 or higher via
|
|
|
|
# autogen. Limited testing shows that calling SILENT_RULES directly
|
|
|
|
# works in more cases than adding "silent-rules" to INIT_AUTOMAKE
|
|
|
|
# (even though they're supposed to be identical). Shrug.
|
2010-09-24 22:34:53 +00:00
|
|
|
AM_SILENT_RULES([yes])
|
2009-11-04 02:07:02 +00:00
|
|
|
|
2005-09-16 02:49:31 +00:00
|
|
|
# Make configure depend on the VERSION file, since it's used in AC_INIT
|
2005-09-07 05:54:53 +00:00
|
|
|
AC_SUBST([CONFIGURE_DEPENDENCIES], ['$(top_srcdir)/VERSION'])
|
|
|
|
|
2020-10-24 06:12:52 -07:00
|
|
|
# Sanity checks
|
|
|
|
AC_DEFUN([OMPI_CHECK_DIR_FOR_SPACES],[
|
|
|
|
dir="$1"
|
|
|
|
article="$2"
|
|
|
|
label="$3"
|
|
|
|
|
|
|
|
AC_MSG_CHECKING([directory of $label])
|
|
|
|
AC_MSG_RESULT([$dir])
|
|
|
|
AS_IF([test -n "`echo $dir | grep ' '`"],
|
|
|
|
[AC_MSG_WARN([This version of Open MPI does not support $article $label])
|
|
|
|
AC_MSG_WARN([with a path that contains spaces])
|
|
|
|
AC_MSG_ERROR([Cannot continue.])])
|
|
|
|
])
|
|
|
|
|
2020-10-28 22:47:28 -04:00
|
|
|
AC_DEFUN([OMPI_CANONICALIZE_PATH],[
|
|
|
|
case $host_os in
|
|
|
|
darwin*)
|
|
|
|
# MacOS does not have "readlink -f" or realpath (at least as
|
|
|
|
# of MacOS Cataline / 10.15). Instead, use Python, because we
|
|
|
|
# know MacOS comes with a /usr/bin/python that has
|
|
|
|
# os.path.realpath.
|
|
|
|
$2=`/usr/bin/python -c 'import os; print os.path.realpath("'$1'")'`
|
|
|
|
;;
|
|
|
|
*)
|
|
|
|
$2=`readlink -f $1`
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
])
|
|
|
|
|
2020-10-24 06:12:52 -07:00
|
|
|
OMPI_CHECK_DIR_FOR_SPACES([$srcdir], [a], [source tree])
|
2020-10-28 22:47:28 -04:00
|
|
|
OMPI_CANONICALIZE_PATH([$srcdir], [ompi_dir])
|
|
|
|
OMPI_CHECK_DIR_FOR_SPACES([$ompi_dir], [an], [absolute source tree])
|
|
|
|
OMPI_CANONICALIZE_PATH([.], [ompi_dir])
|
|
|
|
OMPI_CHECK_DIR_FOR_SPACES([$ompi_dir], [a], [build tree])
|
2020-10-24 06:12:52 -07:00
|
|
|
OMPI_CHECK_DIR_FOR_SPACES([$prefix], [a], [prefix])
|
2020-10-28 22:47:28 -04:00
|
|
|
OMPI_CANONICALIZE_PATH([$prefix], [ompi_dir])
|
|
|
|
OMPI_CHECK_DIR_FOR_SPACES([$ompi_dir], [an], [absolute prefix])
|
2020-10-24 06:12:52 -07:00
|
|
|
|
2014-05-05 22:35:23 +00:00
|
|
|
opal_show_subtitle "Checking versions"
|
2006-01-21 22:53:16 +00:00
|
|
|
|
2016-11-22 15:03:20 -08:00
|
|
|
# Get the version of OMPI that we are installing
|
|
|
|
|
|
|
|
m4_ifdef([project_ompi],
|
|
|
|
[OPAL_SAVE_VERSION([OMPI], [Open MPI], [$srcdir/VERSION],
|
|
|
|
[ompi/include/ompi/version.h])])
|
|
|
|
|
|
|
|
m4_ifdef([project_oshmem],
|
|
|
|
[OPAL_SAVE_VERSION([OSHMEM], [Open SHMEM],
|
|
|
|
[$srcdir/VERSION],
|
|
|
|
[oshmem/include/oshmem/version.h])])
|
|
|
|
|
2010-09-17 23:04:06 +00:00
|
|
|
OPAL_SAVE_VERSION([OPAL], [Open Portable Access Layer], [$srcdir/VERSION],
|
2006-03-12 04:35:01 +00:00
|
|
|
[opal/include/opal/version.h])
|
2004-06-07 15:33:53 +00:00
|
|
|
|
2009-07-24 01:04:17 +00:00
|
|
|
# Get shared library version numbers
|
2016-11-22 14:24:54 -08:00
|
|
|
|
2016-11-22 15:03:20 -08:00
|
|
|
. $srcdir/VERSION
|
|
|
|
m4_ifdef([project_ompi],
|
|
|
|
[AC_SUBST(libmpi_so_version)
|
|
|
|
AC_SUBST(libmpi_mpifh_so_version)
|
|
|
|
AC_SUBST(libmpi_usempi_tkr_so_version)
|
|
|
|
AC_SUBST(libmpi_usempi_ignore_tkr_so_version)
|
|
|
|
AC_SUBST(libmpi_usempif08_so_version)
|
|
|
|
AC_SUBST(libmpi_java_so_version)
|
|
|
|
AC_SUBST(libompitrace_so_version)])
|
|
|
|
m4_ifdef([project_oshmem],
|
|
|
|
[AC_SUBST(liboshmem_so_version)])
|
2014-07-31 13:24:15 +00:00
|
|
|
AC_SUBST(libopen_pal_so_version)
|
|
|
|
# It's icky that we have to hard-code the names of the
|
|
|
|
# common components here. :-( This could probably be done
|
|
|
|
# transparently by adding some intelligence in autogen.pl
|
|
|
|
# and/or opal_mca.m4, but I don't have the cycles to do this
|
|
|
|
# right now.
|
2019-08-09 09:42:12 -07:00
|
|
|
AC_SUBST(libmca_opal_common_ofi_so_version)
|
2015-12-18 12:48:22 -05:00
|
|
|
AC_SUBST(libmca_opal_common_cuda_so_version)
|
|
|
|
AC_SUBST(libmca_opal_common_sm_so_version)
|
|
|
|
AC_SUBST(libmca_opal_common_ugni_so_version)
|
2016-11-22 15:03:20 -08:00
|
|
|
AC_SUBST(libmca_ompi_common_ompio_so_version)
|
2018-02-20 07:07:23 -08:00
|
|
|
AC_SUBST(libmca_ompi_common_monitoring_so_version)
|
2018-06-22 15:03:01 +03:00
|
|
|
AC_SUBST(libmca_opal_common_ucx_so_version)
|
2009-07-24 01:04:17 +00:00
|
|
|
|
2012-02-17 02:55:06 +00:00
|
|
|
#
|
|
|
|
# Get the versions of the autotools that were used to bootstrap us
|
|
|
|
# (helpful for debugging reports)
|
|
|
|
#
|
|
|
|
AC_MSG_CHECKING([for bootstrap Autoconf version])
|
|
|
|
acversion=`grep "Generated by GNU Autoconf" $0 | head -n 1 | awk '{ print $6 }'`
|
|
|
|
AC_MSG_RESULT([$acversion])
|
|
|
|
AC_MSG_CHECKING([for bootstrap Automake version])
|
|
|
|
AC_MSG_RESULT([$am__api_version])
|
|
|
|
AC_MSG_CHECKING([for boostrap Libtool version])
|
|
|
|
ltversion=`grep VERSION= $srcdir/config/ltmain.sh | head -n 1 | cut -d= -f2`
|
|
|
|
AC_MSG_RESULT([$ltversion])
|
|
|
|
|
2009-07-24 01:04:17 +00:00
|
|
|
# List header files to generate
|
|
|
|
|
2013-01-11 20:20:02 +00:00
|
|
|
AC_CONFIG_HEADERS([opal/include/opal_config.h])
|
2016-11-22 15:03:20 -08:00
|
|
|
m4_ifdef([project_ompi],
|
|
|
|
[AC_CONFIG_HEADERS([ompi/include/mpi.h])])
|
|
|
|
m4_ifdef([project_oshmem],
|
|
|
|
[AC_CONFIG_HEADER([oshmem/include/shmem.h])])
|
2007-06-05 22:07:30 +00:00
|
|
|
|
2014-05-05 22:35:23 +00:00
|
|
|
opal_show_subtitle "Initialization, setup"
|
2003-11-22 16:36:58 +00:00
|
|
|
|
2004-06-07 15:33:53 +00:00
|
|
|
OMPI_TOP_BUILDDIR="`pwd`"
|
|
|
|
AC_SUBST(OMPI_TOP_BUILDDIR)
|
2003-11-22 16:36:58 +00:00
|
|
|
cd "$srcdir"
|
2004-06-07 15:33:53 +00:00
|
|
|
OMPI_TOP_SRCDIR="`pwd`"
|
|
|
|
AC_SUBST(OMPI_TOP_SRCDIR)
|
|
|
|
cd "$OMPI_TOP_BUILDDIR"
|
2016-11-22 15:03:20 -08:00
|
|
|
|
2004-06-07 15:33:53 +00:00
|
|
|
AC_MSG_NOTICE([builddir: $OMPI_TOP_BUILDDIR])
|
|
|
|
AC_MSG_NOTICE([srcdir: $OMPI_TOP_SRCDIR])
|
|
|
|
if test "$OMPI_TOP_BUILDDIR" != "$OMPI_TOP_SRCDIR"; then
|
2003-11-22 16:36:58 +00:00
|
|
|
AC_MSG_NOTICE([Detected VPATH build])
|
|
|
|
fi
|
|
|
|
|
2020-02-20 12:08:11 -08:00
|
|
|
# Check for deprecated/deleted options
|
|
|
|
OMPI_CHECK_DELETED_OPTIONS
|
2020-02-19 10:07:50 -08:00
|
|
|
|
2006-02-12 01:33:29 +00:00
|
|
|
# Setup the top of the opal/include/opal_config.h file
|
2003-11-22 16:36:58 +00:00
|
|
|
|
|
|
|
AH_TOP([/* -*- c -*-
|
|
|
|
*
|
2004-11-22 01:38:40 +00:00
|
|
|
* Copyright (c) 2004-2005 The Trustees of Indiana University.
|
|
|
|
* All rights reserved.
|
|
|
|
* Copyright (c) 2004-2005 The Trustees of the University of Tennessee.
|
|
|
|
* All rights reserved.
|
2009-03-16 02:04:22 +00:00
|
|
|
* Copyright (c) 2004-2005 High Performance Computing Center Stuttgart,
|
2004-11-28 20:09:25 +00:00
|
|
|
* University of Stuttgart. All rights reserved.
|
2005-03-24 12:43:37 +00:00
|
|
|
* Copyright (c) 2004-2005 The Regents of the University of California.
|
|
|
|
* All rights reserved.
|
2014-05-07 21:48:53 +00:00
|
|
|
* Copyright (c) 2014 Intel, Inc. All rights reserved.
|
2004-11-22 01:38:40 +00:00
|
|
|
* $COPYRIGHT$
|
2009-03-16 02:04:22 +00:00
|
|
|
*
|
2004-11-22 01:38:40 +00:00
|
|
|
* Additional copyrights may follow
|
2009-03-16 02:04:22 +00:00
|
|
|
*
|
2004-01-07 14:55:23 +00:00
|
|
|
* $HEADER$
|
2003-11-22 16:36:58 +00:00
|
|
|
*
|
2009-03-16 02:04:22 +00:00
|
|
|
* Function: - OS, CPU and compiler dependent configuration
|
2003-11-22 16:36:58 +00:00
|
|
|
*/
|
|
|
|
|
2006-02-12 01:33:29 +00:00
|
|
|
#ifndef OPAL_CONFIG_H
|
|
|
|
#define OPAL_CONFIG_H
|
2011-03-24 22:39:56 +00:00
|
|
|
|
|
|
|
#include "opal_config_top.h"
|
2016-11-22 14:24:54 -08:00
|
|
|
|
2016-11-22 15:03:20 -08:00
|
|
|
])
|
2003-12-22 16:29:21 +00:00
|
|
|
AH_BOTTOM([
|
2006-02-12 01:33:29 +00:00
|
|
|
#include "opal_config_bottom.h"
|
|
|
|
#endif /* OPAL_CONFIG_H */
|
2003-11-22 16:36:58 +00:00
|
|
|
])
|
|
|
|
|
2004-08-02 00:24:22 +00:00
|
|
|
# Other basic setup stuff (shared with components)
|
2003-11-22 16:36:58 +00:00
|
|
|
|
2010-11-12 23:22:11 +00:00
|
|
|
OPAL_BASIC_SETUP
|
2003-11-22 16:36:58 +00:00
|
|
|
|
2014-05-07 21:48:53 +00:00
|
|
|
OPAL_TOP_SRCDIR="$OMPI_TOP_SRCDIR"
|
|
|
|
OPAL_TOP_BUILDDIR="$OMPI_TOP_BUILDDIR"
|
|
|
|
AC_SUBST(OPAL_TOP_SRCDIR)
|
|
|
|
AC_SUBST(OPAL_TOP_BUILDDIR)
|
|
|
|
|
2016-11-22 15:03:20 -08:00
|
|
|
m4_ifdef([project_oshmem],
|
|
|
|
[OSHMEM_TOP_SRCDIR="$OMPI_TOP_SRCDIR"
|
|
|
|
OSHMEM_TOP_BUILDDIR="$OMPI_TOP_BUILDDIR"
|
|
|
|
AC_SUBST(OSHMEM_TOP_SRCDIR)
|
|
|
|
AC_SUBST(OSHMEM_TOP_BUILDDIR)])
|
2003-11-22 16:36:58 +00:00
|
|
|
|
|
|
|
############################################################################
|
|
|
|
# Configuration options
|
|
|
|
############################################################################
|
|
|
|
|
2009-05-27 03:03:18 +00:00
|
|
|
OPAL_CONFIGURE_OPTIONS
|
2014-03-19 20:32:15 +00:00
|
|
|
OPAL_CHECK_OS_FLAVORS
|
2016-11-22 15:03:20 -08:00
|
|
|
OPAL_CHECK_CUDA
|
2020-04-27 17:32:56 +00:00
|
|
|
|
2016-11-22 15:03:20 -08:00
|
|
|
m4_ifdef([project_ompi], [OMPI_CONFIGURE_OPTIONS])
|
|
|
|
m4_ifdef([project_oshmem], [OSHMEM_CONFIGURE_OPTIONS])
|
|
|
|
|
|
|
|
# Set up project specific AM_CONDITIONALs
|
|
|
|
AS_IF([test "$enable_ompi" != "no"], [project_ompi_amc=true], [project_ompi_amc=false])
|
|
|
|
m4_ifndef([project_ompi], [project_ompi_amc=false])
|
|
|
|
|
2018-05-17 17:22:21 +00:00
|
|
|
AS_IF([test "$enable_oshmem" != "no"], [project_oshmem_amc=true], [project_oshmem_amc="no (disabled)"])
|
|
|
|
m4_ifndef([project_oshmem], [project_oshmem_amc="no (not available)"])
|
2014-01-30 11:16:29 +00:00
|
|
|
|
2016-08-30 15:02:47 -04:00
|
|
|
# Enable/Disable Software-Based Performance Counters Capability
|
|
|
|
AC_ARG_ENABLE(spc,
|
|
|
|
AC_HELP_STRING([--enable-spc],
|
|
|
|
[Enable software-based performance counters capability (default: disabled)]))
|
|
|
|
if test "$enable_spc" = "yes"; then
|
|
|
|
AC_MSG_RESULT([yes])
|
|
|
|
SPC_ENABLE=1
|
|
|
|
else
|
|
|
|
AC_MSG_RESULT([no])
|
|
|
|
SPC_ENABLE=0
|
|
|
|
fi
|
|
|
|
AC_DEFINE_UNQUOTED([SPC_ENABLE],
|
|
|
|
[$SPC_ENABLE],
|
|
|
|
[If the software-based performance counters capability should be enabled.])
|
|
|
|
AM_CONDITIONAL(SPC_ENABLE, test "$SPC_ENABLE" = "1")
|
|
|
|
|
|
|
|
AS_IF([test "$enable_spc" != "no"], [project_spc_amc=true], [project_spc_amc=false])
|
|
|
|
|
2015-02-03 15:45:03 +09:00
|
|
|
if test "$enable_binaries" = "no" && test "$enable_dist" = "yes"; then
|
2008-03-25 12:01:36 +00:00
|
|
|
AC_MSG_WARN([--disable-binaries is incompatible with --enable dist])
|
|
|
|
AC_MSG_ERROR([Cannot continue])
|
|
|
|
fi
|
|
|
|
|
2014-10-28 17:13:14 -07:00
|
|
|
# The library prefixes must be set before we call OPAL MCA. Here is
|
|
|
|
# as good a place as any.
|
2014-10-28 17:34:17 -07:00
|
|
|
OPAL_SET_LIB_PREFIX([])
|
2016-11-22 15:03:20 -08:00
|
|
|
m4_ifdef([project_ompi],
|
|
|
|
[OMPI_SET_LIB_NAME([])])
|
2014-10-28 17:13:14 -07:00
|
|
|
|
2003-11-22 16:36:58 +00:00
|
|
|
############################################################################
|
|
|
|
# Libtool: part one
|
|
|
|
# (before C compiler setup)
|
|
|
|
############################################################################
|
|
|
|
|
|
|
|
#
|
2015-02-24 13:15:10 -08:00
|
|
|
# Part one of libtool magic. Default to: enable shared, disable static.
|
2003-11-22 16:36:58 +00:00
|
|
|
#
|
|
|
|
|
2004-07-01 16:25:44 +00:00
|
|
|
AM_ENABLE_SHARED
|
|
|
|
AM_DISABLE_STATIC
|
2016-11-22 15:03:20 -08:00
|
|
|
|
2020-07-07 22:43:43 -07:00
|
|
|
# Must be called before OPAL_SETUP_CC to get the value of CC
|
|
|
|
# before it is modified by the C99/C11 checks.
|
2009-10-24 01:04:35 +00:00
|
|
|
OPAL_SETUP_WRAPPER_INIT
|
2005-04-18 16:38:27 +00:00
|
|
|
|
2009-01-28 01:06:53 +00:00
|
|
|
##################################
|
|
|
|
# Check for known incompatibility
|
|
|
|
##################################
|
|
|
|
|
|
|
|
# Do *not* print a message that we're checking the OS because this
|
|
|
|
# test is *not* meant to be an all-inclusive "if it passes this test,
|
|
|
|
# then configure must succeed" test. This test is *only* mean to
|
|
|
|
# screen out the versions of OS X where we know OMPI will cause kernel
|
|
|
|
# panics because of bad implementations of pty's. See
|
|
|
|
# https://svn.open-mpi.org/trac/ompi/ticket/1637 for details.
|
2016-11-22 15:03:20 -08:00
|
|
|
|
2012-02-21 15:56:19 +00:00
|
|
|
# OS X name OS X Version $host_os value
|
|
|
|
# OS X Tiger 10.4.x darwin8.x
|
|
|
|
# OS X Leopard 10.5.x darwin9.x
|
|
|
|
# OS X Snow Leopard 10.6.x darwin10.x
|
|
|
|
# OS X Lion 10.7.x darwin11.x
|
2016-11-22 15:03:20 -08:00
|
|
|
|
2012-02-21 15:56:19 +00:00
|
|
|
# We do not support OS X before version 10.5 (Leopard)
|
2009-01-28 01:06:53 +00:00
|
|
|
case $host_os in
|
2012-02-21 15:56:19 +00:00
|
|
|
# Corresponds to OS X 10.0 - 10.4 (additional [] quoting for m4)
|
|
|
|
darwin[[45678]]*)
|
|
|
|
AC_MSG_WARN([Open MPI does not support OS X prior to version 10.5 (Leopard)])
|
2009-01-28 01:06:53 +00:00
|
|
|
AC_MSG_ERROR([Cannot continue])
|
|
|
|
esac
|
2003-11-22 16:36:58 +00:00
|
|
|
|
|
|
|
############################################################################
|
|
|
|
# Check for compilers and preprocessors
|
|
|
|
############################################################################
|
2014-05-05 22:35:23 +00:00
|
|
|
opal_show_title "Compiler and preprocessor tests"
|
2003-11-22 16:36:58 +00:00
|
|
|
|
|
|
|
##################################
|
|
|
|
# C compiler characteristics
|
|
|
|
##################################
|
|
|
|
|
2010-07-26 22:09:24 +00:00
|
|
|
OPAL_SETUP_CC
|
2003-11-22 16:36:58 +00:00
|
|
|
|
2005-12-17 22:29:12 +00:00
|
|
|
# If we build on a windows environment with the windows compiler and linker
|
|
|
|
# then we need some translation functions from the opal/win32 directory.
|
|
|
|
AM_CONDITIONAL(OMPI_NEED_WINDOWS_REPLACEMENTS,
|
2014-05-06 15:01:34 +00:00
|
|
|
test "$opal_cv_c_compiler_vendor" = "microsoft" )
|
2005-12-17 22:29:12 +00:00
|
|
|
|
2008-03-26 23:20:33 +00:00
|
|
|
# Do all Interix detections if necessary
|
|
|
|
OMPI_INTERIX
|
|
|
|
|
2007-11-03 02:40:22 +00:00
|
|
|
# Does the compiler support "ident"-like constructs?
|
|
|
|
|
2014-05-06 19:22:27 +00:00
|
|
|
OPAL_CHECK_IDENT([CC], [CFLAGS], [c], [C])
|
2007-11-03 02:40:22 +00:00
|
|
|
|
2004-02-13 18:05:49 +00:00
|
|
|
#
|
|
|
|
# Check for some types
|
|
|
|
#
|
|
|
|
|
2019-01-30 11:30:18 +09:00
|
|
|
# 'short float' support of the Intel C++ Compiler (group of C and C++
|
|
|
|
# compilers), at least versions 18.0 and 19.0, is half-baked. It can
|
|
|
|
# compile declarations of 'short float' variables and expressions of
|
|
|
|
# 'sizeof(short float)' but cannot compile casts and operations of
|
|
|
|
# 'short float' variables. In this situation, 'AC_CHECK_TYPES(short float)'
|
|
|
|
# defines 'HAVE_SHORT_FLOAT' as 1 and compilation errors occur in
|
|
|
|
# ompi/mca/op/base/op_base_functions.c. To avoid this error, check it
|
|
|
|
# using 'AC_COMPILE_IFELSE' and set Autoconf cache variables before
|
|
|
|
# 'AC_CHECK_TYPES(short float)'. This check can be removed when all
|
|
|
|
# OMPI-supported Intel C++ Compilers support 'short float' completely
|
|
|
|
# (or drop it completely).
|
|
|
|
if test "$opal_cv_c_compiler_vendor" = "intel"; then
|
|
|
|
AC_MSG_CHECKING([if Intel compiler supports "short float" properly])
|
|
|
|
AC_COMPILE_IFELSE(
|
|
|
|
[AC_LANG_SOURCE([float f(short float a, short float b) { return (float)(a + b); }])],
|
|
|
|
[AC_MSG_RESULT([yes])],
|
|
|
|
[ac_cv_type_short_float="no"
|
|
|
|
ac_cv_type_short_float__Complex="no"]
|
|
|
|
AC_MSG_RESULT([no]))
|
|
|
|
fi
|
|
|
|
|
2004-01-09 01:17:00 +00:00
|
|
|
AC_CHECK_TYPES(int8_t)
|
|
|
|
AC_CHECK_TYPES(uint8_t)
|
|
|
|
AC_CHECK_TYPES(int16_t)
|
|
|
|
AC_CHECK_TYPES(uint16_t)
|
|
|
|
AC_CHECK_TYPES(int32_t)
|
|
|
|
AC_CHECK_TYPES(uint32_t)
|
|
|
|
AC_CHECK_TYPES(int64_t)
|
|
|
|
AC_CHECK_TYPES(uint64_t)
|
- Split the datatype engine into two parts: an MPI specific part in
OMPI
and a language agnostic part in OPAL. The convertor is completely
moved into OPAL. This offers several benefits as described in RFC
http://www.open-mpi.org/community/lists/devel/2009/07/6387.php
namely:
- Fewer basic types (int* and float* types, boolean and wchar
- Fixing naming scheme to ompi-nomenclature.
- Usability outside of the ompi-layer.
- Due to the fixed nature of simple opal types, their information is
completely
known at compile time and therefore constified
- With fewer datatypes (22), the actual sizes of bit-field types may be
reduced
from 64 to 32 bits, allowing reorganizing the opal_datatype
structure, eliminating holes and keeping data required in convertor
(upon send/recv) in one cacheline...
This has implications to the convertor-datastructure and other parts
of the code.
- Several performance tests have been run, the netpipe latency does not
change with
this patch on Linux/x86-64 on the smoky cluster.
- Extensive tests have been done to verify correctness (no new
regressions) using:
1. mpi_test_suite on linux/x86-64 using clean ompi-trunk and
ompi-ddt:
a. running both trunk and ompi-ddt resulted in no differences
(except for MPI_SHORT_INT and MPI_TYPE_MIX_LB_UB do now run
correctly).
b. with --enable-memchecker and running under valgrind (one buglet
when run with static found in test-suite, commited)
2. ibm testsuite on linux/x86-64 using clean ompi-trunk and ompi-ddt:
all passed (except for the dynamic/ tests failed!! as trunk/MTT)
3. compilation and usage of HDF5 tests on Jaguar using PGI and
PathScale compilers.
4. compilation and usage on Scicortex.
- Please note, that for the heterogeneous case, (-m32 compiled
binaries/ompi), neither
ompi-trunk, nor ompi-ddt branch would successfully launch.
This commit was SVN r21641.
2009-07-13 04:56:31 +00:00
|
|
|
AC_CHECK_TYPES(int128_t)
|
2014-12-02 10:25:46 -07:00
|
|
|
AC_CHECK_TYPES(__int128)
|
- Split the datatype engine into two parts: an MPI specific part in
OMPI
and a language agnostic part in OPAL. The convertor is completely
moved into OPAL. This offers several benefits as described in RFC
http://www.open-mpi.org/community/lists/devel/2009/07/6387.php
namely:
- Fewer basic types (int* and float* types, boolean and wchar
- Fixing naming scheme to ompi-nomenclature.
- Usability outside of the ompi-layer.
- Due to the fixed nature of simple opal types, their information is
completely
known at compile time and therefore constified
- With fewer datatypes (22), the actual sizes of bit-field types may be
reduced
from 64 to 32 bits, allowing reorganizing the opal_datatype
structure, eliminating holes and keeping data required in convertor
(upon send/recv) in one cacheline...
This has implications to the convertor-datastructure and other parts
of the code.
- Several performance tests have been run, the netpipe latency does not
change with
this patch on Linux/x86-64 on the smoky cluster.
- Extensive tests have been done to verify correctness (no new
regressions) using:
1. mpi_test_suite on linux/x86-64 using clean ompi-trunk and
ompi-ddt:
a. running both trunk and ompi-ddt resulted in no differences
(except for MPI_SHORT_INT and MPI_TYPE_MIX_LB_UB do now run
correctly).
b. with --enable-memchecker and running under valgrind (one buglet
when run with static found in test-suite, commited)
2. ibm testsuite on linux/x86-64 using clean ompi-trunk and ompi-ddt:
all passed (except for the dynamic/ tests failed!! as trunk/MTT)
3. compilation and usage of HDF5 tests on Jaguar using PGI and
PathScale compilers.
4. compilation and usage on Scicortex.
- Please note, that for the heterogeneous case, (-m32 compiled
binaries/ompi), neither
ompi-trunk, nor ompi-ddt branch would successfully launch.
This commit was SVN r21641.
2009-07-13 04:56:31 +00:00
|
|
|
AC_CHECK_TYPES(uint128_t)
|
|
|
|
AC_CHECK_TYPES(long long)
|
2016-11-22 15:03:20 -08:00
|
|
|
|
2011-08-25 21:56:05 +00:00
|
|
|
AC_CHECK_TYPES(__float128)
|
2018-11-21 19:54:08 +09:00
|
|
|
AC_CHECK_TYPES(short float)
|
- Split the datatype engine into two parts: an MPI specific part in
OMPI
and a language agnostic part in OPAL. The convertor is completely
moved into OPAL. This offers several benefits as described in RFC
http://www.open-mpi.org/community/lists/devel/2009/07/6387.php
namely:
- Fewer basic types (int* and float* types, boolean and wchar
- Fixing naming scheme to ompi-nomenclature.
- Usability outside of the ompi-layer.
- Due to the fixed nature of simple opal types, their information is
completely
known at compile time and therefore constified
- With fewer datatypes (22), the actual sizes of bit-field types may be
reduced
from 64 to 32 bits, allowing reorganizing the opal_datatype
structure, eliminating holes and keeping data required in convertor
(upon send/recv) in one cacheline...
This has implications to the convertor-datastructure and other parts
of the code.
- Several performance tests have been run, the netpipe latency does not
change with
this patch on Linux/x86-64 on the smoky cluster.
- Extensive tests have been done to verify correctness (no new
regressions) using:
1. mpi_test_suite on linux/x86-64 using clean ompi-trunk and
ompi-ddt:
a. running both trunk and ompi-ddt resulted in no differences
(except for MPI_SHORT_INT and MPI_TYPE_MIX_LB_UB do now run
correctly).
b. with --enable-memchecker and running under valgrind (one buglet
when run with static found in test-suite, commited)
2. ibm testsuite on linux/x86-64 using clean ompi-trunk and ompi-ddt:
all passed (except for the dynamic/ tests failed!! as trunk/MTT)
3. compilation and usage of HDF5 tests on Jaguar using PGI and
PathScale compilers.
4. compilation and usage on Scicortex.
- Please note, that for the heterogeneous case, (-m32 compiled
binaries/ompi), neither
ompi-trunk, nor ompi-ddt branch would successfully launch.
This commit was SVN r21641.
2009-07-13 04:56:31 +00:00
|
|
|
AC_CHECK_TYPES(long double)
|
2009-10-20 23:44:20 +00:00
|
|
|
# We only need these types if we're building the OMPI project, but
|
|
|
|
# OPAL currently doesn't protect for their lack of presence well.
|
== Highlights ==
1. New mpifort wrapper compiler: you can utilize mpif.h, use mpi, and use mpi_f08 through this one wrapper compiler
1. mpif77 and mpif90 still exist, but are sym links to mpifort and may be removed in a future release
1. The mpi module has been re-implemented and is significantly "mo' bettah"
1. The mpi_f08 module offers many, many improvements over mpif.h and the mpi module
This stuff is coming from a VERY long-lived mercurial branch (3 years!); it'll almost certainly take a few SVN commits and a bunch of testing before I get it correctly committed to the SVN trunk.
== More details ==
Craig Rasmussen and I have been working with the MPI-3 Fortran WG and Fortran J3 committees for a long, long time to make a prototype MPI-3 Fortran bindings implementation. We think we're at a stable enough state to bring this stuff back to the trunk, with the goal of including it in OMPI v1.7.
Special thanks go out to everyone who has been incredibly patient and helpful to us in this journey:
* Rolf Rabenseifner/HLRS (mastermind/genius behind the entire MPI-3 Fortran effort)
* The Fortran J3 committee
* Tobias Burnus/gfortran
* Tony !Goetz/Absoft
* Terry !Donte/Oracle
* ...and probably others whom I'm forgetting :-(
There's still opportunities for optimization in the mpi_f08 implementation, but by and large, it is as far along as it can be until Fortran compilers start implementing the new F08 dimension(..) syntax.
Note that gfortran is currently unsupported for the mpi_f08 module and the new mpi module. gfortran users will a) fall back to the same mpi module implementation that is in OMPI v1.5.x, and b) not get the new mpi_f08 module. The gfortran maintainers are actively working hard to add the necessary features to support both the new mpi_f08 module and the new mpi module implementations. This will take some time.
As mentioned above, ompi/mpi/f77 and ompi/mpi/f90 no longer exist. All the fortran bindings implementations have been collated under ompi/mpi/fortran; each implementation has its own subdirectory:
{{{
ompi/mpi/fortran/
base/ - glue code
mpif-h/ - what used to be ompi/mpi/f77
use-mpi-tkr/ - what used to be ompi/mpi/f90
use-mpi-ignore-tkr/ - new mpi module implementation
use-mpi-f08/ - new mpi_f08 module implementation
}}}
There's also a prototype 6-function-MPI implementation under use-mpi-f08-desc that emulates the new F08 dimension(..) syntax that isn't fully available in Fortran compilers yet. We did that to prove it to ourselves that it could be done once the compilers fully support it. This directory/implementation will likely eventually replace the use-mpi-f08 version.
Other things that were done:
* ompi_info grew a few new output fields to describe what level of Fortran support is included
* Existing Fortran examples in examples/ were renamed; new mpi_f08 examples were added
* The old Fortran MPI libraries were renamed:
* libmpi_f77 -> libmpi_mpifh
* libmpi_f90 -> libmpi_usempi
* The configury for Fortran was consolidated and significantly slimmed down. Note that the F77 env variable is now IGNORED for configure; you should only use FC. Example:
{{{
shell$ ./configure CC=icc CXX=icpc FC=ifort ...
}}}
All of this work was done in a Mercurial branch off the SVN trunk, and hosted at Bitbucket. This branch has got to be one of OMPI's longest-running branches. Its first commit was Tue Apr 07 23:01:46 2009 -0400 -- it's over 3 years old! :-) We think we've pulled in all relevant changes from the OMPI trunk (e.g., Fortran implementations of the new MPI-3 MPROBE stuff for mpif.h, use mpi, and use mpi_f08, and the recent Fujitsu Fortran patches).
I anticipate some instability when we bring this stuff into the trunk, simply because it touches a LOT of code in the MPI layer in the OMPI code base. We'll try our best to make it as pain-free as possible, but please bear with us when it is committed.
This commit was SVN r26283.
2012-04-18 15:57:29 +00:00
|
|
|
AC_CHECK_HEADERS(complex.h)
|
2018-11-21 19:54:08 +09:00
|
|
|
AC_CHECK_TYPES(short float _Complex)
|
- Split the datatype engine into two parts: an MPI specific part in
OMPI
and a language agnostic part in OPAL. The convertor is completely
moved into OPAL. This offers several benefits as described in RFC
http://www.open-mpi.org/community/lists/devel/2009/07/6387.php
namely:
- Fewer basic types (int* and float* types, boolean and wchar
- Fixing naming scheme to ompi-nomenclature.
- Usability outside of the ompi-layer.
- Due to the fixed nature of simple opal types, their information is
completely
known at compile time and therefore constified
- With fewer datatypes (22), the actual sizes of bit-field types may be
reduced
from 64 to 32 bits, allowing reorganizing the opal_datatype
structure, eliminating holes and keeping data required in convertor
(upon send/recv) in one cacheline...
This has implications to the convertor-datastructure and other parts
of the code.
- Several performance tests have been run, the netpipe latency does not
change with
this patch on Linux/x86-64 on the smoky cluster.
- Extensive tests have been done to verify correctness (no new
regressions) using:
1. mpi_test_suite on linux/x86-64 using clean ompi-trunk and
ompi-ddt:
a. running both trunk and ompi-ddt resulted in no differences
(except for MPI_SHORT_INT and MPI_TYPE_MIX_LB_UB do now run
correctly).
b. with --enable-memchecker and running under valgrind (one buglet
when run with static found in test-suite, commited)
2. ibm testsuite on linux/x86-64 using clean ompi-trunk and ompi-ddt:
all passed (except for the dynamic/ tests failed!! as trunk/MTT)
3. compilation and usage of HDF5 tests on Jaguar using PGI and
PathScale compilers.
4. compilation and usage on Scicortex.
- Please note, that for the heterogeneous case, (-m32 compiled
binaries/ompi), neither
ompi-trunk, nor ompi-ddt branch would successfully launch.
This commit was SVN r21641.
2009-07-13 04:56:31 +00:00
|
|
|
AC_CHECK_TYPES(float _Complex)
|
|
|
|
AC_CHECK_TYPES(double _Complex)
|
|
|
|
AC_CHECK_TYPES(long double _Complex)
|
2016-11-22 15:03:20 -08:00
|
|
|
|
2004-01-09 01:17:00 +00:00
|
|
|
AC_CHECK_TYPES(intptr_t)
|
|
|
|
AC_CHECK_TYPES(uintptr_t)
|
2004-10-13 20:47:52 +00:00
|
|
|
AC_CHECK_TYPES(mode_t)
|
2006-10-20 03:24:59 +00:00
|
|
|
AC_CHECK_TYPES(ssize_t)
|
|
|
|
AC_CHECK_TYPES(ptrdiff_t)
|
2005-05-12 01:42:24 +00:00
|
|
|
|
2004-02-13 18:05:49 +00:00
|
|
|
#
|
|
|
|
# Check for type sizes
|
|
|
|
#
|
|
|
|
|
2015-06-28 13:30:53 -07:00
|
|
|
AC_CHECK_SIZEOF(_Bool)
|
2004-01-09 01:17:00 +00:00
|
|
|
AC_CHECK_SIZEOF(char)
|
|
|
|
AC_CHECK_SIZEOF(short)
|
|
|
|
AC_CHECK_SIZEOF(int)
|
2020-11-14 09:33:14 -05:00
|
|
|
AC_CHECK_SIZEOF(unsigned int)
|
2004-01-09 01:17:00 +00:00
|
|
|
AC_CHECK_SIZEOF(long)
|
2020-11-14 09:33:14 -05:00
|
|
|
AC_CHECK_SIZEOF(unsigned long)
|
2018-11-14 09:57:10 +09:00
|
|
|
AC_CHECK_SIZEOF(long long)
|
2018-11-21 19:54:08 +09:00
|
|
|
if test "$ac_cv_type_short_float" = yes; then
|
|
|
|
AC_CHECK_SIZEOF(short float)
|
|
|
|
fi
|
- Split the datatype engine into two parts: an MPI specific part in
OMPI
and a language agnostic part in OPAL. The convertor is completely
moved into OPAL. This offers several benefits as described in RFC
http://www.open-mpi.org/community/lists/devel/2009/07/6387.php
namely:
- Fewer basic types (int* and float* types, boolean and wchar
- Fixing naming scheme to ompi-nomenclature.
- Usability outside of the ompi-layer.
- Due to the fixed nature of simple opal types, their information is
completely
known at compile time and therefore constified
- With fewer datatypes (22), the actual sizes of bit-field types may be
reduced
from 64 to 32 bits, allowing reorganizing the opal_datatype
structure, eliminating holes and keeping data required in convertor
(upon send/recv) in one cacheline...
This has implications to the convertor-datastructure and other parts
of the code.
- Several performance tests have been run, the netpipe latency does not
change with
this patch on Linux/x86-64 on the smoky cluster.
- Extensive tests have been done to verify correctness (no new
regressions) using:
1. mpi_test_suite on linux/x86-64 using clean ompi-trunk and
ompi-ddt:
a. running both trunk and ompi-ddt resulted in no differences
(except for MPI_SHORT_INT and MPI_TYPE_MIX_LB_UB do now run
correctly).
b. with --enable-memchecker and running under valgrind (one buglet
when run with static found in test-suite, commited)
2. ibm testsuite on linux/x86-64 using clean ompi-trunk and ompi-ddt:
all passed (except for the dynamic/ tests failed!! as trunk/MTT)
3. compilation and usage of HDF5 tests on Jaguar using PGI and
PathScale compilers.
4. compilation and usage on Scicortex.
- Please note, that for the heterogeneous case, (-m32 compiled
binaries/ompi), neither
ompi-trunk, nor ompi-ddt branch would successfully launch.
This commit was SVN r21641.
2009-07-13 04:56:31 +00:00
|
|
|
AC_CHECK_SIZEOF(float)
|
|
|
|
AC_CHECK_SIZEOF(double)
|
2018-11-14 09:57:10 +09:00
|
|
|
AC_CHECK_SIZEOF(long double)
|
2011-08-25 21:56:05 +00:00
|
|
|
if test "$ac_cv_type___float128" = yes; then
|
|
|
|
AC_CHECK_SIZEOF(__float128)
|
|
|
|
fi
|
2009-10-20 23:44:20 +00:00
|
|
|
# We only need these types if we're building the OMPI project, but
|
|
|
|
# OPAL currently doesn't protect for their lack of presence well.
|
2018-11-21 19:54:08 +09:00
|
|
|
if test "$ac_cv_type_short_float__Complex" = yes; then
|
|
|
|
AC_CHECK_SIZEOF(short float _Complex)
|
|
|
|
fi
|
2018-11-14 09:57:10 +09:00
|
|
|
AC_CHECK_SIZEOF(float _Complex)
|
|
|
|
AC_CHECK_SIZEOF(double _Complex)
|
|
|
|
AC_CHECK_SIZEOF(long double _Complex)
|
2016-11-22 15:03:20 -08:00
|
|
|
|
2004-01-09 01:17:00 +00:00
|
|
|
AC_CHECK_SIZEOF(void *)
|
2005-04-05 02:32:36 +00:00
|
|
|
AC_CHECK_SIZEOF(size_t)
|
2011-08-25 21:56:05 +00:00
|
|
|
if test "$ac_cv_type_ssize_t" = yes ; then
|
2006-10-20 03:24:59 +00:00
|
|
|
AC_CHECK_SIZEOF(ssize_t)
|
|
|
|
fi
|
2011-08-25 21:56:05 +00:00
|
|
|
if test "$ac_cv_type_ptrdiff_t" = yes; then
|
2006-10-20 03:24:59 +00:00
|
|
|
AC_CHECK_SIZEOF(ptrdiff_t)
|
2016-05-25 09:16:35 +09:00
|
|
|
else
|
|
|
|
AC_MSG_ERROR([ptrdiff_t type is not available, this is required by C99 standard. Cannot continue])
|
2006-10-20 03:24:59 +00:00
|
|
|
fi
|
2016-11-22 14:24:54 -08:00
|
|
|
AC_CHECK_SIZEOF(wchar_t)
|
2016-11-22 15:03:20 -08:00
|
|
|
|
2014-02-06 11:42:34 +00:00
|
|
|
AC_CHECK_SIZEOF(pid_t)
|
|
|
|
|
2017-07-18 12:06:27 -06:00
|
|
|
# Check sizes of atomic types so we can define fixed-width types in OPAL
|
|
|
|
AC_CHECK_SIZEOF(atomic_short, [],[[#include <stdatomic.h>]])
|
|
|
|
AC_CHECK_SIZEOF(atomic_int,[],[[#include <stdatomic.h>]])
|
|
|
|
AC_CHECK_SIZEOF(atomic_long,[],[[#include <stdatomic.h>]])
|
|
|
|
AC_CHECK_SIZEOF(atomic_llong,[],[[#include <stdatomic.h>]])
|
2016-11-22 15:03:20 -08:00
|
|
|
|
2004-02-13 18:05:49 +00:00
|
|
|
#
|
|
|
|
# Check for type alignments
|
|
|
|
#
|
|
|
|
|
2015-06-24 08:25:49 -07:00
|
|
|
OPAL_C_GET_ALIGNMENT(bool, OPAL_ALIGNMENT_BOOL)
|
2014-05-06 16:50:27 +00:00
|
|
|
OPAL_C_GET_ALIGNMENT(int8_t, OPAL_ALIGNMENT_INT8)
|
|
|
|
OPAL_C_GET_ALIGNMENT(int16_t, OPAL_ALIGNMENT_INT16)
|
|
|
|
OPAL_C_GET_ALIGNMENT(int32_t, OPAL_ALIGNMENT_INT32)
|
|
|
|
OPAL_C_GET_ALIGNMENT(int64_t, OPAL_ALIGNMENT_INT64)
|
- Split the datatype engine into two parts: an MPI specific part in
OMPI
and a language agnostic part in OPAL. The convertor is completely
moved into OPAL. This offers several benefits as described in RFC
http://www.open-mpi.org/community/lists/devel/2009/07/6387.php
namely:
- Fewer basic types (int* and float* types, boolean and wchar
- Fixing naming scheme to ompi-nomenclature.
- Usability outside of the ompi-layer.
- Due to the fixed nature of simple opal types, their information is
completely
known at compile time and therefore constified
- With fewer datatypes (22), the actual sizes of bit-field types may be
reduced
from 64 to 32 bits, allowing reorganizing the opal_datatype
structure, eliminating holes and keeping data required in convertor
(upon send/recv) in one cacheline...
This has implications to the convertor-datastructure and other parts
of the code.
- Several performance tests have been run, the netpipe latency does not
change with
this patch on Linux/x86-64 on the smoky cluster.
- Extensive tests have been done to verify correctness (no new
regressions) using:
1. mpi_test_suite on linux/x86-64 using clean ompi-trunk and
ompi-ddt:
a. running both trunk and ompi-ddt resulted in no differences
(except for MPI_SHORT_INT and MPI_TYPE_MIX_LB_UB do now run
correctly).
b. with --enable-memchecker and running under valgrind (one buglet
when run with static found in test-suite, commited)
2. ibm testsuite on linux/x86-64 using clean ompi-trunk and ompi-ddt:
all passed (except for the dynamic/ tests failed!! as trunk/MTT)
3. compilation and usage of HDF5 tests on Jaguar using PGI and
PathScale compilers.
4. compilation and usage on Scicortex.
- Please note, that for the heterogeneous case, (-m32 compiled
binaries/ompi), neither
ompi-trunk, nor ompi-ddt branch would successfully launch.
This commit was SVN r21641.
2009-07-13 04:56:31 +00:00
|
|
|
if test "$ac_cv_type_int128_t" = yes ; then
|
2014-05-06 16:50:27 +00:00
|
|
|
OPAL_C_GET_ALIGNMENT(int128_t, OPAL_ALIGNMENT_INT128)
|
- Split the datatype engine into two parts: an MPI specific part in
OMPI
and a language agnostic part in OPAL. The convertor is completely
moved into OPAL. This offers several benefits as described in RFC
http://www.open-mpi.org/community/lists/devel/2009/07/6387.php
namely:
- Fewer basic types (int* and float* types, boolean and wchar
- Fixing naming scheme to ompi-nomenclature.
- Usability outside of the ompi-layer.
- Due to the fixed nature of simple opal types, their information is
completely
known at compile time and therefore constified
- With fewer datatypes (22), the actual sizes of bit-field types may be
reduced
from 64 to 32 bits, allowing reorganizing the opal_datatype
structure, eliminating holes and keeping data required in convertor
(upon send/recv) in one cacheline...
This has implications to the convertor-datastructure and other parts
of the code.
- Several performance tests have been run, the netpipe latency does not
change with
this patch on Linux/x86-64 on the smoky cluster.
- Extensive tests have been done to verify correctness (no new
regressions) using:
1. mpi_test_suite on linux/x86-64 using clean ompi-trunk and
ompi-ddt:
a. running both trunk and ompi-ddt resulted in no differences
(except for MPI_SHORT_INT and MPI_TYPE_MIX_LB_UB do now run
correctly).
b. with --enable-memchecker and running under valgrind (one buglet
when run with static found in test-suite, commited)
2. ibm testsuite on linux/x86-64 using clean ompi-trunk and ompi-ddt:
all passed (except for the dynamic/ tests failed!! as trunk/MTT)
3. compilation and usage of HDF5 tests on Jaguar using PGI and
PathScale compilers.
4. compilation and usage on Scicortex.
- Please note, that for the heterogeneous case, (-m32 compiled
binaries/ompi), neither
ompi-trunk, nor ompi-ddt branch would successfully launch.
This commit was SVN r21641.
2009-07-13 04:56:31 +00:00
|
|
|
fi
|
2014-05-06 16:50:27 +00:00
|
|
|
OPAL_C_GET_ALIGNMENT(char, OPAL_ALIGNMENT_CHAR)
|
|
|
|
OPAL_C_GET_ALIGNMENT(short, OPAL_ALIGNMENT_SHORT)
|
|
|
|
OPAL_C_GET_ALIGNMENT(wchar_t, OPAL_ALIGNMENT_WCHAR)
|
|
|
|
OPAL_C_GET_ALIGNMENT(int, OPAL_ALIGNMENT_INT)
|
|
|
|
OPAL_C_GET_ALIGNMENT(long, OPAL_ALIGNMENT_LONG)
|
2018-11-14 09:57:10 +09:00
|
|
|
OPAL_C_GET_ALIGNMENT(long long, OPAL_ALIGNMENT_LONG_LONG)
|
2018-11-21 19:54:08 +09:00
|
|
|
if test "$ac_cv_type_short_float" = yes; then
|
|
|
|
OPAL_C_GET_ALIGNMENT(short float, OPAL_ALIGNMENT_SHORT_FLOAT)
|
|
|
|
fi
|
2014-05-06 16:50:27 +00:00
|
|
|
OPAL_C_GET_ALIGNMENT(float, OPAL_ALIGNMENT_FLOAT)
|
|
|
|
OPAL_C_GET_ALIGNMENT(double, OPAL_ALIGNMENT_DOUBLE)
|
2018-11-14 09:57:10 +09:00
|
|
|
OPAL_C_GET_ALIGNMENT(long double, OPAL_ALIGNMENT_LONG_DOUBLE)
|
2011-08-25 21:56:05 +00:00
|
|
|
if test "$ac_cv_type___float128" = yes; then
|
2014-05-06 16:50:27 +00:00
|
|
|
OPAL_C_GET_ALIGNMENT(__float128, OPAL_ALIGNMENT___FLOAT128)
|
2011-08-25 21:56:05 +00:00
|
|
|
fi
|
|
|
|
|
2016-11-22 15:03:20 -08:00
|
|
|
|
2009-10-20 23:44:20 +00:00
|
|
|
# We only need these types if we're building the OMPI project, but
|
|
|
|
# OPAL currently doesn't protect for their lack of presence well.
|
2018-11-21 19:54:08 +09:00
|
|
|
if test "$ac_cv_type_short_float__Complex" = yes; then
|
|
|
|
OPAL_C_GET_ALIGNMENT(short float _Complex, OPAL_ALIGNMENT_SHORT_FLOAT_COMPLEX)
|
|
|
|
fi
|
2018-11-14 09:57:10 +09:00
|
|
|
OPAL_C_GET_ALIGNMENT(float _Complex, OPAL_ALIGNMENT_FLOAT_COMPLEX)
|
|
|
|
OPAL_C_GET_ALIGNMENT(double _Complex, OPAL_ALIGNMENT_DOUBLE_COMPLEX)
|
|
|
|
OPAL_C_GET_ALIGNMENT(long double _Complex, OPAL_ALIGNMENT_LONG_DOUBLE_COMPLEX)
|
- Split the datatype engine into two parts: an MPI specific part in
OMPI
and a language agnostic part in OPAL. The convertor is completely
moved into OPAL. This offers several benefits as described in RFC
http://www.open-mpi.org/community/lists/devel/2009/07/6387.php
namely:
- Fewer basic types (int* and float* types, boolean and wchar
- Fixing naming scheme to ompi-nomenclature.
- Usability outside of the ompi-layer.
- Due to the fixed nature of simple opal types, their information is
completely
known at compile time and therefore constified
- With fewer datatypes (22), the actual sizes of bit-field types may be
reduced
from 64 to 32 bits, allowing reorganizing the opal_datatype
structure, eliminating holes and keeping data required in convertor
(upon send/recv) in one cacheline...
This has implications to the convertor-datastructure and other parts
of the code.
- Several performance tests have been run, the netpipe latency does not
change with
this patch on Linux/x86-64 on the smoky cluster.
- Extensive tests have been done to verify correctness (no new
regressions) using:
1. mpi_test_suite on linux/x86-64 using clean ompi-trunk and
ompi-ddt:
a. running both trunk and ompi-ddt resulted in no differences
(except for MPI_SHORT_INT and MPI_TYPE_MIX_LB_UB do now run
correctly).
b. with --enable-memchecker and running under valgrind (one buglet
when run with static found in test-suite, commited)
2. ibm testsuite on linux/x86-64 using clean ompi-trunk and ompi-ddt:
all passed (except for the dynamic/ tests failed!! as trunk/MTT)
3. compilation and usage of HDF5 tests on Jaguar using PGI and
PathScale compilers.
4. compilation and usage on Scicortex.
- Please note, that for the heterogeneous case, (-m32 compiled
binaries/ompi), neither
ompi-trunk, nor ompi-ddt branch would successfully launch.
This commit was SVN r21641.
2009-07-13 04:56:31 +00:00
|
|
|
|
2014-05-06 16:50:27 +00:00
|
|
|
OPAL_C_GET_ALIGNMENT(void *, OPAL_ALIGNMENT_VOID_P)
|
|
|
|
OPAL_C_GET_ALIGNMENT(size_t, OPAL_ALIGNMENT_SIZE_T)
|
2004-02-13 18:05:49 +00:00
|
|
|
|
2018-11-21 19:55:43 +09:00
|
|
|
#
|
|
|
|
# Check for an alternate type of C 'short float'
|
|
|
|
#
|
|
|
|
|
|
|
|
OPAL_CHECK_ALT_SHORT_FLOAT
|
|
|
|
|
2004-02-13 18:05:49 +00:00
|
|
|
#
|
|
|
|
# Check for other compiler characteristics
|
|
|
|
#
|
2004-01-07 07:49:23 +00:00
|
|
|
|
2014-05-06 18:03:08 +00:00
|
|
|
OPAL_C_WEAK_SYMBOLS
|
2014-08-23 10:50:14 +00:00
|
|
|
OPAL_C_MACRO_WEAK_SYMBOLS
|
2003-11-22 16:36:58 +00:00
|
|
|
|
2005-05-10 09:09:04 +00:00
|
|
|
if test "x$CC" = "xicc"; then
|
2014-05-06 19:22:27 +00:00
|
|
|
OPAL_CHECK_ICC_VARARGS
|
2005-05-10 09:09:04 +00:00
|
|
|
fi
|
|
|
|
|
2016-11-22 15:03:20 -08:00
|
|
|
# If we want the profiling layer:
|
|
|
|
# - If the C compiler has weak symbols, use those.
|
|
|
|
# - If not, then set to compile the code again with #define's in a
|
|
|
|
# separate directory.
|
|
|
|
|
|
|
|
if test "$WANT_WEAK_SYMBOLS" = "0"; then
|
|
|
|
OPAL_C_HAVE_WEAK_SYMBOLS=0
|
|
|
|
fi
|
|
|
|
if test "$OPAL_C_HAVE_WEAK_SYMBOLS" = "1"; then
|
|
|
|
OMPI_PROFILING_COMPILE_SEPARATELY=0
|
|
|
|
else
|
|
|
|
OMPI_PROFILING_COMPILE_SEPARATELY=1
|
|
|
|
fi
|
|
|
|
|
2009-06-27 23:36:25 +00:00
|
|
|
# Check if we support the offsetof compiler directive
|
2016-11-22 15:03:20 -08:00
|
|
|
|
2009-06-27 23:36:25 +00:00
|
|
|
OPAL_CHECK_OFFSETOF
|
|
|
|
|
2016-11-22 15:03:20 -08:00
|
|
|
|
2003-11-22 16:36:58 +00:00
|
|
|
##################################
|
2016-11-22 15:03:20 -08:00
|
|
|
# C++ compiler characteristics
|
|
|
|
##################################
|
|
|
|
|
2020-02-18 22:42:21 -08:00
|
|
|
# We don't need C++ unless we're building Open MPI, because Open MPI
|
|
|
|
# supports an "mpicxx" wrapper compiler (there is no C++ code in Open
|
|
|
|
# MPI -- the MPI C++ bindings were removed in Open MPI v5.0 -- so we
|
|
|
|
# don't need a C++ compiler for compiling Open MPI itself).
|
|
|
|
m4_ifdef([project_ompi], [OMPI_SETUP_CXX])
|
2016-11-22 15:03:20 -08:00
|
|
|
|
|
|
|
##################################
|
|
|
|
# Only after setting up both
|
|
|
|
# C and C++ check compiler attributes.
|
2007-02-08 13:34:44 +00:00
|
|
|
##################################
|
2009-08-04 11:54:01 +00:00
|
|
|
|
2014-05-05 22:35:23 +00:00
|
|
|
opal_show_subtitle "Compiler characteristics"
|
2009-08-04 11:54:01 +00:00
|
|
|
|
2010-06-12 03:15:47 +00:00
|
|
|
OPAL_CHECK_ATTRIBUTES
|
- As proposed in RFC and telcon, warn the user about deprecated
functionality (per MPI-2.1). This warning can be toggled using
--enable-mpi-interface-warning (default OFF), but can be
selectively turned on passing
mpicc -DOMPI_WANT_MPI_INTERFACE_WARNING
Using icc, gcc < 4.5, warnings (such as in mpi2basic_tests) show:
type_vector.c:83: warning: ‘MPI_Type_hvector’ is deprecated
(declared at /home/../usr/include/mpi.h:1379)
Using gcc-4.5 (gcc-svn) these show up as:
type_vector.c:83: warning: ‘MPI_Type_hvector’ is deprecated
(declared at /home/../usr/include/mpi.h:1379):
MPI_Type_hvector is superseded by MPI_Type_create_hvector in MPI-2.0
Jeff and I propose to turn such warnings on with Open MPI-1.7 by default.
- Detection of user-level compiler is handled using the preprocessor
checks of GASnet's other/portable_platform.h (thanks to Paul Hargrove
and Dan Bonachea) adapted into ompi/include/mpi_portable_platform.h
(see comments).
The OMPI-build time detection is output (Familyname and Version)
with ompi_info.
This functionality (actually any upcoming __attribute__) are turned
off, if a different compiler (and version) is being detected.
- Note, that any warnings regarding (user-compiler!=build-compiler)
as discussed in the RFC are _not_ included for now.
- Tested on Linux with --enable-mpi-interface-warning on
Linux, gcc-4.5 (deprecated w/ specific msg)
Linux, gcc-4.3 (deprecated w/o specific msg)
Linux, pathscale 3.1 (deprecated w/o specific msg)
Linux, icc-11.0 (deprecated w/o specific msg)
Linux, PGI-8.0.6 accepts __deprecated__ but does not issue a warning,
further investigation needed...
This commit was SVN r21262.
2009-05-22 04:39:43 +00:00
|
|
|
OPAL_CHECK_COMPILER_VERSION_ID
|
2004-01-07 07:49:23 +00:00
|
|
|
|
2016-11-22 15:03:20 -08:00
|
|
|
|
|
|
|
##################################
|
|
|
|
# Java MPI Binding request
|
|
|
|
##################################
|
|
|
|
# Only needed for OMPI
|
|
|
|
m4_ifdef([project_ompi], [OMPI_SETUP_JAVA_BINDINGS])
|
|
|
|
|
|
|
|
|
|
|
|
##################################
|
|
|
|
# MPI / OpenSHMEM API profiling layer
|
|
|
|
##################################
|
|
|
|
|
|
|
|
# Setup profiling bindings (if we're building the relevant projects).
|
|
|
|
m4_ifdef([project_ompi], [OMPI_SETUP_MPI_PROFILING])
|
|
|
|
m4_ifdef([project_oshmem], [OSHMEM_SETUP_PROFILING])
|
|
|
|
|
|
|
|
|
2005-01-27 01:39:55 +00:00
|
|
|
##################################
|
|
|
|
# Assembler Configuration
|
|
|
|
##################################
|
|
|
|
|
2014-05-05 22:35:23 +00:00
|
|
|
opal_show_subtitle "Assembler"
|
2005-01-27 01:39:55 +00:00
|
|
|
|
|
|
|
AM_PROG_AS
|
2010-07-27 04:51:50 +00:00
|
|
|
OPAL_CONFIG_ASM
|
2005-01-27 01:39:55 +00:00
|
|
|
|
2016-11-22 15:03:20 -08:00
|
|
|
|
|
|
|
##################################
|
|
|
|
# Fortran
|
|
|
|
##################################
|
|
|
|
|
|
|
|
OMPI_BUILD_FORTRAN_BINDINGS=0
|
|
|
|
|
|
|
|
m4_ifdef([project_ompi], [OMPI_SETUP_MPI_FORTRAN], [ompi_fortran_happy=0])
|
|
|
|
|
|
|
|
# Used in Makefile.ompi-rules
|
|
|
|
AM_CONDITIONAL(MAN_PAGE_BUILD_MPIFH_BINDINGS,
|
|
|
|
[test $OMPI_BUILD_FORTRAN_BINDINGS -gt $OMPI_FORTRAN_NO_BINDINGS])
|
|
|
|
AM_CONDITIONAL(MAN_PAGE_BUILD_USEMPIF08_BINDINGS,
|
|
|
|
[test $OMPI_BUILD_FORTRAN_BINDINGS -ge $OMPI_FORTRAN_USEMPIF08_BINDINGS])
|
|
|
|
|
|
|
|
AM_CONDITIONAL(OSHMEM_BUILD_FORTRAN_BINDINGS,
|
|
|
|
[test "$enable_oshmem" = "yes" && \
|
|
|
|
test "$ompi_fortran_happy" = "1" && \
|
|
|
|
test "$OMPI_TRY_FORTRAN_BINDINGS" -gt "$OMPI_FORTRAN_NO_BINDINGS" && \
|
|
|
|
test "$enable_oshmem_fortran" != "no"])
|
|
|
|
|
|
|
|
# checkpoint results
|
|
|
|
AC_CACHE_SAVE
|
|
|
|
|
|
|
|
|
2003-11-22 16:36:58 +00:00
|
|
|
##################################
|
|
|
|
# Header files
|
|
|
|
##################################
|
|
|
|
|
2014-05-05 22:35:23 +00:00
|
|
|
opal_show_title "Header file tests"
|
2004-03-28 10:52:58 +00:00
|
|
|
|
2005-04-15 21:18:20 +00:00
|
|
|
AC_CHECK_HEADERS([alloca.h aio.h arpa/inet.h dirent.h \
|
2017-07-07 09:22:34 +09:00
|
|
|
dlfcn.h endian.h execinfo.h err.h fcntl.h grp.h libgen.h \
|
2009-03-05 02:40:25 +00:00
|
|
|
libutil.h memory.h netdb.h netinet/in.h netinet/tcp.h \
|
2015-06-24 10:00:01 -06:00
|
|
|
poll.h pthread.h pty.h pwd.h sched.h \
|
2016-05-04 08:14:17 +02:00
|
|
|
strings.h stropts.h linux/ethtool.h linux/sockios.h \
|
2016-09-23 11:19:47 +09:00
|
|
|
sys/fcntl.h sys/ipc.h sys/shm.h \
|
2012-12-22 16:32:26 +00:00
|
|
|
sys/ioctl.h sys/mman.h sys/param.h sys/queue.h \
|
2005-04-15 21:18:20 +00:00
|
|
|
sys/resource.h sys/select.h sys/socket.h sys/sockio.h \
|
2015-06-24 10:00:01 -06:00
|
|
|
sys/stat.h sys/statfs.h sys/statvfs.h sys/time.h sys/tree.h \
|
2014-01-26 21:05:45 +00:00
|
|
|
sys/types.h sys/uio.h sys/un.h net/uio.h sys/utsname.h sys/vfs.h sys/wait.h syslog.h \
|
2015-06-24 10:00:01 -06:00
|
|
|
termios.h ulimit.h unistd.h util.h utmp.h malloc.h \
|
|
|
|
ifaddrs.h crt_externs.h regex.h mntent.h paths.h \
|
2020-03-03 08:47:39 -08:00
|
|
|
ioLib.h sockLib.h hostLib.h shlwapi.h sys/synch.h db.h ndbm.h ieee754.h])
|
2004-09-29 19:42:16 +00:00
|
|
|
|
2012-12-22 16:32:26 +00:00
|
|
|
AC_CHECK_HEADERS([sys/mount.h], [], [],
|
|
|
|
[AC_INCLUDES_DEFAULT
|
|
|
|
#if HAVE_SYS_PARAM_H
|
|
|
|
#include <sys/param.h>
|
|
|
|
#endif
|
|
|
|
])
|
|
|
|
|
|
|
|
AC_CHECK_HEADERS([sys/sysctl.h], [], [],
|
|
|
|
[AC_INCLUDES_DEFAULT
|
|
|
|
#if HAVE_SYS_PARAM_H
|
|
|
|
#include <sys/param.h>
|
|
|
|
#endif
|
|
|
|
])
|
|
|
|
|
2006-01-12 03:19:37 +00:00
|
|
|
# Needed to work around Darwin requiring sys/socket.h for
|
|
|
|
# net/if.h
|
|
|
|
AC_CHECK_HEADERS([net/if.h], [], [],
|
|
|
|
[#include <stdio.h>
|
|
|
|
#if STDC_HEADERS
|
|
|
|
# include <stdlib.h>
|
|
|
|
# include <stddef.h>
|
|
|
|
#else
|
|
|
|
# if HAVE_STDLIB_H
|
|
|
|
# include <stdlib.h>
|
|
|
|
# endif
|
|
|
|
#endif
|
|
|
|
#if HAVE_SYS_SOCKET_H
|
|
|
|
# include <sys/socket.h>
|
|
|
|
#endif
|
|
|
|
])
|
|
|
|
|
2005-07-09 18:52:53 +00:00
|
|
|
# checkpoint results
|
|
|
|
AC_CACHE_SAVE
|
|
|
|
|
2016-11-22 15:03:20 -08:00
|
|
|
|
2005-07-13 04:16:03 +00:00
|
|
|
##################################
|
|
|
|
# Types
|
|
|
|
##################################
|
|
|
|
|
2014-05-05 22:35:23 +00:00
|
|
|
opal_show_title "Type tests"
|
2005-07-13 04:16:03 +00:00
|
|
|
|
2009-03-16 02:04:22 +00:00
|
|
|
AC_CHECK_TYPES([socklen_t, struct sockaddr_in, struct sockaddr_in6,
|
2016-05-04 08:14:17 +02:00
|
|
|
struct sockaddr_storage, struct ifreq, struct ethtool_cmd],
|
2007-07-20 01:34:02 +00:00
|
|
|
[], [], [AC_INCLUDES_DEFAULT
|
|
|
|
#if HAVE_SYS_SOCKET_H
|
2007-05-20 21:54:43 +00:00
|
|
|
#include <sys/socket.h>
|
2007-07-20 01:34:02 +00:00
|
|
|
#endif
|
2007-05-17 01:17:59 +00:00
|
|
|
#ifdef HAVE_NETINET_IN_H
|
|
|
|
#include <netinet/in.h>
|
2016-05-04 08:14:17 +02:00
|
|
|
#endif
|
|
|
|
#ifdef HAVE_LINUX_ETHTOOL_H
|
|
|
|
#include <linux/ethtool.h>
|
|
|
|
#endif
|
|
|
|
#ifdef HAVE_NET_IF_H
|
|
|
|
#include <net/if.h>
|
|
|
|
#endif])
|
|
|
|
|
|
|
|
AC_CHECK_DECLS([ethtool_cmd_speed, SIOCETHTOOL],
|
|
|
|
[], [], [AC_INCLUDES_DEFAULT
|
|
|
|
#ifdef HAVE_LINUX_ETHTOOL_H
|
|
|
|
#include <linux/ethtool.h>
|
|
|
|
#endif
|
|
|
|
#ifdef HAVE_LINUX_SOCKIOS_H
|
|
|
|
#include <linux/sockios.h>
|
2007-05-17 01:17:59 +00:00
|
|
|
#endif])
|
2007-07-20 01:34:02 +00:00
|
|
|
|
2016-05-19 11:42:22 +09:00
|
|
|
AC_CHECK_MEMBERS([struct ethtool_cmd.speed_hi],
|
|
|
|
[], [], [AC_INCLUDES_DEFAULT
|
|
|
|
#ifdef HAVE_LINUX_ETHTOOL_H
|
|
|
|
#include <linux/ethtool.h>
|
|
|
|
#endif
|
|
|
|
#ifdef HAVE_LINUX_SOCKIOS_H
|
|
|
|
#include <linux/sockios.h>
|
|
|
|
#endif])
|
|
|
|
|
|
|
|
AC_CHECK_MEMBERS([struct ethtool_cmd.speed_hi],
|
|
|
|
[], [], [AC_INCLUDES_DEFAULT
|
|
|
|
#ifdef HAVE_LINUX_ETHTOOL_H
|
|
|
|
#include <linux/ethtool.h>
|
|
|
|
#endif
|
|
|
|
#ifdef HAVE_LINUX_SOCKIOS_H
|
|
|
|
#include <linux/sockios.h>
|
|
|
|
#endif])
|
|
|
|
|
|
|
|
AC_CHECK_MEMBERS([struct ethtool_cmd.speed_hi],
|
|
|
|
[], [], [AC_INCLUDES_DEFAULT
|
|
|
|
#ifdef HAVE_LINUX_ETHTOOL_H
|
|
|
|
#include <linux/ethtool.h>
|
|
|
|
#endif
|
|
|
|
#ifdef HAVE_LINUX_SOCKIOS_H
|
|
|
|
#include <linux/sockios.h>
|
|
|
|
#endif])
|
|
|
|
|
|
|
|
AC_CHECK_MEMBERS([struct ethtool_cmd.speed_hi],
|
|
|
|
[], [], [AC_INCLUDES_DEFAULT
|
|
|
|
#ifdef HAVE_LINUX_ETHTOOL_H
|
|
|
|
#include <linux/ethtool.h>
|
|
|
|
#endif
|
|
|
|
#ifdef HAVE_LINUX_SOCKIOS_H
|
|
|
|
#include <linux/sockios.h>
|
|
|
|
#endif])
|
|
|
|
|
2009-03-16 02:04:22 +00:00
|
|
|
AC_CHECK_DECLS([AF_UNSPEC, PF_UNSPEC, AF_INET6, PF_INET6],
|
2007-07-20 01:34:02 +00:00
|
|
|
[], [], [AC_INCLUDES_DEFAULT
|
|
|
|
#if HAVE_SYS_SOCKET_H
|
2007-05-27 03:52:56 +00:00
|
|
|
#include <sys/socket.h>
|
2007-07-20 01:34:02 +00:00
|
|
|
#endif
|
2007-05-17 01:17:59 +00:00
|
|
|
#ifdef HAVE_NETINET_IN_H
|
|
|
|
#include <netinet/in.h>
|
|
|
|
#endif])
|
2006-09-08 00:10:40 +00:00
|
|
|
|
2005-07-13 04:16:03 +00:00
|
|
|
# SA_RESTART in signal.h
|
2013-12-06 23:40:34 +00:00
|
|
|
OPAL_VAR_SCOPE_PUSH([MSG])
|
2005-07-13 04:16:03 +00:00
|
|
|
AC_MSG_CHECKING([if SA_RESTART defined in signal.h])
|
|
|
|
AC_EGREP_CPP(yes, [
|
|
|
|
#include <signal.h>
|
|
|
|
#ifdef SA_RESTART
|
|
|
|
yes
|
|
|
|
#endif ], [MSG=yes VALUE=1], [MSG=no VALUE=0])
|
2009-05-06 20:11:28 +00:00
|
|
|
AC_DEFINE_UNQUOTED(OPAL_HAVE_SA_RESTART, $VALUE,
|
2005-07-13 04:16:03 +00:00
|
|
|
[Whether we have SA_RESTART in <signal.h> or not])
|
|
|
|
AC_MSG_RESULT([$MSG])
|
2013-12-06 23:40:34 +00:00
|
|
|
OPAL_VAR_SCOPE_POP
|
2005-07-13 04:16:03 +00:00
|
|
|
|
2007-07-20 01:34:02 +00:00
|
|
|
AC_CHECK_MEMBERS([struct sockaddr.sa_len], [], [], [
|
|
|
|
#include <sys/types.h>
|
|
|
|
#if HAVE_SYS_SOCKET_H
|
|
|
|
#include <sys/socket.h>
|
|
|
|
#endif])
|
2005-07-13 04:16:03 +00:00
|
|
|
|
|
|
|
AC_CHECK_MEMBERS([struct dirent.d_type], [], [], [
|
|
|
|
#include <sys/types.h>
|
|
|
|
#include <dirent.h>])
|
|
|
|
|
|
|
|
AC_CHECK_MEMBERS([siginfo_t.si_fd],,,[#include <signal.h>])
|
2005-12-15 00:51:28 +00:00
|
|
|
AC_CHECK_MEMBERS([siginfo_t.si_band],,,[#include <signal.h>])
|
2005-07-13 04:16:03 +00:00
|
|
|
|
2014-01-09 21:28:52 +00:00
|
|
|
#
|
|
|
|
# Checks for struct member names in struct statfs
|
|
|
|
#
|
|
|
|
AC_CHECK_MEMBERS([struct statfs.f_type], [], [], [
|
|
|
|
AC_INCLUDES_DEFAULT
|
|
|
|
#ifdef HAVE_SYS_VFS_H
|
|
|
|
#include <sys/vfs.h>
|
|
|
|
#endif
|
2014-01-11 01:07:10 +00:00
|
|
|
#ifdef HAVE_SYS_STATFS_H
|
2014-01-09 21:28:52 +00:00
|
|
|
#include <sys/statfs.h>
|
|
|
|
#endif
|
|
|
|
])
|
|
|
|
|
|
|
|
AC_CHECK_MEMBERS([struct statfs.f_fstypename], [], [], [
|
|
|
|
AC_INCLUDES_DEFAULT
|
|
|
|
#ifdef HAVE_SYS_PARAM_H
|
|
|
|
#include <sys/param.h>
|
|
|
|
#endif
|
|
|
|
#ifdef HAVE_SYS_MOUNT_H
|
|
|
|
#include <sys/mount.h>
|
|
|
|
#endif
|
|
|
|
#ifdef HAVE_SYS_VFS_H
|
|
|
|
#include <sys/vfs.h>
|
|
|
|
#endif
|
2014-01-11 01:07:10 +00:00
|
|
|
#ifdef HAVE_SYS_STATFS_H
|
2014-01-09 21:28:52 +00:00
|
|
|
#include <sys/statfs.h>
|
|
|
|
#endif
|
|
|
|
])
|
|
|
|
|
|
|
|
#
|
|
|
|
# Checks for struct member names in struct statvfs
|
|
|
|
#
|
|
|
|
AC_CHECK_MEMBERS([struct statvfs.f_basetype], [], [], [
|
|
|
|
AC_INCLUDES_DEFAULT
|
2014-01-11 01:07:10 +00:00
|
|
|
#ifdef HAVE_SYS_STATVFS_H
|
|
|
|
#include <sys/statvfs.h>
|
|
|
|
#endif
|
|
|
|
])
|
|
|
|
|
|
|
|
AC_CHECK_MEMBERS([struct statvfs.f_fstypename], [], [], [
|
|
|
|
AC_INCLUDES_DEFAULT
|
|
|
|
#ifdef HAVE_SYS_STATVFS_H
|
2014-01-09 21:28:52 +00:00
|
|
|
#include <sys/statvfs.h>
|
|
|
|
#endif
|
|
|
|
])
|
|
|
|
|
Fixes trac:4205: ensure sizeof(MPI_Count) <= sizeof(size_t)
- Move the ptrdiff_t tests up higher in configure.ac to be with the
rest of the type tests.
- Create new OMPI_FIND_MPI_AINT_COUNT_OFFSET for finding the
corresponding types of MPI_Aint, MPI_Count, and MPI_Offset.
Consolidate all the old C and Fortran tests into this new macro (and
.m4 file).
- Fix Fortran MPI_*_KIND tests that incorrectly keyed off assumed
types (e.g., int64_t) rather than whatever the corresponding C
MPI_Aint, MPI_Count, MPI_Offset types turned out to be.
- Add new logic to ensure that sizeof(MPI_Count) <= sizeof(size_t),
because our entire PML, BTL, and convertor infrastructure requires
this. As a side effect, just like MPI_Offset the same type of
MPI_Count (because MPI_Count has to be able to hold an MPI_Offset,
so we can't let MPI_Offset be larger than a MPI_Count).
This commit was SVN r30776.
The following Trac tickets were found above:
Ticket 4205 --> https://svn.open-mpi.org/trac/ompi/ticket/4205
2014-02-19 23:04:34 +00:00
|
|
|
#
|
|
|
|
# Find corresponding types for MPI_Aint, MPI_Count, and MPI_Offset.
|
|
|
|
# And if relevant, find the corresponding MPI_ADDRESS_KIND,
|
|
|
|
# MPI_COUNT_KIND, and MPI_OFFSET_KIND.
|
|
|
|
#
|
2016-11-22 15:03:20 -08:00
|
|
|
m4_ifdef([project_ompi], [OMPI_FIND_MPI_AINT_COUNT_OFFSET])
|
2005-07-13 04:16:03 +00:00
|
|
|
|
|
|
|
# checkpoint results
|
|
|
|
AC_CACHE_SAVE
|
|
|
|
|
2015-04-14 15:34:21 -06:00
|
|
|
##################################
|
|
|
|
# Linker characteristics
|
|
|
|
##################################
|
|
|
|
|
|
|
|
AC_MSG_CHECKING([the linker for support for the -fini option])
|
2015-04-20 15:06:23 -06:00
|
|
|
OPAL_VAR_SCOPE_PUSH([LDFLAGS_save])
|
2015-04-14 15:34:21 -06:00
|
|
|
LDFLAGS_save=$LDFLAGS
|
|
|
|
LDFLAGS="$LDFLAGS_save -Wl,-fini -Wl,finalize"
|
|
|
|
AC_TRY_LINK([void finalize (void) {}], [], [AC_MSG_RESULT([yes])
|
2015-04-20 09:51:06 -06:00
|
|
|
opal_ld_have_fini=1], [AC_MSG_RESULT([no])
|
|
|
|
opal_ld_have_fini=0])
|
2015-04-14 15:34:21 -06:00
|
|
|
LDFLAGS=$LDFLAGS_save
|
2015-04-20 15:06:23 -06:00
|
|
|
OPAL_VAR_SCOPE_POP
|
2005-07-13 04:16:03 +00:00
|
|
|
|
2003-11-22 16:36:58 +00:00
|
|
|
##################################
|
|
|
|
# Libraries
|
|
|
|
##################################
|
|
|
|
|
2014-05-05 22:35:23 +00:00
|
|
|
opal_show_title "Library and Function tests"
|
2004-03-28 10:02:38 +00:00
|
|
|
|
2008-08-13 20:56:06 +00:00
|
|
|
# Darwin doesn't need -lutil, as it's something other than this -lutil.
|
configury: ensure wrapper static LIBS is filled properly
In core library portions of the configury (e.g., top-level
configure.ac itself), we were calling AC_CHECK_LIB and
OPAL_CHECK_FUNC_LIB to check for various libraries.
'''SIDENOTE:''' It turns out that modern Autoconf has AC_SEARCH_LIBS,
which does just about exactly what OPAL_CHECK_FUNC_LIB does. So this
commit effectively replaces OPAL_CHECK_FUNC_LIB with AC_SEARCH_LIBS.
However, we never bothered to add these found libraries to the wrapper
compiler list of libraries used for static linking (doh!). We've been
getting lucky for quite a while that components were adding the same
libraries to their wrapper compiler LIBS list.
This is problematic, however, if we don't build some of these
components. For example, Paul Hargrove noticed that if he configured
with --disable-shared --enable-static --disable-io-romio, ROMIO was no
longer adding some libraries to the wrapper LIBS list -- libraries
that just happened to also be needed by core OPAL/ORTE/OMPI layers.
The solution is not to use AC_CHECK_LIB or OPAL_CHECK_FUNC_LIB, but
use a pair of new macros:
* OPAL_SEARCH_LIBS_CORE: a wrapper around AC_SEARCH_LIBS. If we add
something to $LIBS, then also add it to the wrapper list of static
libraries. This is the main piece of functionality that was
wrong/missing.
* OPAL_SEARCH_LIBS_COMPONENT: similar to OPAL_SEARCH_LIBS_CORE, but
instead of directly adding it to the wrapper list of static
libaries, add it to <framework>_<component>_LIBS (which eventually
gets slurped up into the wrapper list of static libraries. See the
lengthy comment in config/opal_setup_wrappers.m4 near the beginning
of OPAL_SETUP_WRAPPER_INIT() for a more detailed explanation).
Most components did this correctly already, but one or two weren't
right, so I implemented this second macro quite similar to the
first and put it everywhere we already used AC_SEARCH_LIBS or
OPAL_CHECK_FUNC_LIB.
This needs to soak for a day or two on the trunk before moving to the
v1.8 branch.
Refs trac:4834
cmr=v1.8.2:reviewer=ggouaillardet
This commit was SVN r32447.
The following Trac tickets were found above:
Ticket 4834 --> https://svn.open-mpi.org/trac/ompi/ticket/4834
2014-08-07 23:54:45 +00:00
|
|
|
OPAL_SEARCH_LIBS_CORE([openpty], [util])
|
2005-08-24 21:24:17 +00:00
|
|
|
|
2014-08-08 01:43:22 +00:00
|
|
|
OPAL_SEARCH_LIBS_CORE([gethostbyname], [nsl])
|
2005-08-24 21:24:17 +00:00
|
|
|
|
configury: ensure wrapper static LIBS is filled properly
In core library portions of the configury (e.g., top-level
configure.ac itself), we were calling AC_CHECK_LIB and
OPAL_CHECK_FUNC_LIB to check for various libraries.
'''SIDENOTE:''' It turns out that modern Autoconf has AC_SEARCH_LIBS,
which does just about exactly what OPAL_CHECK_FUNC_LIB does. So this
commit effectively replaces OPAL_CHECK_FUNC_LIB with AC_SEARCH_LIBS.
However, we never bothered to add these found libraries to the wrapper
compiler list of libraries used for static linking (doh!). We've been
getting lucky for quite a while that components were adding the same
libraries to their wrapper compiler LIBS list.
This is problematic, however, if we don't build some of these
components. For example, Paul Hargrove noticed that if he configured
with --disable-shared --enable-static --disable-io-romio, ROMIO was no
longer adding some libraries to the wrapper LIBS list -- libraries
that just happened to also be needed by core OPAL/ORTE/OMPI layers.
The solution is not to use AC_CHECK_LIB or OPAL_CHECK_FUNC_LIB, but
use a pair of new macros:
* OPAL_SEARCH_LIBS_CORE: a wrapper around AC_SEARCH_LIBS. If we add
something to $LIBS, then also add it to the wrapper list of static
libraries. This is the main piece of functionality that was
wrong/missing.
* OPAL_SEARCH_LIBS_COMPONENT: similar to OPAL_SEARCH_LIBS_CORE, but
instead of directly adding it to the wrapper list of static
libaries, add it to <framework>_<component>_LIBS (which eventually
gets slurped up into the wrapper list of static libraries. See the
lengthy comment in config/opal_setup_wrappers.m4 near the beginning
of OPAL_SETUP_WRAPPER_INIT() for a more detailed explanation).
Most components did this correctly already, but one or two weren't
right, so I implemented this second macro quite similar to the
first and put it everywhere we already used AC_SEARCH_LIBS or
OPAL_CHECK_FUNC_LIB.
This needs to soak for a day or two on the trunk before moving to the
v1.8 branch.
Refs trac:4834
cmr=v1.8.2:reviewer=ggouaillardet
This commit was SVN r32447.
The following Trac tickets were found above:
Ticket 4834 --> https://svn.open-mpi.org/trac/ompi/ticket/4834
2014-08-07 23:54:45 +00:00
|
|
|
OPAL_SEARCH_LIBS_CORE([socket], [socket])
|
2006-01-16 01:48:03 +00:00
|
|
|
|
2009-08-12 13:07:04 +00:00
|
|
|
# Solaris has sched_yield in -lrt, usually in libc
|
configury: ensure wrapper static LIBS is filled properly
In core library portions of the configury (e.g., top-level
configure.ac itself), we were calling AC_CHECK_LIB and
OPAL_CHECK_FUNC_LIB to check for various libraries.
'''SIDENOTE:''' It turns out that modern Autoconf has AC_SEARCH_LIBS,
which does just about exactly what OPAL_CHECK_FUNC_LIB does. So this
commit effectively replaces OPAL_CHECK_FUNC_LIB with AC_SEARCH_LIBS.
However, we never bothered to add these found libraries to the wrapper
compiler list of libraries used for static linking (doh!). We've been
getting lucky for quite a while that components were adding the same
libraries to their wrapper compiler LIBS list.
This is problematic, however, if we don't build some of these
components. For example, Paul Hargrove noticed that if he configured
with --disable-shared --enable-static --disable-io-romio, ROMIO was no
longer adding some libraries to the wrapper LIBS list -- libraries
that just happened to also be needed by core OPAL/ORTE/OMPI layers.
The solution is not to use AC_CHECK_LIB or OPAL_CHECK_FUNC_LIB, but
use a pair of new macros:
* OPAL_SEARCH_LIBS_CORE: a wrapper around AC_SEARCH_LIBS. If we add
something to $LIBS, then also add it to the wrapper list of static
libraries. This is the main piece of functionality that was
wrong/missing.
* OPAL_SEARCH_LIBS_COMPONENT: similar to OPAL_SEARCH_LIBS_CORE, but
instead of directly adding it to the wrapper list of static
libaries, add it to <framework>_<component>_LIBS (which eventually
gets slurped up into the wrapper list of static libraries. See the
lengthy comment in config/opal_setup_wrappers.m4 near the beginning
of OPAL_SETUP_WRAPPER_INIT() for a more detailed explanation).
Most components did this correctly already, but one or two weren't
right, so I implemented this second macro quite similar to the
first and put it everywhere we already used AC_SEARCH_LIBS or
OPAL_CHECK_FUNC_LIB.
This needs to soak for a day or two on the trunk before moving to the
v1.8 branch.
Refs trac:4834
cmr=v1.8.2:reviewer=ggouaillardet
This commit was SVN r32447.
The following Trac tickets were found above:
Ticket 4834 --> https://svn.open-mpi.org/trac/ompi/ticket/4834
2014-08-07 23:54:45 +00:00
|
|
|
OPAL_SEARCH_LIBS_CORE([sched_yield], [rt])
|
2006-01-16 01:48:03 +00:00
|
|
|
|
2014-09-04 16:10:38 +00:00
|
|
|
# IRIX and CentOS have dirname in -lgen, usually in libc
|
configury: ensure wrapper static LIBS is filled properly
In core library portions of the configury (e.g., top-level
configure.ac itself), we were calling AC_CHECK_LIB and
OPAL_CHECK_FUNC_LIB to check for various libraries.
'''SIDENOTE:''' It turns out that modern Autoconf has AC_SEARCH_LIBS,
which does just about exactly what OPAL_CHECK_FUNC_LIB does. So this
commit effectively replaces OPAL_CHECK_FUNC_LIB with AC_SEARCH_LIBS.
However, we never bothered to add these found libraries to the wrapper
compiler list of libraries used for static linking (doh!). We've been
getting lucky for quite a while that components were adding the same
libraries to their wrapper compiler LIBS list.
This is problematic, however, if we don't build some of these
components. For example, Paul Hargrove noticed that if he configured
with --disable-shared --enable-static --disable-io-romio, ROMIO was no
longer adding some libraries to the wrapper LIBS list -- libraries
that just happened to also be needed by core OPAL/ORTE/OMPI layers.
The solution is not to use AC_CHECK_LIB or OPAL_CHECK_FUNC_LIB, but
use a pair of new macros:
* OPAL_SEARCH_LIBS_CORE: a wrapper around AC_SEARCH_LIBS. If we add
something to $LIBS, then also add it to the wrapper list of static
libraries. This is the main piece of functionality that was
wrong/missing.
* OPAL_SEARCH_LIBS_COMPONENT: similar to OPAL_SEARCH_LIBS_CORE, but
instead of directly adding it to the wrapper list of static
libaries, add it to <framework>_<component>_LIBS (which eventually
gets slurped up into the wrapper list of static libraries. See the
lengthy comment in config/opal_setup_wrappers.m4 near the beginning
of OPAL_SETUP_WRAPPER_INIT() for a more detailed explanation).
Most components did this correctly already, but one or two weren't
right, so I implemented this second macro quite similar to the
first and put it everywhere we already used AC_SEARCH_LIBS or
OPAL_CHECK_FUNC_LIB.
This needs to soak for a day or two on the trunk before moving to the
v1.8 branch.
Refs trac:4834
cmr=v1.8.2:reviewer=ggouaillardet
This commit was SVN r32447.
The following Trac tickets were found above:
Ticket 4834 --> https://svn.open-mpi.org/trac/ompi/ticket/4834
2014-08-07 23:54:45 +00:00
|
|
|
OPAL_SEARCH_LIBS_CORE([dirname], [gen])
|
2006-01-16 01:48:03 +00:00
|
|
|
|
|
|
|
# Darwin doesn't need -lm, as it's a symlink to libSystem.dylib
|
configury: ensure wrapper static LIBS is filled properly
In core library portions of the configury (e.g., top-level
configure.ac itself), we were calling AC_CHECK_LIB and
OPAL_CHECK_FUNC_LIB to check for various libraries.
'''SIDENOTE:''' It turns out that modern Autoconf has AC_SEARCH_LIBS,
which does just about exactly what OPAL_CHECK_FUNC_LIB does. So this
commit effectively replaces OPAL_CHECK_FUNC_LIB with AC_SEARCH_LIBS.
However, we never bothered to add these found libraries to the wrapper
compiler list of libraries used for static linking (doh!). We've been
getting lucky for quite a while that components were adding the same
libraries to their wrapper compiler LIBS list.
This is problematic, however, if we don't build some of these
components. For example, Paul Hargrove noticed that if he configured
with --disable-shared --enable-static --disable-io-romio, ROMIO was no
longer adding some libraries to the wrapper LIBS list -- libraries
that just happened to also be needed by core OPAL/ORTE/OMPI layers.
The solution is not to use AC_CHECK_LIB or OPAL_CHECK_FUNC_LIB, but
use a pair of new macros:
* OPAL_SEARCH_LIBS_CORE: a wrapper around AC_SEARCH_LIBS. If we add
something to $LIBS, then also add it to the wrapper list of static
libraries. This is the main piece of functionality that was
wrong/missing.
* OPAL_SEARCH_LIBS_COMPONENT: similar to OPAL_SEARCH_LIBS_CORE, but
instead of directly adding it to the wrapper list of static
libaries, add it to <framework>_<component>_LIBS (which eventually
gets slurped up into the wrapper list of static libraries. See the
lengthy comment in config/opal_setup_wrappers.m4 near the beginning
of OPAL_SETUP_WRAPPER_INIT() for a more detailed explanation).
Most components did this correctly already, but one or two weren't
right, so I implemented this second macro quite similar to the
first and put it everywhere we already used AC_SEARCH_LIBS or
OPAL_CHECK_FUNC_LIB.
This needs to soak for a day or two on the trunk before moving to the
v1.8 branch.
Refs trac:4834
cmr=v1.8.2:reviewer=ggouaillardet
This commit was SVN r32447.
The following Trac tickets were found above:
Ticket 4834 --> https://svn.open-mpi.org/trac/ompi/ticket/4834
2014-08-07 23:54:45 +00:00
|
|
|
OPAL_SEARCH_LIBS_CORE([ceil], [m])
|
2005-08-24 21:24:17 +00:00
|
|
|
|
2014-11-28 14:39:48 -05:00
|
|
|
# -lrt might be needed for clock_gettime
|
|
|
|
OPAL_SEARCH_LIBS_CORE([clock_gettime], [rt])
|
|
|
|
|
2018-09-27 10:32:24 -07:00
|
|
|
AC_CHECK_FUNCS([asprintf snprintf vasprintf vsnprintf openpty isatty getpwuid fork waitpid execve pipe ptsname setsid mmap tcgetpgrp posix_memalign strsignal sysconf syslog vsyslog regcmp regexec regfree _NSGetEnviron socketpair usleep mkfifo dbopen dbm_open statfs statvfs setpgid setenv __malloc_initialize_hook __clear_cache])
|
2014-01-09 21:28:52 +00:00
|
|
|
|
|
|
|
# Sanity check: ensure that we got at least one of statfs or statvfs.
|
2015-02-03 15:45:03 +09:00
|
|
|
if test $ac_cv_func_statfs = no && test $ac_cv_func_statvfs = no; then
|
2014-01-09 21:28:52 +00:00
|
|
|
AC_MSG_WARN([neither statfs() and statvfs() were found])
|
|
|
|
AC_MSG_ERROR([Cannot continue])
|
|
|
|
fi
|
2008-06-24 23:20:25 +00:00
|
|
|
|
|
|
|
# On some hosts, htonl is a define, so the AC_CHECK_FUNC will get
|
|
|
|
# confused. On others, it's in the standard library, but stubbed with
|
|
|
|
# the magic glibc foo as not implemented. and on other systems, it's
|
|
|
|
# just not there. This covers all cases.
|
|
|
|
AC_CACHE_CHECK([for htonl define],
|
|
|
|
[ompi_cv_htonl_define],
|
|
|
|
[AC_PREPROC_IFELSE([AC_LANG_PROGRAM([
|
|
|
|
#ifdef HAVE_SYS_TYPES_H
|
|
|
|
#include <sys/types.h>
|
|
|
|
#endif
|
|
|
|
#ifdef HAVE_NETINET_IN_H
|
|
|
|
#include <netinet/in.h>
|
|
|
|
#endif
|
|
|
|
#ifdef HAVE_ARPA_INET_H
|
|
|
|
#include <arpa/inet.h>
|
|
|
|
#endif],[
|
|
|
|
#ifndef ntohl
|
|
|
|
#error "ntohl not defined"
|
|
|
|
#endif
|
|
|
|
])], [ompi_cv_htonl_define=yes], [ompi_cv_htonl_define=no])])
|
|
|
|
AC_CHECK_FUNC([htonl], [ompi_have_htonl=yes], [ompi_have_htonl=no])
|
2015-02-03 15:45:03 +09:00
|
|
|
AS_IF([test "$ompi_cv_htonl_define" = "yes" || test "$ompi_have_htonl" = "yes"],
|
2009-03-16 02:04:22 +00:00
|
|
|
[AC_DEFINE_UNQUOTED([HAVE_UNIX_BYTESWAP], [1],
|
2008-06-24 23:20:25 +00:00
|
|
|
[whether unix byteswap routines -- htonl, htons, nothl, ntohs -- are available])])
|
2004-08-10 22:41:17 +00:00
|
|
|
|
2004-01-14 06:39:55 +00:00
|
|
|
#
|
|
|
|
# Make sure we can copy va_lists (need check declared, not linkable)
|
|
|
|
#
|
|
|
|
|
2009-05-06 20:11:28 +00:00
|
|
|
AC_CHECK_DECL(va_copy, OPAL_HAVE_VA_COPY=1, OPAL_HAVE_VA_COPY=0,
|
2009-03-16 04:22:22 +00:00
|
|
|
[#include <stdarg.h>])
|
2009-05-06 20:11:28 +00:00
|
|
|
AC_DEFINE_UNQUOTED(OPAL_HAVE_VA_COPY, $OPAL_HAVE_VA_COPY,
|
2004-01-14 06:39:55 +00:00
|
|
|
[Whether we have va_copy or not])
|
|
|
|
|
2009-05-06 20:11:28 +00:00
|
|
|
AC_CHECK_DECL(__va_copy, OPAL_HAVE_UNDERSCORE_VA_COPY=1,
|
|
|
|
OPAL_HAVE_UNDERSCORE_VA_COPY=0, [#include <stdarg.h>])
|
|
|
|
AC_DEFINE_UNQUOTED(OPAL_HAVE_UNDERSCORE_VA_COPY, $OPAL_HAVE_UNDERSCORE_VA_COPY,
|
2004-01-14 06:39:55 +00:00
|
|
|
[Whether we have __va_copy or not])
|
|
|
|
|
2004-10-29 19:14:11 +00:00
|
|
|
AC_CHECK_DECLS(__func__)
|
|
|
|
|
2005-07-09 18:52:53 +00:00
|
|
|
# checkpoint results
|
|
|
|
AC_CACHE_SAVE
|
|
|
|
|
2016-11-22 15:03:20 -08:00
|
|
|
|
2003-11-22 16:36:58 +00:00
|
|
|
##################################
|
|
|
|
# System-specific tests
|
|
|
|
##################################
|
|
|
|
|
2014-05-05 22:35:23 +00:00
|
|
|
opal_show_title "System-specific tests"
|
2004-06-29 00:02:25 +00:00
|
|
|
|
2007-02-06 12:03:56 +00:00
|
|
|
# Do we have _SC_NPROCESSORS_ONLN? (only going to pass if we also have
|
|
|
|
# <unistd.h> and sysconf(), which is ok) OS X 10.4 has <unistd.h> and
|
|
|
|
# sysconf(), but does not have _SC_NPROCESSORS_ONLN. Doh!
|
|
|
|
|
2008-11-07 22:13:43 +00:00
|
|
|
AC_CACHE_CHECK([for _SC_NPROCESSORS_ONLN],
|
|
|
|
[ompi_cv_have__SC_NPROCESSORS_ONLN],
|
|
|
|
[AC_COMPILE_IFELSE([AC_LANG_PROGRAM([
|
|
|
|
AC_INCLUDES_DEFAULT
|
|
|
|
#include <unistd.h>
|
|
|
|
],
|
|
|
|
[int i = _SC_NPROCESSORS_ONLN;])],
|
|
|
|
[ompi_cv_have__SC_NPROCESSORS_ONLN="yes"],
|
|
|
|
[ompi_cv_have__SC_NPROCESSORS_ONLN="no"])])
|
|
|
|
AS_IF([test "$ompi_cv_have__SC_NPROCESSORS_ONLN" = "yes"],
|
|
|
|
[result=1], [result=0])
|
|
|
|
AC_DEFINE_UNQUOTED([OPAL_HAVE__SC_NPROCESSORS_ONLN], [$result],
|
|
|
|
[Define to 1 ifyou have the declaration of _SC_NPROCESSORS_ONLN, and to 0 otherwise])
|
2007-02-06 12:03:56 +00:00
|
|
|
|
2003-11-22 16:36:58 +00:00
|
|
|
# all: endian
|
2016-11-22 15:03:20 -08:00
|
|
|
|
2006-03-04 13:59:14 +00:00
|
|
|
AC_C_BIGENDIAN
|
2004-10-14 12:55:34 +00:00
|
|
|
|
2014-05-07 15:45:47 +00:00
|
|
|
OPAL_CHECK_BROKEN_QSORT
|
2005-06-26 23:11:37 +00:00
|
|
|
|
2016-11-22 15:03:20 -08:00
|
|
|
# all: SYSV semaphores
|
|
|
|
# all: SYSV shared memory
|
|
|
|
# all: size of FD_SET
|
|
|
|
# all: sizeof struct stat members
|
|
|
|
# all: type of getsockopt optlen
|
|
|
|
# all: type of recvfrom optlen
|
|
|
|
|
2004-02-13 03:58:56 +00:00
|
|
|
#
|
|
|
|
# What is the local equivalent of "ln -s"
|
|
|
|
#
|
|
|
|
|
|
|
|
AC_PROG_LN_S
|
2016-11-22 15:03:20 -08:00
|
|
|
|
2007-06-01 02:31:15 +00:00
|
|
|
AC_PROG_GREP
|
|
|
|
AC_PROG_EGREP
|
|
|
|
|
2004-08-05 14:01:45 +00:00
|
|
|
#
|
2004-08-15 23:55:10 +00:00
|
|
|
# We need as and lex
|
2004-08-05 14:01:45 +00:00
|
|
|
#
|
2004-08-15 23:55:10 +00:00
|
|
|
AM_PROG_AS
|
2004-08-05 14:01:45 +00:00
|
|
|
AM_PROG_LEX
|
|
|
|
|
2015-04-22 16:59:59 -04:00
|
|
|
# If we don't have Flex and we don't have a generated .c file
|
|
|
|
# (distribution tarballs will have the .c file included, but git
|
|
|
|
# clones will not), then error. Must have Flex -- other versions of
|
|
|
|
# Lex are not workable (all things being equal, since this is *only*
|
|
|
|
# required for developers, we decided that it really was not worth it
|
|
|
|
# to be portable between different versions of lex ;-).
|
2004-09-05 17:45:59 +00:00
|
|
|
|
2015-02-03 15:45:03 +09:00
|
|
|
if test -z "$LEX" || \
|
|
|
|
test -n "`echo $LEX | $GREP missing`" || \
|
|
|
|
test "`basename $LEX`" != "flex"; then
|
2005-07-04 02:38:44 +00:00
|
|
|
if test ! -f "$srcdir/opal/util/show_help_lex.c"; then
|
2015-04-22 16:59:59 -04:00
|
|
|
AC_MSG_WARN([*** Could not find Flex on your system.])
|
|
|
|
AC_MSG_WARN([*** Flex is required for developer builds of Open MPI.])
|
2004-09-05 17:45:59 +00:00
|
|
|
AC_MSG_WARN([*** Other versions of Lex are not supported.])
|
2020-04-27 11:15:43 -07:00
|
|
|
AC_MSG_WARN([*** NOTE: If you are building a tarball downloaded from www.open-mpi.org, you do not need Flex])
|
2004-08-26 16:17:20 +00:00
|
|
|
AC_MSG_ERROR([Cannot continue])
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2020-04-20 09:43:59 -07:00
|
|
|
#
|
|
|
|
# Setup man page processing
|
|
|
|
#
|
|
|
|
|
|
|
|
OPAL_SETUP_MAN_PAGES
|
|
|
|
|
2004-01-09 08:25:18 +00:00
|
|
|
#
|
2004-01-09 05:08:31 +00:00
|
|
|
# File system case sensitivity
|
2004-01-09 08:25:18 +00:00
|
|
|
#
|
2004-01-09 05:08:31 +00:00
|
|
|
|
2012-12-18 23:51:38 +00:00
|
|
|
OPAL_CASE_SENSITIVE_FS_SETUP
|
2003-11-22 16:36:58 +00:00
|
|
|
|
2016-11-22 15:03:20 -08:00
|
|
|
# AIX: FIONBIO in sys/ioctl.h
|
|
|
|
# glibc: memcpy
|
|
|
|
|
2007-04-25 01:54:37 +00:00
|
|
|
#
|
|
|
|
# Do we have RLIMIT_NPROC in <sys/resources.h>? (e.g., Solaris does not)
|
|
|
|
#
|
|
|
|
|
|
|
|
AC_CHECK_DECLS([RLIMIT_NPROC], [], [], [
|
|
|
|
AC_INCLUDES_DEFAULT
|
|
|
|
#if HAVE_SYS_RESOURCE_H
|
|
|
|
#include <sys/resource.h>
|
2009-03-16 02:04:22 +00:00
|
|
|
#endif])
|
2007-04-25 01:54:37 +00:00
|
|
|
|
2008-11-25 03:13:09 +00:00
|
|
|
#
|
|
|
|
# Do we have RLIMIT_MEMLOCK in <sys/resources.h>? (e.g., Solaris does not)
|
|
|
|
#
|
|
|
|
|
|
|
|
AC_CHECK_DECLS([RLIMIT_MEMLOCK], [], [], [
|
|
|
|
AC_INCLUDES_DEFAULT
|
|
|
|
#if HAVE_SYS_RESOURCE_H
|
|
|
|
#include <sys/resource.h>
|
2009-03-16 02:04:22 +00:00
|
|
|
#endif])
|
2008-11-25 03:13:09 +00:00
|
|
|
|
2013-12-20 14:09:43 +00:00
|
|
|
#
|
|
|
|
# Do we have RLIMIT_NOFILE in <sys/resources.h>? (e.g., Solaris does not)
|
|
|
|
#
|
|
|
|
|
|
|
|
AC_CHECK_DECLS([RLIMIT_NOFILE], [], [], [
|
|
|
|
AC_INCLUDES_DEFAULT
|
|
|
|
#if HAVE_SYS_RESOURCE_H
|
|
|
|
#include <sys/resource.h>
|
|
|
|
#endif])
|
|
|
|
|
|
|
|
#
|
|
|
|
# Do we have RLIMIT_MEMLOCK in <sys/resources.h>? (e.g., Solaris does not)
|
|
|
|
#
|
|
|
|
|
|
|
|
AC_CHECK_DECLS([RLIMIT_FSIZE], [], [], [
|
|
|
|
AC_INCLUDES_DEFAULT
|
|
|
|
#if HAVE_SYS_RESOURCE_H
|
|
|
|
#include <sys/resource.h>
|
|
|
|
#endif])
|
|
|
|
|
|
|
|
#
|
|
|
|
# Do we have RLIMIT_CORE in <sys/resources.h>? (e.g., Solaris does not)
|
|
|
|
#
|
|
|
|
|
|
|
|
AC_CHECK_DECLS([RLIMIT_CORE], [], [], [
|
|
|
|
AC_INCLUDES_DEFAULT
|
|
|
|
#if HAVE_SYS_RESOURCE_H
|
|
|
|
#include <sys/resource.h>
|
|
|
|
#endif])
|
|
|
|
|
|
|
|
#
|
|
|
|
# Do we have RLIMIT_STACK in <sys/resources.h>? (e.g., Solaris does not)
|
|
|
|
#
|
|
|
|
|
|
|
|
AC_CHECK_DECLS([RLIMIT_STACK], [], [], [
|
|
|
|
AC_INCLUDES_DEFAULT
|
|
|
|
#if HAVE_SYS_RESOURCE_H
|
|
|
|
#include <sys/resource.h>
|
|
|
|
#endif])
|
|
|
|
|
2013-12-20 14:44:51 +00:00
|
|
|
#
|
|
|
|
# Do we have RLIMIT_AS in <sys/resources.h>? (e.g., Solaris does not)
|
|
|
|
#
|
|
|
|
|
|
|
|
AC_CHECK_DECLS([RLIMIT_AS], [], [], [
|
|
|
|
AC_INCLUDES_DEFAULT
|
|
|
|
#if HAVE_SYS_RESOURCE_H
|
|
|
|
#include <sys/resource.h>
|
|
|
|
#endif])
|
|
|
|
|
2005-07-09 18:52:53 +00:00
|
|
|
# checkpoint results
|
|
|
|
AC_CACHE_SAVE
|
|
|
|
|
2016-11-22 15:03:20 -08:00
|
|
|
###########################################################
|
|
|
|
# Fault Tolerance
|
|
|
|
#
|
|
|
|
# The FT code in the OMPI trunk is currently broken. We don't
|
|
|
|
# have an active maintainer for it at this time, and it isn't
|
|
|
|
# clear if/when we will return to it. We have therefore removed
|
|
|
|
# the configure options supporting it until such time as it
|
|
|
|
# can be fixed.
|
|
|
|
#
|
|
|
|
# However, we recognize that there are researchers who use this
|
|
|
|
# option on their independent branches. In such cases, simply
|
|
|
|
# uncomment the line below to render the FT configure options
|
|
|
|
# visible again
|
|
|
|
#
|
|
|
|
###########################################################
|
2017-07-13 11:06:49 -06:00
|
|
|
dnl OPAL_SETUP_FT_OPTIONS
|
2016-11-22 15:03:20 -08:00
|
|
|
###########################################################
|
|
|
|
# The following line is always required as it contains the
|
|
|
|
# AC_DEFINE and AM_CONDITIONAL calls that set variables used
|
|
|
|
# throughout the build system. If the above line is commented
|
|
|
|
# out, then those variables will be set to "off". Otherwise,
|
|
|
|
# they are controlled by the options
|
|
|
|
OPAL_SETUP_FT
|
|
|
|
|
build: Add third-party package infrastructure
With Open MPI 5.0, the decision was made to stop building 3rd-party
packages, such as Libevent, HWLOC, PMIx, and PRRTE as MCA components
and instead 1) start relying on external libraries whenever possible
and 2) Open MPI builds the 3rd party libraries (if needed) as
independent libraries, rather than linked into libopen-pal.
This patch is the first step in that process, providing foundational
changes required for supporting 3rd-party packages, such as changes
to autogen.pl, the top-level Makefile.am, and introducing two
Autoconf macros to support running sub-configure scripts; one
supporting source in tarball form and the other supporting
source in a sub-tree.
Signed-off-by: Brian Barrett <bbarrett@amazon.com>
2020-04-28 02:37:08 +00:00
|
|
|
##################################
|
|
|
|
# 3rd-party packages not called ROMIO
|
|
|
|
##################################
|
|
|
|
opal_show_title "3rd-party packages"
|
|
|
|
|
|
|
|
OPAL_3RDPARY_SUBDIRS=
|
|
|
|
OPAL_3RDPARY_DIST_SUBDIRS=
|
|
|
|
OPAL_3RDPARY_EXTRA_DIST=
|
|
|
|
OPAL_3RDPARY_DISTCLEAN_DIRS=
|
|
|
|
|
2020-04-04 23:14:00 +00:00
|
|
|
OPAL_CONFIG_LIBEVENT
|
2020-04-04 23:14:00 +00:00
|
|
|
OPAL_CONFIG_HWLOC
|
2020-04-27 17:32:56 +00:00
|
|
|
OPAL_CONFIG_PMIX
|
2020-05-08 00:06:44 +00:00
|
|
|
OMPI_SETUP_PRRTE
|
2020-04-04 23:14:00 +00:00
|
|
|
|
build: Add third-party package infrastructure
With Open MPI 5.0, the decision was made to stop building 3rd-party
packages, such as Libevent, HWLOC, PMIx, and PRRTE as MCA components
and instead 1) start relying on external libraries whenever possible
and 2) Open MPI builds the 3rd party libraries (if needed) as
independent libraries, rather than linked into libopen-pal.
This patch is the first step in that process, providing foundational
changes required for supporting 3rd-party packages, such as changes
to autogen.pl, the top-level Makefile.am, and introducing two
Autoconf macros to support running sub-configure scripts; one
supporting source in tarball form and the other supporting
source in a sub-tree.
Signed-off-by: Brian Barrett <bbarrett@amazon.com>
2020-04-28 02:37:08 +00:00
|
|
|
AC_SUBST(OPAL_3RDPARTY_SUBDIRS)
|
|
|
|
AC_SUBST(OPAL_3RDPARTY_DIST_SUBDIRS)
|
|
|
|
AC_SUBST(OPAL_3RDPARTY_EXTRA_DIST)
|
|
|
|
AC_SUBST(OPAL_3RDPARTY_DISTCLEAN_DIRS)
|
|
|
|
|
2004-01-11 21:35:37 +00:00
|
|
|
##################################
|
|
|
|
# MCA
|
|
|
|
##################################
|
|
|
|
|
2014-05-05 22:35:23 +00:00
|
|
|
opal_show_title "Modular Component Architecture (MCA) setup"
|
2004-01-11 21:35:37 +00:00
|
|
|
|
|
|
|
AC_MSG_CHECKING([for subdir args])
|
2014-05-07 21:48:53 +00:00
|
|
|
OPAL_CONFIG_SUBDIR_ARGS([opal_subdir_args])
|
|
|
|
AC_MSG_RESULT([$opal_subdir_args])
|
2004-01-11 21:35:37 +00:00
|
|
|
|
2014-05-07 21:48:53 +00:00
|
|
|
OPAL_MCA
|
2004-01-11 21:35:37 +00:00
|
|
|
|
2019-02-04 20:20:37 -07:00
|
|
|
#
|
|
|
|
# Now that we know how to support threads with wrappers, update
|
|
|
|
#
|
|
|
|
OPAL_WRAPPER_FLAGS_ADD([CFLAGS], [$THREAD_CFLAGS])
|
|
|
|
OPAL_WRAPPER_FLAGS_ADD([CXXFLAGS], [$THREAD_CXXFLAGS])
|
|
|
|
OPAL_WRAPPER_FLAGS_ADD([FCFLAGS], [$THREAD_FCFLAGS])
|
|
|
|
OPAL_WRAPPER_FLAGS_ADD([LDFLAGS], [$THREAD_LDFLAGS])
|
|
|
|
|
2016-11-22 15:03:20 -08:00
|
|
|
m4_ifdef([project_ompi], [OMPI_REQUIRE_ENDPOINT_TAG_FINI])
|
|
|
|
|
2018-05-17 17:22:21 +00:00
|
|
|
# Last minute disable of OpenSHMEM if we didn't find any oshmem SPMLs
|
|
|
|
if test "$project_oshmem_amc" = "true" && test $OSHMEM_FOUND_WORKING_SPML -eq 0 ; then
|
|
|
|
# We don't have an spml that will work, so oshmem wouldn't be able
|
|
|
|
# to run an application. Therefore, don't build the oshmem layer.
|
|
|
|
if test "$enable_oshmem" != "no" && test -n "$enable_oshmem"; then
|
|
|
|
AC_MSG_WARN([No spml found, so OpenSHMEM layer will be non functional.])
|
|
|
|
AC_MSG_ERROR([Aborting because OpenSHMEM requested, but can not build.])
|
|
|
|
else
|
|
|
|
AC_MSG_WARN([No spml found. Will not build OpenSHMEM layer.])
|
|
|
|
project_oshmem_amc="false (no spml)"
|
|
|
|
# now for the hard part, remove project from list that will
|
|
|
|
# run. This is a hack, but it works as long as the project
|
|
|
|
# remains named "oshmem".
|
|
|
|
MCA_PROJECT_SUBDIRS=`echo "$MCA_PROJECT_SUBDIRS" | sed -e 's/oshmem//'`
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2016-11-22 15:03:20 -08:00
|
|
|
# checkpoint results
|
|
|
|
AC_CACHE_SAVE
|
|
|
|
|
|
|
|
##################################
|
|
|
|
# CUDA: part two
|
|
|
|
##################################
|
|
|
|
|
|
|
|
# This is somewhat gross to have a configure check for a common MCA
|
|
|
|
# component outside of the normal MCA checks, but this check must come
|
|
|
|
# after the opal DL MCA checks have done. Someday this could perhaps
|
|
|
|
# be done better by having some kind of "run this check at the end of
|
|
|
|
# all other MCA checks" hook...?
|
|
|
|
|
|
|
|
OPAL_CHECK_CUDA_AFTER_OPAL_DL
|
|
|
|
|
|
|
|
##################################
|
|
|
|
# MPI Extended Interfaces
|
|
|
|
##################################
|
|
|
|
|
|
|
|
m4_ifdef([project_ompi], [OMPI_SETUP_MPI_EXT])
|
|
|
|
|
|
|
|
# checkpoint results
|
|
|
|
AC_CACHE_SAVE
|
|
|
|
|
|
|
|
##################################
|
|
|
|
# Contributed software
|
|
|
|
##################################
|
|
|
|
|
|
|
|
m4_ifdef([project_ompi], [OMPI_SETUP_CONTRIB])
|
|
|
|
|
2010-01-18 13:30:56 +00:00
|
|
|
# checkpoint results
|
|
|
|
AC_CACHE_SAVE
|
|
|
|
|
2008-03-06 22:15:10 +00:00
|
|
|
##################################
|
2009-03-16 02:00:27 +00:00
|
|
|
# Visibility
|
2008-03-06 22:15:10 +00:00
|
|
|
##################################
|
2016-11-22 15:03:20 -08:00
|
|
|
|
2009-03-16 02:00:27 +00:00
|
|
|
# Check the visibility declspec at the end to avoid problem with
|
|
|
|
# the previous tests that are not necessarily prepared for
|
2008-03-06 22:15:10 +00:00
|
|
|
# the visibility feature.
|
2014-05-05 22:35:23 +00:00
|
|
|
opal_show_title "Symbol visibility feature"
|
2008-03-06 22:15:10 +00:00
|
|
|
|
2010-10-23 14:32:44 +00:00
|
|
|
OPAL_CHECK_VISIBILITY
|
2008-03-06 22:15:10 +00:00
|
|
|
|
2016-11-22 15:03:20 -08:00
|
|
|
|
2004-01-16 01:31:50 +00:00
|
|
|
############################################################################
|
2016-11-22 15:03:20 -08:00
|
|
|
# Final top-level OMPI configuration
|
2004-01-16 01:31:50 +00:00
|
|
|
############################################################################
|
|
|
|
|
2016-11-22 15:03:20 -08:00
|
|
|
opal_show_title "Final top-level OMPI configuration"
|
2004-01-16 01:31:50 +00:00
|
|
|
|
2003-11-22 16:36:58 +00:00
|
|
|
############################################################################
|
|
|
|
# Libtool: part two
|
2008-03-06 22:17:40 +00:00
|
|
|
# (after C compiler setup = no compiler/linker tests after this)
|
2003-11-22 16:36:58 +00:00
|
|
|
############################################################################
|
2016-11-22 15:03:20 -08:00
|
|
|
|
2014-05-05 22:35:23 +00:00
|
|
|
opal_show_subtitle "Libtool configuration"
|
2003-11-22 16:36:58 +00:00
|
|
|
|
2008-11-25 15:59:48 +00:00
|
|
|
# Use the undocumented solaris_use_stlport4 libtool variable to turn off any
|
|
|
|
# Cstd/stlport4 linkage. This allows Open MPI to be C++ STL agnostic.
|
2014-05-06 15:01:34 +00:00
|
|
|
if test "x$opal_cv_c_compiler_vendor" = "xsun"; then
|
2008-11-25 15:59:48 +00:00
|
|
|
solaris_use_stlport4="yes"
|
|
|
|
fi
|
|
|
|
|
2016-11-22 15:03:20 -08:00
|
|
|
# Due to this thread:
|
2020-04-02 10:43:50 -04:00
|
|
|
# https://www.open-mpi.org/community/lists/users/2013/02/21356.php and
|
2016-11-22 15:03:20 -08:00
|
|
|
# a helpful tip from Dave Goodell, set the precious variables for
|
|
|
|
# compilers to "no" that we don't want. Libtool's m4 configry will
|
|
|
|
# interpret this as "I won't be using this language; don't bother
|
|
|
|
# setting it up." Note that we do this only for Fortran; we *don't*
|
2020-02-18 22:42:21 -08:00
|
|
|
# do this for C++, because *do* still want to setup the mpicxx wrapper
|
|
|
|
# if we have a C++ compiler.
|
2016-11-22 15:03:20 -08:00
|
|
|
AS_IF([test "$OMPI_TRY_FORTRAN_BINDINGS" = "$OMPI_FORTRAN_NO_BINDINGS"],[F77=no FC=no])
|
2007-08-17 17:11:36 +00:00
|
|
|
|
2020-05-22 12:35:18 -07:00
|
|
|
LT_INIT
|
2016-11-22 14:24:54 -08:00
|
|
|
|
Put back the static-library-detection stuff from r27668, with some
additional functionality. Rationale (refs trac:3422):
* Normal MPI applications only ever use the MPI API. Hence, -lmpi is
sufficient (they'll never directly call ORTE or OPAL
functions). This is arguably the most common case.
* That being said, we do have some test programs (e.g., those in
orte/test/mpi) that call MPI functions but also call ORTE/OPAL
functions. I've also written the occasional MPI test program that
calls opal_output, for example (there even might be a few tests in
the IBM test suite that directly call ORTE/OPAL functions).
* Even though this is not a common case, these applications should
also compile/link with mpicc.
* So we should add a --openmpi:linkall option that will also link
in whatever is necessary to call ORTE/OPAL functions
* Yes, we could hard-code "-lopen-rte -lopen-pal" in Makefiles, but
we do reserve the right to change those library names and/or add
others someday, so it's better to abstract out the names and let
the wrapper supply whatever is necessary.
* ORTE programs, however, are different. They almost always call OPAL
functions (e.g., if they want to send a message, they must use the
OPAL DSS). As such, it seems like the ORTE programs should always
link in OPAL.
Therefore:
* Add undocumented --openmpi:linkall flag to the wrapper compilers.
See the comment in opal_wrapper.c for an explanation of what it
does. This flag is only intended for Open MPI developers -- not
end users. That's why it's undocumented.
* Update orte/test/mpi/Makefile.am to add --openmpi:linkall
* Make ortecc/ortec++'s wrapper data text files always explicitly
link in libopen-pal
This commit was SVN r27670.
The following SVN revision numbers were found above:
r27668 --> open-mpi/ompi@cf845897aa89407195aa13f56ddf4ec0d3c21a68
The following Trac tickets were found above:
Ticket 3422 --> https://svn.open-mpi.org/trac/ompi/ticket/3422
2012-12-13 22:31:37 +00:00
|
|
|
# What's the suffix of shared libraries? Inspired by generated
|
|
|
|
# Libtool code (even though we don't support several of these
|
|
|
|
# platforms, there didn't seem to be any harm in leaving in some of
|
|
|
|
# them, alhtough I did remove some that we have never/will never
|
|
|
|
# support, like OS/2).
|
2013-02-15 14:12:39 +00:00
|
|
|
OPAL_DYN_LIB_PREFIX=lib
|
Put back the static-library-detection stuff from r27668, with some
additional functionality. Rationale (refs trac:3422):
* Normal MPI applications only ever use the MPI API. Hence, -lmpi is
sufficient (they'll never directly call ORTE or OPAL
functions). This is arguably the most common case.
* That being said, we do have some test programs (e.g., those in
orte/test/mpi) that call MPI functions but also call ORTE/OPAL
functions. I've also written the occasional MPI test program that
calls opal_output, for example (there even might be a few tests in
the IBM test suite that directly call ORTE/OPAL functions).
* Even though this is not a common case, these applications should
also compile/link with mpicc.
* So we should add a --openmpi:linkall option that will also link
in whatever is necessary to call ORTE/OPAL functions
* Yes, we could hard-code "-lopen-rte -lopen-pal" in Makefiles, but
we do reserve the right to change those library names and/or add
others someday, so it's better to abstract out the names and let
the wrapper supply whatever is necessary.
* ORTE programs, however, are different. They almost always call OPAL
functions (e.g., if they want to send a message, they must use the
OPAL DSS). As such, it seems like the ORTE programs should always
link in OPAL.
Therefore:
* Add undocumented --openmpi:linkall flag to the wrapper compilers.
See the comment in opal_wrapper.c for an explanation of what it
does. This flag is only intended for Open MPI developers -- not
end users. That's why it's undocumented.
* Update orte/test/mpi/Makefile.am to add --openmpi:linkall
* Make ortecc/ortec++'s wrapper data text files always explicitly
link in libopen-pal
This commit was SVN r27670.
The following SVN revision numbers were found above:
r27668 --> open-mpi/ompi@cf845897aa89407195aa13f56ddf4ec0d3c21a68
The following Trac tickets were found above:
Ticket 3422 --> https://svn.open-mpi.org/trac/ompi/ticket/3422
2012-12-13 22:31:37 +00:00
|
|
|
case $host_os in
|
2013-02-15 14:12:39 +00:00
|
|
|
cygwin*)
|
|
|
|
OPAL_DYN_LIB_PREFIX=cyg
|
|
|
|
OPAL_DYN_LIB_SUFFIX=dll
|
|
|
|
;;
|
|
|
|
mingw* | pw32* | cegcc*)
|
Put back the static-library-detection stuff from r27668, with some
additional functionality. Rationale (refs trac:3422):
* Normal MPI applications only ever use the MPI API. Hence, -lmpi is
sufficient (they'll never directly call ORTE or OPAL
functions). This is arguably the most common case.
* That being said, we do have some test programs (e.g., those in
orte/test/mpi) that call MPI functions but also call ORTE/OPAL
functions. I've also written the occasional MPI test program that
calls opal_output, for example (there even might be a few tests in
the IBM test suite that directly call ORTE/OPAL functions).
* Even though this is not a common case, these applications should
also compile/link with mpicc.
* So we should add a --openmpi:linkall option that will also link
in whatever is necessary to call ORTE/OPAL functions
* Yes, we could hard-code "-lopen-rte -lopen-pal" in Makefiles, but
we do reserve the right to change those library names and/or add
others someday, so it's better to abstract out the names and let
the wrapper supply whatever is necessary.
* ORTE programs, however, are different. They almost always call OPAL
functions (e.g., if they want to send a message, they must use the
OPAL DSS). As such, it seems like the ORTE programs should always
link in OPAL.
Therefore:
* Add undocumented --openmpi:linkall flag to the wrapper compilers.
See the comment in opal_wrapper.c for an explanation of what it
does. This flag is only intended for Open MPI developers -- not
end users. That's why it's undocumented.
* Update orte/test/mpi/Makefile.am to add --openmpi:linkall
* Make ortecc/ortec++'s wrapper data text files always explicitly
link in libopen-pal
This commit was SVN r27670.
The following SVN revision numbers were found above:
r27668 --> open-mpi/ompi@cf845897aa89407195aa13f56ddf4ec0d3c21a68
The following Trac tickets were found above:
Ticket 3422 --> https://svn.open-mpi.org/trac/ompi/ticket/3422
2012-12-13 22:31:37 +00:00
|
|
|
OPAL_DYN_LIB_SUFFIX=dll
|
|
|
|
;;
|
|
|
|
darwin* | rhapsody*)
|
|
|
|
OPAL_DYN_LIB_SUFFIX=dylib
|
|
|
|
;;
|
|
|
|
hpux9* | hpux10* | hpux11*)
|
|
|
|
case $host_cpu in
|
|
|
|
ia64*)
|
|
|
|
OPAL_DYN_LIB_SUFFIX=so
|
|
|
|
;;
|
|
|
|
*)
|
|
|
|
OPAL_DYN_LIB_SUFFIX=sl
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
;;
|
|
|
|
*)
|
|
|
|
OPAL_DYN_LIB_SUFFIX=so
|
|
|
|
;;
|
|
|
|
esac
|
2013-02-15 14:12:39 +00:00
|
|
|
AC_SUBST(OPAL_DYN_LIB_PREFIX)
|
Put back the static-library-detection stuff from r27668, with some
additional functionality. Rationale (refs trac:3422):
* Normal MPI applications only ever use the MPI API. Hence, -lmpi is
sufficient (they'll never directly call ORTE or OPAL
functions). This is arguably the most common case.
* That being said, we do have some test programs (e.g., those in
orte/test/mpi) that call MPI functions but also call ORTE/OPAL
functions. I've also written the occasional MPI test program that
calls opal_output, for example (there even might be a few tests in
the IBM test suite that directly call ORTE/OPAL functions).
* Even though this is not a common case, these applications should
also compile/link with mpicc.
* So we should add a --openmpi:linkall option that will also link
in whatever is necessary to call ORTE/OPAL functions
* Yes, we could hard-code "-lopen-rte -lopen-pal" in Makefiles, but
we do reserve the right to change those library names and/or add
others someday, so it's better to abstract out the names and let
the wrapper supply whatever is necessary.
* ORTE programs, however, are different. They almost always call OPAL
functions (e.g., if they want to send a message, they must use the
OPAL DSS). As such, it seems like the ORTE programs should always
link in OPAL.
Therefore:
* Add undocumented --openmpi:linkall flag to the wrapper compilers.
See the comment in opal_wrapper.c for an explanation of what it
does. This flag is only intended for Open MPI developers -- not
end users. That's why it's undocumented.
* Update orte/test/mpi/Makefile.am to add --openmpi:linkall
* Make ortecc/ortec++'s wrapper data text files always explicitly
link in libopen-pal
This commit was SVN r27670.
The following SVN revision numbers were found above:
r27668 --> open-mpi/ompi@cf845897aa89407195aa13f56ddf4ec0d3c21a68
The following Trac tickets were found above:
Ticket 3422 --> https://svn.open-mpi.org/trac/ompi/ticket/3422
2012-12-13 22:31:37 +00:00
|
|
|
AC_SUBST(OPAL_DYN_LIB_SUFFIX)
|
|
|
|
|
2020-05-22 12:35:18 -07:00
|
|
|
# Need the libtool executable before the rpathify stuff
|
2014-02-04 19:44:08 +00:00
|
|
|
LT_OUTPUT
|
2010-01-25 23:41:59 +00:00
|
|
|
|
2003-11-22 16:36:58 +00:00
|
|
|
############################################################################
|
2005-10-27 23:23:08 +00:00
|
|
|
# final compiler config
|
2003-11-22 16:36:58 +00:00
|
|
|
############################################################################
|
2016-11-22 15:03:20 -08:00
|
|
|
|
2019-12-12 11:52:28 +09:00
|
|
|
m4_ifdef([project_ompi], [opal_show_subtitle "Compiler flags"])
|
2003-11-22 16:36:58 +00:00
|
|
|
|
|
|
|
#
|
|
|
|
# This is needed for VPATH builds, so that it will -I the appropriate
|
2005-09-01 12:16:36 +00:00
|
|
|
# include directory. We delayed doing it until now just so that
|
2003-11-22 16:36:58 +00:00
|
|
|
# '-I$(top_srcdir)' doesn't show up in any of the configure output --
|
|
|
|
# purely aesthetic.
|
|
|
|
#
|
2016-11-22 15:03:20 -08:00
|
|
|
# Because opal_config.h and mpi.h are created by AC_CONFIG_HEADERS, we
|
2019-12-12 11:52:28 +09:00
|
|
|
# don't need to -I the builddir for <opal,ompi>/include. If we VPATH
|
|
|
|
# building, we do need to include the source directories, however.
|
2005-09-01 12:16:36 +00:00
|
|
|
#
|
2006-02-12 01:33:29 +00:00
|
|
|
if test "$OMPI_TOP_BUILDDIR" != "$OMPI_TOP_SRCDIR"; then
|
2009-10-20 23:44:20 +00:00
|
|
|
# Note the embedded m4 directives here -- we must embed them
|
|
|
|
# rather than have successive assignments to these shell
|
|
|
|
# variables, lest the $(foo) names try to get evaluated here.
|
|
|
|
# Yuck!
|
2019-11-14 15:51:01 -08:00
|
|
|
cpp_includes='$(top_srcdir) $(top_builddir) $(top_srcdir)/opal/include m4_ifdef([project_ompi], [$(top_srcdir)/ompi/include]) m4_ifdef([project_oshmem], [$(top_srcdir)/oshmem/include])'
|
2006-02-12 01:33:29 +00:00
|
|
|
else
|
2019-11-14 15:51:01 -08:00
|
|
|
cpp_includes='$(top_srcdir)'
|
2005-09-01 10:37:20 +00:00
|
|
|
fi
|
|
|
|
|
2019-11-14 15:51:01 -08:00
|
|
|
CPP_INCLUDES="$(echo $cpp_includes | $SED 's/[[^ \]]* */'"$opal_cc_iquote"'&/g')"
|
|
|
|
CXX_INCLUDES="$(echo $cpp_includes | $SED 's/[[^ \]]* */'"$opal_cxx_iquote"'&/g')"
|
|
|
|
CPPFLAGS="$CPP_INCLUDES $CPPFLAGS"
|
|
|
|
# C++ is only relevant if we're building OMPI
|
|
|
|
m4_ifdef([project_ompi],[CXXCPPFLAGS="$CXX_INCLUDES $CXXCPPFLAGS"])
|
|
|
|
|
2020-02-29 07:06:58 -08:00
|
|
|
# OMPI needs some additional processing of the flags (e.g., get
|
|
|
|
# versions without optimization for debugger modules).
|
|
|
|
|
|
|
|
m4_ifdef([project_ompi], [OMPI_SETUP_DEBUGGER_FLAGS])
|
2004-01-19 01:41:40 +00:00
|
|
|
#
|
2020-02-18 22:42:21 -08:00
|
|
|
# Delayed the substitution of CFLAGS and friends until now because
|
2004-01-19 01:41:40 +00:00
|
|
|
# they may have been modified throughout the course of this script.
|
|
|
|
#
|
|
|
|
|
2003-11-22 16:36:58 +00:00
|
|
|
AC_SUBST(CFLAGS)
|
2016-11-22 15:03:20 -08:00
|
|
|
AC_SUBST(CPPFLAGS)
|
|
|
|
m4_ifdef([project_ompi], [AC_SUBST(FFLAGS)
|
|
|
|
AC_SUBST(FCFLAGS)
|
|
|
|
|
|
|
|
AC_SUBST(OMPI_LIBMPI_EXTRA_LIBS)
|
|
|
|
AC_SUBST(OMPI_LIBMPI_EXTRA_LDFLAGS)])
|
2007-08-17 03:52:53 +00:00
|
|
|
|
2007-03-01 13:39:20 +00:00
|
|
|
#
|
|
|
|
# Aggregate MCA parameters directory
|
|
|
|
#
|
2014-08-07 21:19:46 +00:00
|
|
|
AC_SUBST([AMCA_PARAM_SETS_DIR], ['$(opaldatadir)/amca-param-sets'])
|
2007-03-01 13:39:20 +00:00
|
|
|
|
2005-10-27 23:23:08 +00:00
|
|
|
############################################################################
|
|
|
|
# final wrapper compiler config
|
|
|
|
############################################################################
|
2016-11-22 14:24:54 -08:00
|
|
|
|
2016-11-22 15:03:20 -08:00
|
|
|
opal_show_subtitle "Wrapper compiler final setup"
|
2019-12-12 11:52:28 +09:00
|
|
|
# The OMPI wrapper scripts (i.e., not the C-compiled
|
2010-10-19 22:45:54 +00:00
|
|
|
# executables) need perl.
|
|
|
|
AC_PATH_PROG(PERL, perl, perl)
|
|
|
|
|
2009-10-24 01:04:35 +00:00
|
|
|
OPAL_SETUP_WRAPPER_FINAL
|
2003-11-22 16:36:58 +00:00
|
|
|
|
2016-11-22 15:03:20 -08:00
|
|
|
# Recreate some defines prefixed with OMPI_ so that there are no bare
|
|
|
|
# autoconf macro defines in mpi.h. Since AC sometimes changes whether
|
|
|
|
# things are defined as null tokens or an integer result, two projects
|
|
|
|
# with different versions of AC can cause problems.
|
|
|
|
if test $ac_cv_header_stdc = yes; then
|
|
|
|
AC_DEFINE(OPAL_STDC_HEADERS, 1,
|
|
|
|
[Do not use outside of mpi.h. Define to 1 if you have the ANSI C header files.])
|
|
|
|
fi
|
|
|
|
if test $ac_cv_header_sys_time_h = yes ; then
|
|
|
|
AC_DEFINE(OPAL_HAVE_SYS_TIME_H, 1,
|
|
|
|
[Do not use outside of mpi.h. Define to 1 if you have the <sys/time.h> header file.])
|
|
|
|
fi
|
|
|
|
if test $ac_cv_type_long_long = yes ; then
|
|
|
|
AC_DEFINE(OPAL_HAVE_LONG_LONG, 1,
|
|
|
|
[Do not use outside of mpi.h. Define to 1 if the system has the type `long long'.]) dnl `
|
|
|
|
fi
|
|
|
|
if test $ac_cv_header_sys_synch_h = yes ; then
|
|
|
|
AC_DEFINE(OPAL_HAVE_SYS_SYNCH_H, 1,
|
|
|
|
[Do not use outside of mpi.h. Define to 1 if you have the <sys/synch.h> header file.])
|
|
|
|
fi
|
|
|
|
|
|
|
|
# If there is a local hook for each project, call it. This allows 3rd
|
2019-12-12 11:52:28 +09:00
|
|
|
# parties to add configuration steps to OPAL and/or OMPI simply
|
|
|
|
# by placing a file in [opal|ompi]/config/whatever.m4 that
|
2016-11-22 15:03:20 -08:00
|
|
|
# AC_DEFUN's the appropriate macro name -- no patching is necessary.
|
|
|
|
# If that macro is defined, we'll run it here.
|
|
|
|
#
|
|
|
|
# Unfortunately, aclocal is not smart enough to parse something like
|
|
|
|
# the following in opal_mca.m4 (when we're already m4 looping over the
|
|
|
|
# project list):
|
|
|
|
#
|
|
|
|
# m4_foreach(mca_project, [mca_project_list],
|
|
|
|
# [m4_ifdef(mca_project[_CONFIG_LOCAL], mca_project[_CONFIG_LOCAL])])
|
|
|
|
#
|
|
|
|
# Meaning that aclocal doesn't see that, for example,
|
|
|
|
# "ompi_CONFIG_LOCAL" is actually invoked at the bottom and therefore
|
|
|
|
# go look for an .m4 file that contains it. Instead, we have to
|
|
|
|
# manually list the macros here. *Then* aclocal is smart enough to go
|
|
|
|
# look for an .m4 file containing each macro, and if found,
|
|
|
|
# automatically m4_include the corresponding in aclocal.m4. Bummer.
|
|
|
|
# :-\
|
|
|
|
|
2009-12-16 23:32:47 +00:00
|
|
|
m4_ifdef([opal_CONFIG_LOCAL], [opal_CONFIG_LOCAL])
|
2016-11-22 15:03:20 -08:00
|
|
|
m4_ifdef([project_ompi],
|
|
|
|
[m4_ifdef([ompi_CONFIG_LOCAL], [ompi_CONFIG_LOCAL])])
|
2009-12-16 23:32:47 +00:00
|
|
|
|
2003-11-22 16:36:58 +00:00
|
|
|
############################################################################
|
|
|
|
# Party on
|
|
|
|
############################################################################
|
|
|
|
|
2018-05-17 17:11:12 +00:00
|
|
|
# set projects good/no good AM_CONDITIONALS. This is at the end so
|
|
|
|
# that the OSHMEM/OMPI projects can be disabled, if needed, based on
|
|
|
|
# MCA tests. If a project is to be disabled, also remove it from
|
|
|
|
# MCA_PROJECT_SUBDIRS to actually disable building.
|
|
|
|
AM_CONDITIONAL([PROJECT_OMPI], [test "$project_ompi_amc" = "true"])
|
|
|
|
AM_CONDITIONAL([PROJECT_OSHMEM], [test "$project_oshmem_amc" = "true"])
|
|
|
|
|
2013-10-06 23:56:54 +00:00
|
|
|
AC_MSG_CHECKING([if libtool needs -no-undefined flag to build shared libraries])
|
|
|
|
case "`uname`" in
|
|
|
|
CYGWIN*|MINGW*|AIX*)
|
|
|
|
## Add in the -no-undefined flag to LDFLAGS for libtool.
|
|
|
|
AC_MSG_RESULT([yes])
|
|
|
|
LDFLAGS="$LDFLAGS -no-undefined"
|
|
|
|
;;
|
|
|
|
*)
|
|
|
|
## Don't add in anything.
|
|
|
|
AC_MSG_RESULT([no])
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
|
2014-05-08 02:01:35 +00:00
|
|
|
# opaldatadir, opallibdir, and opalinclude are essentially the same as
|
2016-11-22 15:03:20 -08:00
|
|
|
# pkg*dir, but will always be */openmpi. This is to make it a bit
|
2019-12-12 11:52:28 +09:00
|
|
|
# easier to deal with the problem of opal and ompi built from
|
2016-11-22 15:03:20 -08:00
|
|
|
# their own tarballs, with their own PACKAGE variables.
|
|
|
|
opaldatadir='${datadir}/openmpi'
|
|
|
|
opallibdir='${libdir}/openmpi'
|
|
|
|
opalincludedir='${includedir}/openmpi'
|
2014-05-08 02:01:35 +00:00
|
|
|
AC_SUBST(opaldatadir)
|
|
|
|
AC_SUBST(opallibdir)
|
|
|
|
AC_SUBST(opalincludedir)
|
|
|
|
|
2016-11-22 15:03:20 -08:00
|
|
|
OPAL_SET_MCA_PREFIX([OMPI_MCA_])
|
|
|
|
OPAL_SET_MCA_CMD_LINE_ID([mca])
|
|
|
|
m4_ifdef([project_ompi],
|
|
|
|
[ompidatadir="$opaldatadir"
|
|
|
|
AC_SUBST(ompidatadir)
|
|
|
|
ompilibdir="$opallibdir"
|
|
|
|
AC_SUBST(ompilibdir)
|
|
|
|
ompiincludedir="$opalincludedir"
|
|
|
|
AC_SUBST(ompiincludedir)])
|
|
|
|
m4_ifdef([project_oshmem],
|
|
|
|
[oshmemdatadir="$opaldatadir"
|
|
|
|
AC_SUBST(oshmemdatadir)
|
|
|
|
oshmemlibdir="$opallibdir"
|
|
|
|
AC_SUBST(oshmemlibdir)
|
|
|
|
oshmemincludedir="$opalincludedir"
|
|
|
|
AC_SUBST(oshmemincludedir)])
|
2013-10-06 23:56:54 +00:00
|
|
|
|
2014-05-05 22:35:23 +00:00
|
|
|
opal_show_subtitle "Final output"
|
2003-11-22 16:36:58 +00:00
|
|
|
|
2019-12-12 11:52:28 +09:00
|
|
|
AC_MSG_CHECKING([OMPI final CPPFLAGS])
|
|
|
|
AC_MSG_RESULT([$CPPFLAGS])
|
|
|
|
AC_MSG_CHECKING([OMPI final LDFLAGS])
|
|
|
|
AC_MSG_RESULT([$LDFLAGS])
|
|
|
|
AC_MSG_CHECKING([OMPI final LIBS])
|
|
|
|
AC_MSG_RESULT([$LIBS])
|
|
|
|
|
2003-11-22 16:36:58 +00:00
|
|
|
AC_CONFIG_FILES([
|
|
|
|
Makefile
|
2016-11-22 15:03:20 -08:00
|
|
|
|
2003-11-22 16:36:58 +00:00
|
|
|
config/Makefile
|
2016-11-22 15:03:20 -08:00
|
|
|
|
2005-08-21 21:04:52 +00:00
|
|
|
contrib/Makefile
|
2016-11-22 15:03:20 -08:00
|
|
|
|
|
|
|
contrib/dist/mofed/debian/changelog
|
|
|
|
contrib/dist/mofed/debian/control
|
|
|
|
contrib/dist/mofed/debian/copyright:LICENSE
|
|
|
|
|
build: Add third-party package infrastructure
With Open MPI 5.0, the decision was made to stop building 3rd-party
packages, such as Libevent, HWLOC, PMIx, and PRRTE as MCA components
and instead 1) start relying on external libraries whenever possible
and 2) Open MPI builds the 3rd party libraries (if needed) as
independent libraries, rather than linked into libopen-pal.
This patch is the first step in that process, providing foundational
changes required for supporting 3rd-party packages, such as changes
to autogen.pl, the top-level Makefile.am, and introducing two
Autoconf macros to support running sub-configure scripts; one
supporting source in tarball form and the other supporting
source in a sub-tree.
Signed-off-by: Brian Barrett <bbarrett@amazon.com>
2020-04-28 02:37:08 +00:00
|
|
|
3rd-party/Makefile
|
|
|
|
|
2016-11-22 15:03:20 -08:00
|
|
|
test/Makefile
|
|
|
|
test/event/Makefile
|
|
|
|
test/asm/Makefile
|
|
|
|
test/datatype/Makefile
|
|
|
|
test/dss/Makefile
|
|
|
|
test/class/Makefile
|
2018-03-22 03:55:18 -06:00
|
|
|
test/mpool/Makefile
|
2016-11-22 15:03:20 -08:00
|
|
|
test/support/Makefile
|
|
|
|
test/threads/Makefile
|
|
|
|
test/util/Makefile
|
2013-12-06 23:36:36 +00:00
|
|
|
])
|
2017-06-29 18:58:58 +02:00
|
|
|
|
2016-08-30 15:02:47 -04:00
|
|
|
m4_ifdef([project_ompi], [AC_CONFIG_FILES([test/monitoring/Makefile test/spc/Makefile])])
|
2015-11-21 14:33:07 -08:00
|
|
|
|
2016-11-22 15:03:20 -08:00
|
|
|
AC_CONFIG_FILES([contrib/dist/mofed/debian/rules],
|
|
|
|
[chmod +x contrib/dist/mofed/debian/rules])
|
|
|
|
AC_CONFIG_FILES([contrib/dist/mofed/compile_debian_mlnx_example],
|
|
|
|
[chmod +x contrib/dist/mofed/compile_debian_mlnx_example])
|
2009-10-20 23:44:20 +00:00
|
|
|
|
2009-10-24 01:04:35 +00:00
|
|
|
OPAL_CONFIG_FILES
|
2016-11-22 15:03:20 -08:00
|
|
|
m4_ifdef([project_ompi], [OMPI_CONFIG_FILES])
|
|
|
|
m4_ifdef([project_oshmem], [OSHMEM_CONFIG_FILES])
|
2009-10-20 23:44:20 +00:00
|
|
|
|
2016-10-12 10:53:08 +09:00
|
|
|
OPAL_CHECK_LIBNL_SUMMARY
|
|
|
|
|
2019-12-12 11:52:28 +09:00
|
|
|
# checkpoint results
|
|
|
|
AC_CACHE_SAVE
|
|
|
|
|
2003-11-22 16:36:58 +00:00
|
|
|
AC_OUTPUT
|
2016-03-01 11:01:51 -07:00
|
|
|
|
2016-04-20 08:38:57 -07:00
|
|
|
OPAL_SUMMARY_PRINT
|