source: m4/lx_find_mpi.m4@ f83e26

Action_Thermostats Add_AtomRandomPerturbation Add_FitFragmentPartialChargesAction Add_RotateAroundBondAction Add_SelectAtomByNameAction Added_ParseSaveFragmentResults Adding_Graph_to_ChangeBondActions Adding_MD_integration_tests Adding_StructOpt_integration_tests Automaking_mpqc_open AutomationFragmentation_failures Candidate_v1.5.4 Candidate_v1.6.0 Candidate_v1.6.1 Candidate_v1.7.0 ChangeBugEmailaddress ChangingTestPorts ChemicalSpaceEvaluator Combining_Subpackages Debian_Package_split Debian_package_split_molecuildergui_only Disabling_MemDebug Docu_Python_wait EmpiricalPotential_contain_HomologyGraph EmpiricalPotential_contain_HomologyGraph_documentation Enable_parallel_make_install Enhance_userguide Enhanced_StructuralOptimization Enhanced_StructuralOptimization_continued Example_ManyWaysToTranslateAtom Exclude_Hydrogens_annealWithBondGraph FitPartialCharges_GlobalError Fix_ChargeSampling_PBC Fix_ChronosMutex Fix_FitPartialCharges Fix_FitPotential_needs_atomicnumbers Fix_ForceAnnealing Fix_IndependentFragmentGrids Fix_ParseParticles Fix_ParseParticles_split_forward_backward_Actions Fix_StatusMsg Fix_StepWorldTime_single_argument Fix_Verbose_Codepatterns Fixes ForceAnnealing_goodresults ForceAnnealing_oldresults ForceAnnealing_tocheck ForceAnnealing_with_BondGraph ForceAnnealing_with_BondGraph_continued ForceAnnealing_with_BondGraph_continued_betteresults ForceAnnealing_with_BondGraph_contraction-expansion GeometryObjects Gui_displays_atomic_force_velocity IndependentFragmentGrids IndependentFragmentGrids_IndividualZeroInstances IndependentFragmentGrids_IntegrationTest IndependentFragmentGrids_Sole_NN_Calculation JobMarket_RobustOnKillsSegFaults JobMarket_StableWorkerPool JobMarket_unresolvable_hostname_fix ODR_violation_mpqc_open PartialCharges_OrthogonalSummation PythonUI_with_named_parameters QtGui_reactivate_TimeChanged_changes Recreated_GuiChecks RotateToPrincipalAxisSystem_UndoRedo SaturateAtoms_findBestMatching SaturateAtoms_singleDegree StoppableMakroAction Subpackage_CodePatterns Subpackage_JobMarket Subpackage_LinearAlgebra Subpackage_levmar Subpackage_mpqc_open Subpackage_vmg ThirdParty_MPQC_rebuilt_buildsystem TrajectoryDependenant_MaxOrder TremoloParser_IncreasedPrecision TremoloParser_MultipleTimesteps Ubuntu_1604_changes stable
Last change on this file since f83e26 was 8a8c8c, checked in by Frederik Heber <heber@…>, 13 years ago

Using CommMPI in VMGJob now.

  • this is used instead of CommSerial as CommMPI is better maintained right now.
  • using lx_find_mpi from Libra project to detect mpi compiler and linker flags.
  • Property mode set to 100644
File size: 9.1 KB
Line 
1#################################################################################################
2# Copyright (c) 2010, Lawrence Livermore National Security, LLC.
3# Produced at the Lawrence Livermore National Laboratory
4# Written by Todd Gamblin, tgamblin@llnl.gov.
5# LLNL-CODE-417602
6# All rights reserved.
7#
8# This file is part of Libra. For details, see http://github.com/tgamblin/libra.
9# Please also read the LICENSE file for further information.
10#
11# Redistribution and use in source and binary forms, with or without modification, are
12# permitted provided that the following conditions are met:
13#
14# * Redistributions of source code must retain the above copyright notice, this list of
15# conditions and the disclaimer below.
16# * Redistributions in binary form must reproduce the above copyright notice, this list of
17# conditions and the disclaimer (as noted below) in the documentation and/or other materials
18# provided with the distribution.
19# * Neither the name of the LLNS/LLNL nor the names of its contributors may be used to endorse
20# or promote products derived from this software without specific prior written permission.
21#
22# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS
23# OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
24# MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
25# LAWRENCE LIVERMORE NATIONAL SECURITY, LLC, THE U.S. DEPARTMENT OF ENERGY OR CONTRIBUTORS BE
26# LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
27# (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
28# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
29# WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
30# ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
31#################################################################################################
32
33#
34# LX_FIND_MPI()
35# ------------------------------------------------------------------------
36# This macro finds an MPI compiler and extracts includes and libraries from
37# it for use in automake projects. The script exports the following variables:
38#
39# AC_DEFINE variables:
40# HAVE_MPI AC_DEFINE'd to 1 if we found MPI
41#
42# AC_SUBST variables:
43# MPICC Name of MPI compiler
44# MPI_CFLAGS Includes and defines for MPI C compilation
45# MPI_CLDFLAGS Libraries and library paths for linking MPI C programs
46#
47# MPICXX Name of MPI C++ compiler
48# MPI_CXXFLAGS Includes and defines for MPI C++ compilation
49# MPI_CXXLDFLAGS Libraries and library paths for linking MPI C++ programs
50#
51# MPIF77 Name of MPI Fortran 77 compiler
52# MPI_F77FLAGS Includes and defines for MPI Fortran 77 compilation
53# MPI_F77LDFLAGS Libraries and library paths for linking MPI Fortran 77 programs
54#
55# MPIFC Name of MPI Fortran compiler
56# MPI_FFLAGS Includes and defines for MPI Fortran compilation
57# MPI_FLDFLAGS Libraries and library paths for linking MPI Fortran programs
58#
59# Shell variables output by this macro:
60# have_C_mpi 'yes' if we found MPI for C, 'no' otherwise
61# have_CXX_mpi 'yes' if we found MPI for C++, 'no' otherwise
62# have_F77_mpi 'yes' if we found MPI for F77, 'no' otherwise
63# have_F_mpi 'yes' if we found MPI for Fortran, 'no' otherwise
64#
65AC_DEFUN([LX_FIND_MPI],
66[
67 AC_LANG_CASE(
68 [C], [
69 AC_REQUIRE([AC_PROG_CC])
70 if [[ ! -z "$MPICC" ]]; then
71 LX_QUERY_MPI_COMPILER(MPICC, [$MPICC], C)
72 else
73 LX_QUERY_MPI_COMPILER(MPICC, [mpicc mpiicc mpixlc mpipgcc], C)
74 fi
75 ],
76 [C++], [
77 AC_REQUIRE([AC_PROG_CXX])
78 if [[ ! -z "$MPICXX" ]]; then
79 LX_QUERY_MPI_COMPILER(MPICXX, [$MPICXX], CXX)
80 else
81 LX_QUERY_MPI_COMPILER(MPICXX, [mpicxx mpiCC mpic++ mpig++ mpiicpc mpipgCC mpixlC], CXX)
82 fi
83 ],
84 [F77], [
85 AC_REQUIRE([AC_PROG_F77])
86 if [[ ! -z "$MPIF77" ]]; then
87 LX_QUERY_MPI_COMPILER(MPIF77, [$MPIF77], F77)
88 else
89 LX_QUERY_MPI_COMPILER(MPIF77, [mpif77 mpiifort mpixlf77 mpixlf77_r], F77)
90 fi
91 ],
92 [Fortran], [
93 AC_REQUIRE([AC_PROG_FC])
94 if [[ ! -z "$MPIFC" ]]; then
95 LX_QUERY_MPI_COMPILER(MPIFC, [$MPIFC], F)
96 else
97 mpi_default_fc="mpif95 mpif90 mpigfortran mpif2003"
98 mpi_intel_fc="mpiifort"
99 mpi_xl_fc="mpixlf95 mpixlf95_r mpixlf90 mpixlf90_r mpixlf2003 mpixlf2003_r"
100 mpi_pg_fc="mpipgf95 mpipgf90"
101 LX_QUERY_MPI_COMPILER(MPIFC, [$mpi_default_fc $mpi_intel_fc $mpi_xl_fc $mpi_pg_fc], F)
102 fi
103 ])
104])
105
106
107#
108# LX_QUERY_MPI_COMPILER([compiler-var-name], [compiler-names], [output-var-prefix])
109# ------------------------------------------------------------------------
110# AC_SUBST variables:
111# MPI_<prefix>FLAGS Includes and defines for MPI compilation
112# MPI_<prefix>LDFLAGS Libraries and library paths for linking MPI C programs
113#
114# Shell variables output by this macro:
115# found_mpi_flags 'yes' if we were able to get flags, 'no' otherwise
116#
117AC_DEFUN([LX_QUERY_MPI_COMPILER],
118[
119 # Try to find a working MPI compiler from the supplied names
120 AC_PATH_PROGS($1, [$2], [not-found])
121
122 # Figure out what the compiler responds to to get it to show us the compile
123 # and link lines. After this part of the macro, we'll have a valid
124 # lx_mpi_command_line
125 echo -n "Checking whether $$1 responds to '-showme:compile'... "
126 lx_mpi_compile_line=`$$1 -showme:compile 2>/dev/null`
127 if [[ "$?" -eq 0 ]]; then
128 echo yes
129 lx_mpi_link_line=`$$1 -showme:link 2>/dev/null`
130 else
131 echo no
132 echo -n "Checking whether $$1 responds to '-showme'... "
133 lx_mpi_command_line=`$$1 -showme 2>/dev/null`
134 if [[ "$?" -ne 0 ]]; then
135 echo no
136 echo -n "Checking whether $$1 responds to '-compile-info'... "
137 lx_mpi_compile_line=`$$1 -compile-info 2>/dev/null`
138 if [[ "$?" -eq 0 ]]; then
139 echo yes
140 lx_mpi_link_line=`$$1 -link-info 2>/dev/null`
141 else
142 echo no
143 echo -n "Checking whether $$1 responds to '-show'... "
144 lx_mpi_command_line=`$$1 -show 2>/dev/null`
145 if [[ "$?" -eq 0 ]]; then
146 echo yes
147 else
148 echo no
149 fi
150 fi
151 else
152 echo yes
153 fi
154 fi
155
156 if [[ ! -z "$lx_mpi_compile_line" -a ! -z "$lx_mpi_link_line" ]]; then
157 lx_mpi_command_line="$lx_mpi_compile_line $lx_mpi_link_line"
158 fi
159
160 if [[ ! -z "$lx_mpi_command_line" ]]; then
161 # Now extract the different parts of the MPI command line. Do these separately in case we need to
162 # parse them all out in future versions of this macro.
163 lx_mpi_defines=` echo "$lx_mpi_command_line" | grep -o -- '\(^\| \)-D\([[^\"[:space:]]]\+\|\"[[^\"[:space:]]]\+\"\)'`
164 lx_mpi_includes=` echo "$lx_mpi_command_line" | grep -o -- '\(^\| \)-I\([[^\"[:space:]]]\+\|\"[[^\"[:space:]]]\+\"\)'`
165 lx_mpi_link_paths=` echo "$lx_mpi_command_line" | grep -o -- '\(^\| \)-L\([[^\"[:space:]]]\+\|\"[[^\"[:space:]]]\+\"\)'`
166 lx_mpi_libs=` echo "$lx_mpi_command_line" | grep -o -- '\(^\| \)-l\([[^\"[:space:]]]\+\|\"[[^\"[:space:]]]\+\"\)'`
167 lx_mpi_link_args=` echo "$lx_mpi_command_line" | grep -o -- '\(^\| \)-Wl,\([[^\"[:space:]]]\+\|\"[[^\"[:space:]]]\+\"\)'`
168
169 # Create variables and clean up newlines and multiple spaces
170 MPI_$3FLAGS="$lx_mpi_defines $lx_mpi_includes"
171 MPI_$3LDFLAGS="$lx_mpi_link_paths $lx_mpi_libs $lx_mpi_link_args"
172 MPI_$3FLAGS=` echo "$MPI_$3FLAGS" | tr '\n' ' ' | sed 's/^[[ \t]]*//;s/[[ \t]]*$//' | sed 's/ +/ /g'`
173 MPI_$3LDFLAGS=`echo "$MPI_$3LDFLAGS" | tr '\n' ' ' | sed 's/^[[ \t]]*//;s/[[ \t]]*$//' | sed 's/ +/ /g'`
174
175 OLD_CPPFLAGS=$CPPFLAGS
176 OLD_LIBS=$LIBS
177 CPPFLAGS=$MPI_$3FLAGS
178 LIBS=$MPI_$3LDFLAGS
179
180 AC_TRY_LINK([#include <mpi.h>],
181 [int rank, size;
182 MPI_Comm_rank(MPI_COMM_WORLD, &rank);
183 MPI_Comm_size(MPI_COMM_WORLD, &size);],
184 [# Add a define for testing at compile time.
185 AC_DEFINE([HAVE_MPI], [1], [Define to 1 if you have MPI libs and headers.])
186 have_$3_mpi='yes'],
187 [# zero out mpi flags so we don't link against the faulty library.
188 MPI_$3FLAGS=""
189 MPI_$3LDFLAGS=""
190 have_$3_mpi='no'])
191
192 # AC_SUBST everything.
193 AC_SUBST($1)
194 AC_SUBST(MPI_$3FLAGS)
195 AC_SUBST(MPI_$3LDFLAGS)
196
197 LIBS=$OLD_LIBS
198 CPPFLAGS=$OLD_CPPFLAGS
199 else
200 Echo Unable to find suitable MPI Compiler. Try setting $1.
201 have_$3_mpi='no'
202 fi
203])
204
Note: See TracBrowser for help on using the repository browser.