1 |
ce107 |
1.1 |
#!/bin/bash |
2 |
|
|
# |
3 |
jmc |
1.2 |
# $Header: $ |
4 |
|
|
# $Name: $ |
5 |
|
|
# |
6 |
ce107 |
1.1 |
# Constantinos Evangelinos |
7 |
|
|
# |
8 |
|
|
# Build options for the intel 10.1 fortran compiler |
9 |
|
|
|
10 |
jmc |
1.2 |
#------- |
11 |
|
|
# run with OpenMP: needs to set environment var. OMP_NUM_THREADS |
12 |
|
|
# and generally, needs to increase the stack-size: |
13 |
|
|
# - sh,bash: |
14 |
|
|
# > export OMP_NUM_THREADS=2 |
15 |
|
|
# > export KMP_STACKSIZE=400m |
16 |
|
|
# - csh,tcsh: |
17 |
|
|
# > setenv OMP_NUM_THREADS 2 |
18 |
|
|
# > setenv KMP_STACKSIZE 400m |
19 |
|
|
#------- |
20 |
|
|
|
21 |
ce107 |
1.1 |
FC=ifort |
22 |
|
|
F90C=ifort |
23 |
|
|
CC=icc |
24 |
|
|
LINK=ifort |
25 |
|
|
|
26 |
|
|
DEFINES='-DWORDLENGTH=4' |
27 |
|
|
CPP='cpp -traditional -P' |
28 |
jmc |
1.2 |
F90FIXEDFORMAT='-fixed -Tf' |
29 |
ce107 |
1.1 |
EXTENDED_SRC_FLAG='-132' |
30 |
jmc |
1.2 |
OMPFLAG='-openmp' |
31 |
ce107 |
1.1 |
|
32 |
|
|
NOOPTFLAGS='-O0 -g' |
33 |
|
|
NOOPTFILES='' |
34 |
|
|
|
35 |
|
|
INCLUDEDIRS='' |
36 |
|
|
INCLUDES='' |
37 |
|
|
LIBS='' |
38 |
|
|
|
39 |
|
|
if test "x$DEVEL" != x ; then |
40 |
jmc |
1.2 |
FFLAGS='-convert big_endian -assume byterecl -O0 -g -debug all -debug-parameters all -noalign -fp-stack-check -check all -fpe0 -traceback -ftrapuv -fp-model strict -warn all' |
41 |
ce107 |
1.1 |
else |
42 |
jmc |
1.2 |
FFLAGS='-W0 -WB -convert big_endian -assume byterecl' |
43 |
ce107 |
1.1 |
fi |
44 |
jmc |
1.2 |
#- might want to use '-r8' for fizhi pkg: |
45 |
|
|
#FFLAGS="$FFLAGS -r8" |
46 |
ce107 |
1.1 |
|
47 |
|
|
if test "x$GENERIC" != x ; then |
48 |
|
|
PROCF=-axSOTPNWK |
49 |
|
|
else |
50 |
|
|
has_sse4a=f |
51 |
|
|
has_sse4=f |
52 |
|
|
has_ssse3=f |
53 |
|
|
has_sse3=f |
54 |
|
|
has_sse2=f |
55 |
|
|
has_sse=f |
56 |
|
|
is_opteron=f |
57 |
|
|
is_pentiumm=f |
58 |
|
|
grep flags /proc/cpuinfo | grep " sse4a " > /dev/null 2>&1 && has_sse4a=t |
59 |
|
|
grep flags /proc/cpuinfo | grep " sse4 " > /dev/null 2>&1 && has_sse4=t |
60 |
|
|
grep flags /proc/cpuinfo | grep " sse3 " > /dev/null 2>&1 && has_ssse3=t |
61 |
|
|
grep flags /proc/cpuinfo | grep " sse3 " > /dev/null 2>&1 && has_sse3=t |
62 |
|
|
grep flags /proc/cpuinfo | grep " sse2 " > /dev/null 2>&1 && has_sse2=t |
63 |
|
|
grep flags /proc/cpuinfo | grep " sse " > /dev/null 2>&1 && has_sse=t |
64 |
|
|
grep "model name" /proc/cpuinfo | grep " Opteron" > /dev/null 2>&1 && is_opteron=t |
65 |
|
|
grep "model name" /proc/cpuinfo | grep " Phenom" > /dev/null 2>&1 && is_opteron=t |
66 |
|
|
grep "model name" /proc/cpuinfo | grep " Athlon 64" > /dev/null 2>&1 && is_opteron=t |
67 |
|
|
grep "model name" /proc/cpuinfo | grep " Pentium(R) M" > /dev/null 2>&1 && is_pentiumm=t |
68 |
|
|
if test "x$has_sse4a" = xt ; then |
69 |
|
|
PROCF=-xO |
70 |
|
|
elif test "x$has_sse4" = xt ; then |
71 |
|
|
PROCF=-xS |
72 |
|
|
elif test "x$has_ssse3" = xt ; then |
73 |
|
|
PROCF=-xT |
74 |
|
|
elif test "x$has_sse3" = xt ; then |
75 |
|
|
if test "x$is_opteron" = xt ; then |
76 |
|
|
PROCF=-xO |
77 |
|
|
else |
78 |
|
|
PROCF=-xP |
79 |
|
|
fi |
80 |
|
|
elif test "x$has_sse2" = xt ; then |
81 |
|
|
if test "x$is_pentiumm" = xt ; then |
82 |
|
|
PROCF=-xB |
83 |
|
|
elif test "x$is_opteron" = xt ; then |
84 |
|
|
PROCF=-xW |
85 |
|
|
else |
86 |
|
|
PROCF=-xN |
87 |
|
|
fi |
88 |
|
|
elif test "x$has_sse" = xt ; then |
89 |
|
|
PROCF=-xK |
90 |
|
|
fi |
91 |
|
|
fi |
92 |
|
|
# Note that the -mp switch is for ieee "maintain precision" and is |
93 |
|
|
# roughly equivalent to -ieee |
94 |
|
|
if test "x$IEEE" = x ; then |
95 |
|
|
FOPTIM="-O3 -align -ip -opt-streaming-stores auto $PROCF" |
96 |
|
|
else |
97 |
|
|
if test "x$DEVEL" != x ; then |
98 |
|
|
FOPTIM="$PROCF" |
99 |
|
|
else |
100 |
|
|
FOPTIM="-O0 -mp -noalign $PROCF" |
101 |
|
|
fi |
102 |
|
|
fi |
103 |
|
|
F90FLAGS=$FFLAGS |
104 |
|
|
F90OPTIM=$FOPTIM |
105 |
|
|
CFLAGS="-O2 -ip $PROCF" |
106 |
|
|
|
107 |
|
|
if [ "x$NETCDF_ROOT" != x ] ; then |
108 |
|
|
INCLUDEDIRS="${NETCDF_ROOT}/include" |
109 |
|
|
INCLUDES="-I${NETCDF_ROOT}/include" |
110 |
|
|
LIBS="-L${NETCDF_ROOT}/lib" |
111 |
|
|
elif [ "x$NETCDF_HOME" != x ]; then |
112 |
|
|
INCLUDEDIRS="${NETCDF_HOME}/include" |
113 |
|
|
INCLUDES="-I${NETCDF_HOME}/include" |
114 |
|
|
LIBS="-L${NETCDF_HOME}/lib" |
115 |
|
|
elif [ "x$NETCDF_INC" != x -a "x$NETCDF_LIB" != x ]; then |
116 |
|
|
NETCDF_INC=`echo $NETCDF_INC | sed 's/-I//g'` |
117 |
|
|
NETCDF_LIB=`echo $NETCDF_LIB | sed 's/-L//g'` |
118 |
|
|
INCLUDEDIRS="${NETCDF_INC}" |
119 |
|
|
INCLUDES="-I${NETCDF_INC}" |
120 |
|
|
LIBS="-L${NETCDF_LIB}" |
121 |
|
|
elif [ "x$NETCDF_INCDIR" != x -a "x$NETCDF_LIBDIR" != x ]; then |
122 |
|
|
INCLUDEDIRS="${NETCDF_INCDIR}" |
123 |
|
|
INCLUDES="-I${NETCDF_INCDIR}" |
124 |
|
|
LIBS="-L${NETCDF_LIBDIR}" |
125 |
|
|
elif test -d /usr/include/netcdf-3 ; then |
126 |
|
|
INCLUDEDIRS='/usr/include/netcdf-3' |
127 |
|
|
INCLUDES='-I/usr/include/netcdf-3' |
128 |
|
|
LIBS='-L/usr/lib/netcdf-3' |
129 |
|
|
elif test -d /usr/local/pkg/netcdf ; then |
130 |
|
|
INCLUDEDIRS='/usr/local/pkg/netcdf/include' |
131 |
|
|
INCLUDES='-I/usr/local/pkg/netcdf/include' |
132 |
|
|
LIBS='-L/usr/local/pkg/netcdf/lib' |
133 |
|
|
elif test -d /usr/include/netcdf ; then |
134 |
|
|
INCLUDEDIRS='/usr/include/netcdf' |
135 |
|
|
INCLUDES='-I/usr/include/netcdf' |
136 |
|
|
elif test -d /usr/local/netcdf ; then |
137 |
|
|
INCLUDEDIRS='/usr/include/netcdf/include' |
138 |
|
|
INCLUDES='-I/usr/local/netcdf/include' |
139 |
|
|
LIBS='-L/usr/local/netcdf/lib' |
140 |
|
|
elif test -f /usr/local/include/netcdf.inc ; then |
141 |
|
|
INCLUDEDIRS='/usr/local/include' |
142 |
|
|
INCLUDES='-I/usr/local/include' |
143 |
|
|
LIBS='-L/usr/local/lib' |
144 |
|
|
fi |
145 |
|
|
|