Statistiques
| Révision :

root / setup / Make.Debian_FBLAS_OpenMPI

Historique | Voir | Annoter | Télécharger (8,85 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 is defined in main Makefile. Can be overrided here
71 3 equemene
TOPdir       = $(topdir)
72 3 equemene
INCdir       = $(TOPdir)/include
73 3 equemene
BINdir       = $(TOPdir)/bin/$(ARCH)
74 3 equemene
LIBdir       = $(TOPdir)/lib/$(ARCH)
75 3 equemene
#
76 3 equemene
HPLlib       = $(LIBdir)/libhpl.a
77 3 equemene
#
78 3 equemene
# ----------------------------------------------------------------------
79 3 equemene
# - Message Passing library (MPI) --------------------------------------
80 3 equemene
# ----------------------------------------------------------------------
81 3 equemene
# MPinc tells the  C  compiler where to find the Message Passing library
82 3 equemene
# header files,  MPlib  is defined  to be the name of  the library to be
83 3 equemene
# used. The variable MPdir is only used for defining MPinc and MPlib.
84 3 equemene
#
85 3 equemene
MPdir        = /usr/lib/openmpi
86 3 equemene
MPinc        = -I$(MPdir)/include
87 3 equemene
MPlib        = -L$(MPdir)/lib/libmpi.so
88 3 equemene
#
89 3 equemene
# ----------------------------------------------------------------------
90 3 equemene
# - Linear Algebra library (BLAS or VSIPL) -----------------------------
91 3 equemene
# ----------------------------------------------------------------------
92 3 equemene
# LAinc tells the  C  compiler where to find the Linear Algebra  library
93 3 equemene
# header files,  LAlib  is defined  to be the name of  the library to be
94 3 equemene
# used. The variable LAdir is only used for defining LAinc and LAlib.
95 3 equemene
#
96 4 equemene
LAdir        = /usr/lib
97 3 equemene
LAinc        =
98 3 equemene
LAlib        = $(LAdir)/libf77blas.so $(LAdir)/libatlas.so
99 3 equemene
#
100 3 equemene
# ----------------------------------------------------------------------
101 3 equemene
# - F77 / C interface --------------------------------------------------
102 3 equemene
# ----------------------------------------------------------------------
103 3 equemene
# You can skip this section  if and only if  you are not planning to use
104 3 equemene
# a  BLAS  library featuring a Fortran 77 interface.  Otherwise,  it  is
105 3 equemene
# necessary  to  fill out the  F2CDEFS  variable  with  the  appropriate
106 3 equemene
# options.  **One and only one**  option should be chosen in **each** of
107 3 equemene
# the 3 following categories:
108 3 equemene
#
109 3 equemene
# 1) name space (How C calls a Fortran 77 routine)
110 3 equemene
#
111 3 equemene
# -DAdd_              : all lower case and a suffixed underscore  (Suns,
112 3 equemene
#                       Intel, ...),                           [default]
113 3 equemene
# -DNoChange          : all lower case (IBM RS6000),
114 3 equemene
# -DUpCase            : all upper case (Cray),
115 3 equemene
# -DAdd__             : the FORTRAN compiler in use is f2c.
116 3 equemene
#
117 3 equemene
# 2) C and Fortran 77 integer mapping
118 3 equemene
#
119 3 equemene
# -DF77_INTEGER=int   : Fortran 77 INTEGER is a C int,         [default]
120 3 equemene
# -DF77_INTEGER=long  : Fortran 77 INTEGER is a C long,
121 3 equemene
# -DF77_INTEGER=short : Fortran 77 INTEGER is a C short.
122 3 equemene
#
123 3 equemene
# 3) Fortran 77 string handling
124 3 equemene
#
125 3 equemene
# -DStringSunStyle    : The string address is passed at the string loca-
126 3 equemene
#                       tion on the stack, and the string length is then
127 3 equemene
#                       passed as  an  F77_INTEGER  after  all  explicit
128 3 equemene
#                       stack arguments,                       [default]
129 3 equemene
# -DStringStructPtr   : The address  of  a  structure  is  passed  by  a
130 3 equemene
#                       Fortran 77  string,  and the structure is of the
131 3 equemene
#                       form: struct {char *cp; F77_INTEGER len;},
132 3 equemene
# -DStringStructVal   : A structure is passed by value for each  Fortran
133 3 equemene
#                       77 string,  and  the  structure is  of the form:
134 3 equemene
#                       struct {char *cp; F77_INTEGER len;},
135 3 equemene
# -DStringCrayStyle   : Special option for  Cray  machines,  which  uses
136 3 equemene
#                       Cray  fcd  (fortran  character  descriptor)  for
137 3 equemene
#                       interoperation.
138 3 equemene
#
139 3 equemene
F2CDEFS      =
140 3 equemene
#
141 3 equemene
# ----------------------------------------------------------------------
142 3 equemene
# - HPL includes / libraries / specifics -------------------------------
143 3 equemene
# ----------------------------------------------------------------------
144 3 equemene
#
145 3 equemene
HPL_INCLUDES = -I$(INCdir) -I$(INCdir)/$(ARCH) $(LAinc) $(MPinc)
146 3 equemene
HPL_LIBS     = $(HPLlib) $(LAlib) $(MPlib)
147 3 equemene
#
148 3 equemene
# - Compile time options -----------------------------------------------
149 3 equemene
#
150 3 equemene
# -DHPL_COPY_L           force the copy of the panel L before bcast;
151 3 equemene
# -DHPL_CALL_CBLAS       call the cblas interface;
152 3 equemene
# -DHPL_CALL_VSIPL       call the vsip  library;
153 3 equemene
# -DHPL_DETAILED_TIMING  enable detailed timers;
154 3 equemene
#
155 3 equemene
# By default HPL will:
156 3 equemene
#    *) not copy L before broadcast,
157 3 equemene
#    *) call the BLAS Fortran 77 interface,
158 3 equemene
#    *) not display detailed timing information.
159 3 equemene
#
160 3 equemene
HPL_OPTS     =
161 3 equemene
#
162 3 equemene
# ----------------------------------------------------------------------
163 3 equemene
#
164 3 equemene
HPL_DEFS     = $(F2CDEFS) $(HPL_OPTS) $(HPL_INCLUDES)
165 3 equemene
#
166 3 equemene
# ----------------------------------------------------------------------
167 3 equemene
# - Compilers / linkers - Optimization flags ---------------------------
168 3 equemene
# ----------------------------------------------------------------------
169 3 equemene
#
170 3 equemene
CC           = /usr/bin/mpicc.openmpi
171 3 equemene
CCNOOPT      = $(HPL_DEFS)
172 3 equemene
CCFLAGS      = $(HPL_DEFS) -fomit-frame-pointer -O3 -funroll-loops -W -Wall
173 3 equemene
#
174 3 equemene
# On some platforms,  it is necessary  to use the Fortran linker to find
175 3 equemene
# the Fortran internals used in the BLAS library.
176 3 equemene
#
177 5 equemene
LINKER       = /usr/bin/mpif77.openmpi
178 3 equemene
LINKFLAGS    = $(CCFLAGS)
179 3 equemene
#
180 3 equemene
ARCHIVER     = ar
181 3 equemene
ARFLAGS      = r
182 3 equemene
RANLIB       = echo
183 3 equemene
#
184 3 equemene
# ----------------------------------------------------------------------