Statistiques
| Révision :

root / setup / Make.Debian_CBLAS_OpenMPI @ 9

Historique | Voir | Annoter | Télécharger (8,81 ko)

1 3 equemene
#
2 3 equemene
#  -- High Performance Computing Linpack Benchmark (HPL)
3 3 equemene
#     HPL - 2.0 - September 10, 2008
4 3 equemene
#     Antoine P. Petitet
5 3 equemene
#     University of Tennessee, Knoxville
6 3 equemene
#     Innovative Computing Laboratory
7 3 equemene
#     (C) Copyright 2000-2008 All Rights Reserved
8 3 equemene
#
9 3 equemene
#  -- Copyright notice and Licensing terms:
10 3 equemene
#
11 3 equemene
#  Redistribution  and  use in  source and binary forms, with or without
12 3 equemene
#  modification, are  permitted provided  that the following  conditions
13 3 equemene
#  are met:
14 3 equemene
#
15 3 equemene
#  1. Redistributions  of  source  code  must retain the above copyright
16 3 equemene
#  notice, this list of conditions and the following disclaimer.
17 3 equemene
#
18 3 equemene
#  2. Redistributions in binary form must reproduce  the above copyright
19 3 equemene
#  notice, this list of conditions,  and the following disclaimer in the
20 3 equemene
#  documentation and/or other materials provided with the distribution.
21 3 equemene
#
22 3 equemene
#  3. All  advertising  materials  mentioning  features  or  use of this
23 3 equemene
#  software must display the following acknowledgement:
24 3 equemene
#  This  product  includes  software  developed  at  the  University  of
25 3 equemene
#  Tennessee, Knoxville, Innovative Computing Laboratory.
26 3 equemene
#
27 3 equemene
#  4. The name of the  University,  the name of the  Laboratory,  or the
28 3 equemene
#  names  of  its  contributors  may  not  be used to endorse or promote
29 3 equemene
#  products  derived   from   this  software  without  specific  written
30 3 equemene
#  permission.
31 3 equemene
#
32 3 equemene
#  -- Disclaimer:
33 3 equemene
#
34 3 equemene
#  THIS  SOFTWARE  IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
35 3 equemene
#  ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES,  INCLUDING,  BUT NOT
36 3 equemene
#  LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
37 3 equemene
#  A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE UNIVERSITY
38 3 equemene
#  OR  CONTRIBUTORS  BE  LIABLE FOR ANY  DIRECT,  INDIRECT,  INCIDENTAL,
39 3 equemene
#  SPECIAL,  EXEMPLARY,  OR  CONSEQUENTIAL DAMAGES  (INCLUDING,  BUT NOT
40 3 equemene
#  LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
41 3 equemene
#  DATA OR PROFITS; OR BUSINESS INTERRUPTION)  HOWEVER CAUSED AND ON ANY
42 3 equemene
#  THEORY OF LIABILITY, WHETHER IN CONTRACT,  STRICT LIABILITY,  OR TORT
43 3 equemene
#  (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
44 3 equemene
#  OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
45 3 equemene
# ######################################################################
46 3 equemene
#
47 3 equemene
# ----------------------------------------------------------------------
48 3 equemene
# - shell --------------------------------------------------------------
49 3 equemene
# ----------------------------------------------------------------------
50 3 equemene
#
51 3 equemene
SHELL        = /bin/sh
52 3 equemene
#
53 3 equemene
CD           = cd
54 3 equemene
CP           = cp
55 3 equemene
LN_S         = ln -s
56 3 equemene
MKDIR        = mkdir
57 3 equemene
RM           = /bin/rm -f
58 3 equemene
TOUCH        = touch
59 3 equemene
#
60 3 equemene
# ----------------------------------------------------------------------
61 3 equemene
# - Platform identifier ------------------------------------------------
62 3 equemene
# ----------------------------------------------------------------------
63 3 equemene
#
64 3 equemene
ARCH         = $(arch)
65 3 equemene
#
66 3 equemene
# ----------------------------------------------------------------------
67 3 equemene
# - HPL Directory Structure / HPL library ------------------------------
68 3 equemene
# ----------------------------------------------------------------------
69 3 equemene
#
70 3 equemene
TOPdir       = $(topdir)
71 3 equemene
INCdir       = $(TOPdir)/include
72 3 equemene
BINdir       = $(TOPdir)/bin/$(ARCH)
73 3 equemene
LIBdir       = $(TOPdir)/lib/$(ARCH)
74 3 equemene
#
75 3 equemene
HPLlib       = $(LIBdir)/libhpl.a
76 3 equemene
#
77 3 equemene
# ----------------------------------------------------------------------
78 3 equemene
# - Message Passing library (MPI) --------------------------------------
79 3 equemene
# ----------------------------------------------------------------------
80 3 equemene
# MPinc tells the  C  compiler where to find the Message Passing library
81 3 equemene
# header files,  MPlib  is defined  to be the name of  the library to be
82 3 equemene
# used. The variable MPdir is only used for defining MPinc and MPlib.
83 3 equemene
#
84 3 equemene
MPdir        = /usr/lib/openmpi
85 9 equemene
MPinc        = -I/include/include/openmpi
86 3 equemene
MPlib        = -L$(MPdir)/lib/libmpi.so
87 3 equemene
#
88 3 equemene
# ----------------------------------------------------------------------
89 3 equemene
# - Linear Algebra library (BLAS or VSIPL) -----------------------------
90 3 equemene
# ----------------------------------------------------------------------
91 3 equemene
# LAinc tells the  C  compiler where to find the Linear Algebra  library
92 3 equemene
# header files,  LAlib  is defined  to be the name of  the library to be
93 3 equemene
# used. The variable LAdir is only used for defining LAinc and LAlib.
94 3 equemene
#
95 4 equemene
LAdir        = /usr/lib
96 3 equemene
LAinc        =
97 3 equemene
LAlib        = $(LAdir)/libcblas.so $(LAdir)/libatlas.so
98 3 equemene
#
99 3 equemene
# ----------------------------------------------------------------------
100 3 equemene
# - F77 / C interface --------------------------------------------------
101 3 equemene
# ----------------------------------------------------------------------
102 3 equemene
# You can skip this section  if and only if  you are not planning to use
103 3 equemene
# a  BLAS  library featuring a Fortran 77 interface.  Otherwise,  it  is
104 3 equemene
# necessary  to  fill out the  F2CDEFS  variable  with  the  appropriate
105 3 equemene
# options.  **One and only one**  option should be chosen in **each** of
106 3 equemene
# the 3 following categories:
107 3 equemene
#
108 3 equemene
# 1) name space (How C calls a Fortran 77 routine)
109 3 equemene
#
110 3 equemene
# -DAdd_              : all lower case and a suffixed underscore  (Suns,
111 3 equemene
#                       Intel, ...),                           [default]
112 3 equemene
# -DNoChange          : all lower case (IBM RS6000),
113 3 equemene
# -DUpCase            : all upper case (Cray),
114 3 equemene
# -DAdd__             : the FORTRAN compiler in use is f2c.
115 3 equemene
#
116 3 equemene
# 2) C and Fortran 77 integer mapping
117 3 equemene
#
118 3 equemene
# -DF77_INTEGER=int   : Fortran 77 INTEGER is a C int,         [default]
119 3 equemene
# -DF77_INTEGER=long  : Fortran 77 INTEGER is a C long,
120 3 equemene
# -DF77_INTEGER=short : Fortran 77 INTEGER is a C short.
121 3 equemene
#
122 3 equemene
# 3) Fortran 77 string handling
123 3 equemene
#
124 3 equemene
# -DStringSunStyle    : The string address is passed at the string loca-
125 3 equemene
#                       tion on the stack, and the string length is then
126 3 equemene
#                       passed as  an  F77_INTEGER  after  all  explicit
127 3 equemene
#                       stack arguments,                       [default]
128 3 equemene
# -DStringStructPtr   : The address  of  a  structure  is  passed  by  a
129 3 equemene
#                       Fortran 77  string,  and the structure is of the
130 3 equemene
#                       form: struct {char *cp; F77_INTEGER len;},
131 3 equemene
# -DStringStructVal   : A structure is passed by value for each  Fortran
132 3 equemene
#                       77 string,  and  the  structure is  of the form:
133 3 equemene
#                       struct {char *cp; F77_INTEGER len;},
134 3 equemene
# -DStringCrayStyle   : Special option for  Cray  machines,  which  uses
135 3 equemene
#                       Cray  fcd  (fortran  character  descriptor)  for
136 3 equemene
#                       interoperation.
137 3 equemene
#
138 3 equemene
F2CDEFS      =
139 3 equemene
#
140 3 equemene
# ----------------------------------------------------------------------
141 3 equemene
# - HPL includes / libraries / specifics -------------------------------
142 3 equemene
# ----------------------------------------------------------------------
143 3 equemene
#
144 3 equemene
HPL_INCLUDES = -I$(INCdir) -I$(INCdir)/$(ARCH) $(LAinc) $(MPinc)
145 3 equemene
HPL_LIBS     = $(HPLlib) $(LAlib) $(MPlib)
146 3 equemene
#
147 3 equemene
# - Compile time options -----------------------------------------------
148 3 equemene
#
149 3 equemene
# -DHPL_COPY_L           force the copy of the panel L before bcast;
150 3 equemene
# -DHPL_CALL_CBLAS       call the cblas interface;
151 3 equemene
# -DHPL_CALL_VSIPL       call the vsip  library;
152 3 equemene
# -DHPL_DETAILED_TIMING  enable detailed timers;
153 3 equemene
#
154 3 equemene
# By default HPL will:
155 3 equemene
#    *) not copy L before broadcast,
156 3 equemene
#    *) call the BLAS Fortran 77 interface,
157 3 equemene
#    *) not display detailed timing information.
158 3 equemene
#
159 3 equemene
HPL_OPTS     = -DHPL_CALL_CBLAS
160 3 equemene
#
161 3 equemene
# ----------------------------------------------------------------------
162 3 equemene
#
163 3 equemene
HPL_DEFS     = $(F2CDEFS) $(HPL_OPTS) $(HPL_INCLUDES)
164 3 equemene
#
165 3 equemene
# ----------------------------------------------------------------------
166 3 equemene
# - Compilers / linkers - Optimization flags ---------------------------
167 3 equemene
# ----------------------------------------------------------------------
168 3 equemene
#
169 3 equemene
CC           = /usr/bin/mpicc.openmpi
170 3 equemene
CCNOOPT      = $(HPL_DEFS)
171 3 equemene
CCFLAGS      = $(HPL_DEFS) -fomit-frame-pointer -O3 -funroll-loops -W -Wall
172 3 equemene
#
173 3 equemene
# On some platforms,  it is necessary  to use the Fortran linker to find
174 3 equemene
# the Fortran internals used in the BLAS library.
175 3 equemene
#
176 5 equemene
LINKER       = /usr/bin/mpif77.openmpi
177 3 equemene
LINKFLAGS    = $(CCFLAGS)
178 3 equemene
#
179 3 equemene
ARCHIVER     = ar
180 3 equemene
ARFLAGS      = r
181 3 equemene
RANLIB       = echo
182 3 equemene
#
183 3 equemene
# ----------------------------------------------------------------------