1
1
openmpi/ompi/contrib/vt/configure.m4
Ralph Castain 2b7a3ae601 Per RFC, continue pecking away at the build system renaming
OMPI_CONFIG_SUBDIR  -> OPAL_CONFIG_SUBDIR
   OMPI_CONFIG_SUBDIR_ARGS  ->  OPAL_CONFIG_SUBDIR_ARGS

This commit was SVN r31647.
2014-05-06 16:27:38 +00:00

156 строки
6.6 KiB
Bash

# -*- shell-script -*-
#
# Copyright (c) 2004-2005 The Trustees of Indiana University and Indiana
# University Research and Technology
# Corporation. All rights reserved.
# Copyright (c) 2004-2005 The University of Tennessee and The University
# of Tennessee Research Foundation. All rights
# reserved.
# Copyright (c) 2004-2005 High Performance Computing Center Stuttgart,
# University of Stuttgart. All rights reserved.
# Copyright (c) 2004-2005 The Regents of the University of California.
# All rights reserved.
# Copyright (c) 2007 Cisco Systems, Inc. All rights reserved.
# $COPYRIGHT$
#
# Additional copyrights may follow
#
# $HEADER$
#
# OMPI_contrib_vt_CONFIG([action-if-can-compile],
# [action-if-cant-compile])
# ------------------------------------------------
AC_DEFUN([OMPI_contrib_vt_CONFIG],[
AC_ARG_WITH([contrib-vt-flags],
[AC_HELP_STRING([--with-contrib-vt-flags=FLAGS],
[Pass FLAGS to the VampirTrace distribution configuration script])])
AS_IF([test "$with_contrib_vt_flags" = "yes" -o "$with_contrib_vt_flags" = "no"],
[with_contrib_vt_flags=""])
contrib_vt_happy=1
# Check for enabled PMPI.
AC_MSG_CHECKING([whether PMPI is enabled])
if test "$WANT_MPI_PROFILING" = "1"; then
AC_MSG_RESULT([yes])
else
AC_MSG_RESULT([no])
AC_WARN([**************************************************************])
AC_WARN([*** VampirTrace cannot be built due to disabled MPI profiling.])
if test -z "$enable_vt"; then
AC_WARN([*** Pausing to give you time to read this message...])
fi
AC_WARN([**************************************************************])
if test -z "$enable_vt"; then
sleep 10
fi
contrib_vt_happy=0
fi
# Check whether the used C++ STL is suitable to build VampirTrace.
# For example, in case of using the Oracle C++ compiler, some of the needed
# language features are missing in the default STL (libCstd). It's recommended
# to use the STLport4 instead, which is much more conform to the C++ standard.
if test "$contrib_vt_happy" = "1"; then
AC_MSG_CHECKING([whether C++ STL is suitable for vt])
# Append VampirTrace specific CXXFLAGS possibly given by --with-contrib-vt-flags
# to CXXFLAGS. They could contain flags which are essential for the success of
# the following configure test (e.g. -library=stlport4).
contrib_vt_save_CXXFLAGS="$CXXFLAGS"
eval "set x $with_contrib_vt_flags"; shift
for contrib_vt_flag
do
case $contrib_vt_flag in
CXXFLAGS=*)
contrib_vt_flag=`echo "$contrib_vt_flag" | sed "s/CXXFLAGS=//"`
CXXFLAGS="$contrib_vt_save_CXXFLAGS $contrib_vt_flag"
;;
esac
done
AC_LANG_PUSH(C++)
AC_COMPILE_IFELSE(
[AC_LANG_PROGRAM([[#include <map>]],
[[std::map<int, int> map;
// The following assignment implicitly converts an "iterator"
// to a "const_interator". Although this is allowed by the C++
// standard, using Oracle's default STL (libCstd) will cause a
// compile error.
// Seen with Oracle Studio version 12.3 and Express 6/10.
std::pair<std::map<int, int>::const_iterator, bool> ret=
map.insert(std::pair<int, int>(123, 456));]])],
[AC_MSG_RESULT([yes])],
[AC_MSG_RESULT([no])
AC_WARN([**************************************************************])
AC_WARN([*** VampirTrace cannot be built due to your STL appears to])
AC_WARN([*** be broken.])
if test "x$ompi_cv_cxx_compiler_vendor" = "xsun"; then
AC_WARN([*** Please try again re-configuring Open MPI with using])
AC_WARN([*** the STLport4 by adding the compiler flag -library=stlport4])
AC_WARN([*** to CXXFLAGS.])
fi
if test -z "$enable_vt"; then
AC_WARN([*** Pausing to give you time to read this message...])
fi
AC_WARN([**************************************************************])
if test -z "$enable_vt"; then
sleep 10
fi
contrib_vt_happy=0])
AC_LANG_POP(C++)
CXXFLAGS="$contrib_vt_save_CXXFLAGS"
fi
if test "$contrib_vt_happy" = "1"; then
contrib_vt_args="--disable-option-checking --with-openmpi-inside=1.7"
eval "set x $ac_configure_args"; shift
for contrib_vt_arg
do
case $contrib_vt_arg in
-with-contrib-vt-flags | --with-contrib-vt-flags | -with-contrib-vt-flags=* | --with-contrib-vt-flags=*)
;;
-with-platform=* | --with-platform=*)
;;
-with-cuda | --with-cuda | -with-cuda=* | --with-cuda=*)
if test "x$with_cuda" != "xno" -a "x$with_cuda" != "x"; then
contrib_vt_args="$contrib_vt_args '--with-cuda-dir=$with_cuda' '--with-cuda-libdir=$with_cuda_libdir'"
fi
;;
-with-cuda-libdir | --with-cuda-libdir | -with-cuda-libdir=* | --with-cuda-libdir=*)
;;
*)
case $contrib_vt_arg in
*\'*) contrib_vt_arg=`echo "$contrib_vt_arg" | sed "s/'/'\\\\\\\\''/g"` ;;
esac
contrib_vt_args="$contrib_vt_args '$contrib_vt_arg'"
;;
esac
done
contrib_vt_args="$contrib_vt_args $with_contrib_vt_flags"
# Run VampirTrace's configure and see if it succeeded
OPAL_CONFIG_SUBDIR([ompi/contrib/vt/vt],
[$contrib_vt_args],
[], [contrib_vt_happy=0])
fi
# If VampirTrace configured itself successfully, setup OMPI-specific
# VampirTrace glue code to build.
AS_IF([test "$contrib_vt_happy" = "1"],
[$1
AC_CONFIG_FILES([
ompi/contrib/vt/Makefile
ompi/contrib/vt/wrappers/Makefile
ompi/contrib/vt/wrappers/mpicc-vt-wrapper-data.txt
ompi/contrib/vt/wrappers/mpic++-vt-wrapper-data.txt
ompi/contrib/vt/wrappers/mpifort-vt-wrapper-data.txt
])],
[$2])
])dnl