280930e299
This commit was SVN r27560.
156 строки
6.6 KiB
Bash
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
|
|
OMPI_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
|