206 lines
		
	
	
		
			8.9 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
		
		
			
		
	
	
			206 lines
		
	
	
		
			8.9 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
|  | ################################################################################################# | ||
|  | # Copyright (c) 2010, Lawrence Livermore National Security, LLC. | ||
|  | # Produced at the Lawrence Livermore National Laboratory | ||
|  | # Written by Todd Gamblin, tgamblin@llnl.gov. | ||
|  | # LLNL-CODE-417602 | ||
|  | # All rights reserved. | ||
|  | # | ||
|  | # This file is part of Libra. For details, see http://github.com/tgamblin/libra. | ||
|  | # Please also read the LICENSE file for further information. | ||
|  | # | ||
|  | # Redistribution and use in source and binary forms, with or without modification, are | ||
|  | # permitted provided that the following conditions are met: | ||
|  | # | ||
|  | # * Redistributions of source code must retain the above copyright notice, this list of | ||
|  | # conditions and the disclaimer below. | ||
|  | # * Redistributions in binary form must reproduce the above copyright notice, this list of | ||
|  | # conditions and the disclaimer (as noted below) in the documentation and/or other materials | ||
|  | # provided with the distribution. | ||
|  | # * Neither the name of the LLNS/LLNL nor the names of its contributors may be used to endorse | ||
|  | # or promote products derived from this software without specific prior written permission. | ||
|  | # | ||
|  | # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS | ||
|  | # OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF | ||
|  | # MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL | ||
|  | # LAWRENCE LIVERMORE NATIONAL SECURITY, LLC, THE U.S. DEPARTMENT OF ENERGY OR CONTRIBUTORS BE | ||
|  | # LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||
|  | # (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||
|  | # DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, | ||
|  | # WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN | ||
|  | # ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||
|  | ################################################################################################# | ||
|  | 
 | ||
|  | # | ||
|  | # LX_FIND_MPI() | ||
|  | # ------------------------------------------------------------------------ | ||
|  | # This macro finds an MPI compiler and extracts includes and libraries from | ||
|  | # it for use in automake projects. The script exports the following variables: | ||
|  | # | ||
|  | # AC_DEFINE variables: | ||
|  | # HAVE_MPI AC_DEFINE'd to 1 if we found MPI | ||
|  | # | ||
|  | # AC_SUBST variables: | ||
|  | # MPICC Name of MPI compiler | ||
|  | # MPI_CFLAGS Includes and defines for MPI C compilation | ||
|  | # MPI_CLDFLAGS Libraries and library paths for linking MPI C programs | ||
|  | # | ||
|  | # MPICXX Name of MPI C++ compiler | ||
|  | # MPI_CXXFLAGS Includes and defines for MPI C++ compilation | ||
|  | # MPI_CXXLDFLAGS Libraries and library paths for linking MPI C++ programs | ||
|  | # | ||
|  | # MPIF77 Name of MPI Fortran 77 compiler | ||
|  | # MPI_F77FLAGS Includes and defines for MPI Fortran 77 compilation | ||
|  | # MPI_F77LDFLAGS Libraries and library paths for linking MPI Fortran 77 programs | ||
|  | # | ||
|  | # MPIFC Name of MPI Fortran compiler | ||
|  | # MPI_FFLAGS Includes and defines for MPI Fortran compilation | ||
|  | # MPI_FLDFLAGS Libraries and library paths for linking MPI Fortran programs | ||
|  | # | ||
|  | # Shell variables output by this macro: | ||
|  | # have_C_mpi 'yes' if we found MPI for C, 'no' otherwise | ||
|  | # have_CXX_mpi 'yes' if we found MPI for C++, 'no' otherwise | ||
|  | # have_F77_mpi 'yes' if we found MPI for F77, 'no' otherwise | ||
|  | # have_F_mpi 'yes' if we found MPI for Fortran, 'no' otherwise | ||
|  | # | ||
|  | AC_DEFUN([LX_FIND_MPI], | ||
|  | [ | ||
|  |      AC_LANG_CASE( | ||
|  |      [C], [ | ||
|  |          AC_REQUIRE([AC_PROG_CC]) | ||
|  |          if [[ ! -z "$MPICC" ]]; then | ||
|  |              LX_QUERY_MPI_COMPILER(MPICC, [$MPICC], C) | ||
|  |          else | ||
|  |              LX_QUERY_MPI_COMPILER(MPICC, [mpicc mpiicc mpixlc mpipgcc], C) | ||
|  |          fi | ||
|  |      ], | ||
|  |      [C++], [ | ||
|  |          AC_REQUIRE([AC_PROG_CXX]) | ||
|  |          if [[ ! -z "$MPICXX" ]]; then | ||
|  |              LX_QUERY_MPI_COMPILER(MPICXX, [$MPICXX], CXX) | ||
|  |          else | ||
|  |              LX_QUERY_MPI_COMPILER(MPICXX, [mpicxx mpiCC mpic++ mpig++ mpiicpc mpipgCC mpixlC], CXX) | ||
|  |          fi | ||
|  |      ], | ||
|  |      [F77], [ | ||
|  |          AC_REQUIRE([AC_PROG_F77]) | ||
|  |          if [[ ! -z "$MPIF77" ]]; then | ||
|  |              LX_QUERY_MPI_COMPILER(MPIF77, [$MPIF77], F77) | ||
|  |          else | ||
|  |              LX_QUERY_MPI_COMPILER(MPIF77, [mpif77 mpiifort mpixlf77 mpixlf77_r], F77) | ||
|  |          fi | ||
|  |      ], | ||
|  |      [Fortran], [ | ||
|  |          AC_REQUIRE([AC_PROG_FC]) | ||
|  |          if [[ ! -z "$MPIFC" ]]; then | ||
|  |              LX_QUERY_MPI_COMPILER(MPIFC, [$MPIFC], F) | ||
|  |          else | ||
|  |              mpi_default_fc="mpif95 mpif90 mpigfortran mpif2003" | ||
|  |              mpi_intel_fc="mpiifort" | ||
|  |              mpi_xl_fc="mpixlf95 mpixlf95_r mpixlf90 mpixlf90_r mpixlf2003 mpixlf2003_r" | ||
|  |              mpi_pg_fc="mpipgf95 mpipgf90" | ||
|  |              LX_QUERY_MPI_COMPILER(MPIFC, [$mpi_default_fc $mpi_intel_fc $mpi_xl_fc $mpi_pg_fc], F) | ||
|  |          fi | ||
|  |      ]) | ||
|  | ]) | ||
|  | 
 | ||
|  | 
 | ||
|  | # | ||
|  | # LX_QUERY_MPI_COMPILER([compiler-var-name], [compiler-names], [output-var-prefix]) | ||
|  | # ------------------------------------------------------------------------ | ||
|  | # AC_SUBST variables: | ||
|  | # MPI_<prefix>FLAGS Includes and defines for MPI compilation | ||
|  | # MPI_<prefix>LDFLAGS Libraries and library paths for linking MPI C programs | ||
|  | # | ||
|  | # Shell variables output by this macro: | ||
|  | # found_mpi_flags 'yes' if we were able to get flags, 'no' otherwise | ||
|  | # | ||
|  | AC_DEFUN([LX_QUERY_MPI_COMPILER], | ||
|  | [ | ||
|  |      # Try to find a working MPI compiler from the supplied names | ||
|  |      AC_PATH_PROGS($1, [$2], [not-found]) | ||
|  |       | ||
|  |      # Figure out what the compiler responds to to get it to show us the compile | ||
|  |      # and link lines. After this part of the macro, we'll have a valid | ||
|  |      # lx_mpi_command_line | ||
|  |      echo -n "Checking whether $$1 responds to '-showme:compile'... " | ||
|  |      lx_mpi_compile_line=`$$1 -showme:compile 2>/dev/null` | ||
|  |      if [[ "$?" -eq 0 ]]; then | ||
|  |          echo yes | ||
|  |          lx_mpi_link_line=`$$1 -showme:link 2>/dev/null` | ||
|  |      else | ||
|  |          echo no | ||
|  |          echo -n "Checking whether $$1 responds to '-showme'... " | ||
|  |          lx_mpi_command_line=`$$1 -showme 2>/dev/null` | ||
|  |          if [[ "$?" -ne 0 ]]; then | ||
|  |              echo no | ||
|  |              echo -n "Checking whether $$1 responds to '-compile-info'... " | ||
|  |              lx_mpi_compile_line=`$$1 -compile-info 2>/dev/null` | ||
|  |              if [[ "$?" -eq 0 ]]; then | ||
|  |                  echo yes | ||
|  |                  lx_mpi_link_line=`$$1 -link-info 2>/dev/null` | ||
|  |              else | ||
|  |                  echo no | ||
|  |                  echo -n "Checking whether $$1 responds to '-show'... " | ||
|  |                  lx_mpi_command_line=`$$1 -show 2>/dev/null` | ||
|  |                  if [[ "$?" -eq 0 ]]; then | ||
|  |                      echo yes | ||
|  |                  else | ||
|  |                      echo no | ||
|  |                  fi | ||
|  |              fi | ||
|  |          else | ||
|  |              echo yes | ||
|  |          fi | ||
|  |      fi | ||
|  |            | ||
|  |      if [[ ! -z "$lx_mpi_compile_line" -a ! -z "$lx_mpi_link_line" ]]; then | ||
|  |          lx_mpi_command_line="$lx_mpi_compile_line $lx_mpi_link_line" | ||
|  |      fi | ||
|  | 
 | ||
|  |      if [[ ! -z "$lx_mpi_command_line" ]]; then | ||
|  |          # Now extract the different parts of the MPI command line. Do these separately in case we need to | ||
|  |          # parse them all out in future versions of this macro. | ||
|  |          lx_mpi_defines=` echo "$lx_mpi_command_line" | grep -o -- '\(^\| \)-D\([[^\"[:space:]]]\+\|\"[[^\"[:space:]]]\+\"\)'` | ||
|  |          lx_mpi_includes=` echo "$lx_mpi_command_line" | grep -o -- '\(^\| \)-I\([[^\"[:space:]]]\+\|\"[[^\"[:space:]]]\+\"\)'` | ||
|  |          lx_mpi_link_paths=` echo "$lx_mpi_command_line" | grep -o -- '\(^\| \)-L\([[^\"[:space:]]]\+\|\"[[^\"[:space:]]]\+\"\)'` | ||
|  |          lx_mpi_libs=` echo "$lx_mpi_command_line" | grep -o -- '\(^\| \)-l\([[^\"[:space:]]]\+\|\"[[^\"[:space:]]]\+\"\)'` | ||
|  |          lx_mpi_link_args=` echo "$lx_mpi_command_line" | grep -o -- '\(^\| \)-Wl,\([[^\"[:space:]]]\+\|\"[[^\"[:space:]]]\+\"\)'` | ||
|  |           | ||
|  |          # Create variables and clean up newlines and multiple spaces | ||
|  |          MPI_$3FLAGS="$lx_mpi_defines $lx_mpi_includes" | ||
|  |          MPI_$3LDFLAGS="$lx_mpi_link_paths $lx_mpi_libs $lx_mpi_link_args" | ||
|  |          MPI_$3FLAGS=` echo "$MPI_$3FLAGS" | tr '\n' ' ' | sed 's/^[[ \t]]*//;s/[[ \t]]*$//' | sed 's/ +/ /g'` | ||
|  |          MPI_$3LDFLAGS=`echo "$MPI_$3LDFLAGS" | tr '\n' ' ' | sed 's/^[[ \t]]*//;s/[[ \t]]*$//' | sed 's/ +/ /g'` | ||
|  | 
 | ||
|  |          OLD_CPPFLAGS=$CPPFLAGS | ||
|  |          OLD_LIBS=$LIBS | ||
|  |          CPPFLAGS=$MPI_$3FLAGS | ||
|  |          LIBS=$MPI_$3LDFLAGS | ||
|  | 
 | ||
|  |          AC_TRY_LINK([#include <mpi.h>], | ||
|  |                      [int rank, size; | ||
|  |                       MPI_Comm_rank(MPI_COMM_WORLD, &rank); | ||
|  |                       MPI_Comm_size(MPI_COMM_WORLD, &size);], | ||
|  |                      [# Add a define for testing at compile time. | ||
|  |                       AC_DEFINE([HAVE_MPI], [1], [Define to 1 if you have MPI libs and headers.]) | ||
|  |                       have_$3_mpi='yes'], | ||
|  |                      [# zero out mpi flags so we don't link against the faulty library. | ||
|  |                       MPI_$3FLAGS="" | ||
|  |                       MPI_$3LDFLAGS="" | ||
|  |                       have_$3_mpi='no']) | ||
|  | 
 | ||
|  |          # AC_SUBST everything. | ||
|  |          AC_SUBST($1) | ||
|  |          AC_SUBST(MPI_$3FLAGS) | ||
|  |          AC_SUBST(MPI_$3LDFLAGS) | ||
|  | 
 | ||
|  |          LIBS=$OLD_LIBS | ||
|  |          CPPFLAGS=$OLD_CPPFLAGS | ||
|  |      else | ||
|  |          echo Unable to find suitable MPI Compiler. Try setting $1. | ||
|  |          have_$3_mpi='no' | ||
|  |      fi | ||
|  | ]) | ||
|  | 
 | ||
|  | 
 |