/[MITgcm]/MITgcm/tools/build_options/linux_amd64_ifort+mpi_loc
ViewVC logotype

Contents of /MITgcm/tools/build_options/linux_amd64_ifort+mpi_loc

Parent Directory Parent Directory | Revision Log Revision Log | View Revision Graph Revision Graph


Revision 1.7 - (show annotations) (download)
Tue Apr 20 20:13:27 2010 UTC (14 years, 1 month ago) by jmc
Branch: MAIN
CVS Tags: checkpoint62g, checkpoint62f, checkpoint62k, checkpoint62j, checkpoint62i, checkpoint62h, checkpoint62o, checkpoint62n, checkpoint62m, checkpoint62l
Changes since 1.6: +3 -2 lines
remove "-fPIC" from NOOPTFLAGS (already in FFLAGS, no need to be there twice)
as an example, put ad_taf_output.f in NOOPTFILES list (only when using -ieee)

1 #!/bin/bash
2 #
3 # $Header: /u/gcmpack/MITgcm/tools/build_options/linux_amd64_ifort+mpi_loc,v 1.6 2010/03/19 22:04:53 jmc Exp $
4 # $Name: $
5
6 # Adapted from linux_amd64_ifort_generic_mpi
7 # with specific local path (=MPI_INC_DIR & NETCDF_ROOT ) for MPI & NetCDF
8 # Tested on jmc's laptop with MPI & Multi-Threaded
9 # using intel compiler v.10.1.012 & mpich-1.2.7 (FC.8)
10 # v.11.1.046 & mpich-1.2.7 (FC.11)
11 # (intel compiler, mpich & netcdf installed in /opt/intel/ )
12
13 #-------
14 # run with OpenMP: needs to set environment var. OMP_NUM_THREADS
15 # and generally, needs to increase the stack-size:
16 # - sh,bash:
17 # > export OMP_NUM_THREADS=2
18 # > export KMP_STACKSIZE=400m
19 # - csh,tcsh:
20 # > setenv OMP_NUM_THREADS 2
21 # > setenv KMP_STACKSIZE 400m
22 # NOTE: need to set KMP_STACKSIZE in ~/.tcshrc (but curiously, works
23 # without OMP_NUM_THREADS in ~/.tcshrc).
24 #-------
25
26 # Composed and tested by ce107 on ross/weddell (Opteron system)
27 # Should work fine on EM64T and other AMD64 compatible Intel systems
28 # a) Processor specific flags:
29 # 1) for more speed on Core2 processors replace -xW with -xT
30 # 2) for more speed on Pentium4 based EM64T processors replaces -xW with -xP
31 # b) For more speed, provided your data size doesn't exceed 2GB you can
32 # remove -fPIC which carries a performance penalty of 2-6%.
33 # c) Provided that the libraries you link to are compiled with -fPIC this
34 # optfile should work.
35 # d) You can replace -fPIC with -mcmodel=medium which may perform faster
36 # than -fPIC and still support data sizes over 2GB per process but all
37 # the libraries you link to must be compiled with -fPIC or -mcmodel=medium
38 # e) Changed from -O3 to -O2 to avoid buggy Intel v.10 compilers. Speed
39 # impact appears to be minimal.
40 #
41 # DON'T FORGET to set environment variable MPI_INC_DIR to the include
42 # directory of your MPI implementation
43
44 NETCDF_ROOT='/opt/intel/netcdf-4.0.1/11.1'
45 MPI_INC_DIR='/opt/intel/mpich-1.2.7p1_ic-11.1.046/include'
46
47 FC=mpif77
48 F90C='mpif90 -fixed'
49 CC=mpicc
50 LINK='mpif90 -i-dynamic -no-ipo'
51 #LINK='mpif90 -i-static -no-ipo'
52
53 DEFINES='-DALLOW_USE_MPI -DALWAYS_USE_MPI -DWORDLENGTH=4'
54 CPP='cpp -traditional -P'
55 F90FIXEDFORMAT='-fixed -Tf'
56 EXTENDED_SRC_FLAG='-132'
57 OMPFLAG='-openmp'
58
59 NOOPTFLAGS='-O0 -g'
60 NOOPTFILES=''
61
62 INCLUDEDIRS=''
63 INCLUDES=''
64 LIBS=''
65
66 if test "x$DEVEL" != x ; then
67 FFLAGS="$FFLAGS -w95 -W0 -WB -convert big_endian -assume byterecl -fPIC -O0 -g -noalign -fp-stack-check -check all -fpe0 -traceback -ftrapuv -fp-model except -warn all"
68 else
69 FFLAGS="$FFLAGS -w95 -W0 -WB -convert big_endian -assume byterecl -fPIC"
70 fi
71 #- might want to use '-r8' for fizhi pkg:
72 #FFLAGS="$FFLAGS -r8"
73
74 if test "x$IEEE" = x ; then
75 # No need for IEEE-754
76 FOPTIM='-O2 -align -xW -ip'
77 else
78 # Try to follow IEEE-754
79 FOPTIM='-O0 -xW -ip -fp-model strict'
80 # for automatic testing with testreport (but no relation with IEEE arithmetic):
81 FOPTIM="$FOPTIM -fpe0 -ftz -fp-stack-check -check all -ftrapuv"
82 FOPTIM="$FOPTIM -noalign -g -traceback"
83 NOOPTFILES='ad_taf_output.f'
84 fi
85 F90FLAGS=$FFLAGS
86 F90OPTIM=$FOPTIM
87 CFLAGS='-O0 -ip -fPIC'
88
89 if [ "x$NETCDF_ROOT" != x ] ; then
90 INCLUDEDIRS="${NETCDF_ROOT}/include"
91 INCLUDES="-I${NETCDF_ROOT}/include"
92 LIBS="-L${NETCDF_ROOT}/lib"
93 elif [ "x$NETCDF_HOME" != x ]; then
94 INCLUDEDIRS="${NETCDF_HOME}/include"
95 INCLUDES="-I${NETCDF_HOME}/include"
96 LIBS="-L${NETCDF_HOME}/lib"
97 elif [ "x$NETCDF_INC" != x -a "x$NETCDF_LIB" != x ]; then
98 NETCDF_INC=`echo $NETCDF_INC | sed 's/-I//g'`
99 NETCDF_LIB=`echo $NETCDF_LIB | sed 's/-L//g'`
100 INCLUDEDIRS="${NETCDF_INC}"
101 INCLUDES="-I${NETCDF_INC}"
102 LIBS="-L${NETCDF_LIB}"
103 elif [ "x$NETCDF_INCDIR" != x -a "x$NETCDF_LIBDIR" != x ]; then
104 INCLUDEDIRS="${NETCDF_INCDIR}"
105 INCLUDES="-I${NETCDF_INCDIR}"
106 LIBS="-L${NETCDF_LIBDIR}"
107 elif test -d /usr/include/netcdf-3 ; then
108 INCLUDEDIRS='/usr/include/netcdf-3'
109 INCLUDES='-I/usr/include/netcdf-3'
110 LIBS='-L/usr/lib/netcdf-3 -L/usr/lib64/netcdf-3'
111 elif test -d /usr/include/netcdf ; then
112 INCLUDEDIRS='/usr/include/netcdf'
113 INCLUDES='-I/usr/include/netcdf'
114 elif test -d /usr/local/netcdf ; then
115 INCLUDEDIRS='/usr/include/netcdf/include'
116 INCLUDES='-I/usr/local/netcdf/include'
117 LIBS='-L/usr/local/netcdf/lib'
118 elif test -d /usr/local/include/netcdf.inc ; then
119 INCLUDEDIRS='/usr/local/include'
120 INCLUDES='-I/usr/local/include'
121 LIBS='-L/usr/local/lib64'
122 fi
123
124 INCLUDES="$INCLUDES -I$MPI_INC_DIR"
125 INCLUDEDIRS="$INCLUDEDIRS $MPI_INC_DIR"
126 MPIINCLUDEDIR="$MPI_INC_DIR"
127 MPI_HEADER_FILES='mpif.h mpiof.h'
128 MPI_HEADER_FILES_INC='./mpi_headers/mpif.h ./mpi_headers/mpiof.h'

  ViewVC Help
Powered by ViewVC 1.1.22