#! /usr/bin/env bash
#
#  $Header: /u/gcmpack/MITgcm/tools/build_options/linux_amd64_pathf90,v 1.13 2014/07/23 22:54:51 jmc Exp $
#  $Name:  $
#
# Build options for PathScale (EKOPATH) Compiler on Linux x86-64
#  first version tested on Fedore Core 3 x86-64 Opteron (Linux batsi)
#  updated and tested on acesgrid (Fedora Core 15), using:
#     module load ekopath	(Version 4.0.10)
# Also tested with MPI on acesgrid, using:
#     module load ekopath	(Version 4.0.10)
#   and with mpich1:
#     module load mvapich
#   or  with mpich2:
#     module load mvapich2
#   or  with openmpi:
#     module load openmpi

#-------
# run with OpenMP: needs to set environment var. OMP_NUM_THREADS
#    and generally, needs to increase the thread stack-size:
#   -  sh,bash:
#     > export OMP_NUM_THREADS=2
#     > export PSC_OMP_STACK_SIZE=400m
#   - csh,tcsh:
#     > setenv OMP_NUM_THREADS 2
#     > setenv PSC_OMP_STACK_SIZE 400m
#-------

if test "x$MPI" = xtrue ; then
  CC=mpicc
  FC=mpif90
  LINK=mpif90
else
  CC=pathcc
  FC=pathf90
  LINK=pathf90
fi

DEFINES='-DWORDLENGTH=4'
EXTENDED_SRC_FLAG='-extend-source'
GET_FC_VERSION="--version"
OMPFLAG='-openmp'
#OMPFLAG='-openmp -OPT:early_mp=ON'

NOOPTFLAGS='-O0 -g'
NOOPTFILES=''

CFLAGS='-O0 -m64'
FFLAGS="$FFLAGS -m64 -convert big_endian"

#- for big setups, compile & link with "-fPIC" or set memory-model to "medium":
 CFLAGS="$CFLAGS -fPIC"
 FFLAGS="$FFLAGS -fPIC"
#-  with FC 19, need to use this without -fPIC (which cancels -mcmodel option):
#CFLAGS="$CFLAGS -mcmodel=medium"
#FFLAGS="$FFLAGS -mcmodel=medium"
#- might want to use '-r8' for fizhi pkg:
#FFLAGS="$FFLAGS -r8"

if test "x$IEEE" = x ; then     #- with optimisation:
   #- full optimisation, trips over MITgcm code because of compiler problems:
   #FOPTIM='-Ofast -LNO:fusion=2 -funsafe-math-optimizations'
   #- high optimisation (-O3 & (loop)fusion=2), might find Pb with few S/R:
   #FOPTIM='-O3 -LNO:fusion=2 -funsafe-math-optimizations'
   #FOPTIM='-O3 -funsafe-math-optimizations'
   #- fully safe: switch to -O2 without (loop)fusion=2 (to fix some restart Pb):
    FOPTIM='-O2 -funsafe-math-optimizations'
    NOOPTFILES="$NOOPTFILES exf_interpolate.F"
   #- multi-threaded: mon_set_iounit.F needs lower optimisation (lower than -02)
    NOOPTFILES="$NOOPTFILES mon_set_iounit.F"
    NOOPTFLAGS='-O1'
else
  if test "x$DEVEL" = x ; then  #- no optimisation + IEEE :
    FOPTIM='-O0 -OPT:roundoff=0:IEEE_arithmetic=1 -fmath-errno -fno-fast-math'
  else                          #- development/check options:
    FFLAGS="$FFLAGS -ffortran-bounds-check -trapuv -g"
    FOPTIM='-O0 -OPT:roundoff=0:IEEE_arithmetic=1 -fmath-errno -fno-fast-math'
  fi
fi

F90FLAGS=$FFLAGS
F90OPTIM=$FOPTIM
GSLLIB='-lgsl -lgslcblas'

INCLUDEDIRS=''
INCLUDES=''
LIBS=''

if [ "x$NETCDF_ROOT" != x ] ; then
    INCLUDEDIR="${NETCDF_ROOT}/include"
    INCLUDES="-I${NETCDF_ROOT}/include"
    LIBDIR="${NETCDF_ROOT}/lib"
    LIBS="-L${NETCDF_ROOT}/lib"
elif [ "x$NETCDF_HOME" != x ]; then
    INCLUDEDIR="${NETCDF_HOME}/include"
    INCLUDES="-I${NETCDF_HOME}/include"
    LIBDIR="${NETCDF_HOME}/lib"
    LIBS="-L${NETCDF_HOME}/lib"
elif [ "x$NETCDF_INC" != x -a "x$NETCDF_LIB" != x ]; then
    NETCDF_INC=`echo $NETCDF_INC | sed 's/-I//g'`
    NETCDF_LIB=`echo $NETCDF_LIB | sed 's/-L//g'`
    INCLUDEDIR="${NETCDF_INC}"
    INCLUDES="-I${NETCDF_INC}"
    LIBDIR="${NETCDF_LIB}"
    LIBS="-L${NETCDF_LIB}"
elif [ "x$NETCDF_INCDIR" != x -a "x$NETCDF_LIBDIR" != x ]; then
    INCLUDEDIR="${NETCDF_INCDIR}"
    INCLUDES="-I${NETCDF_INCDIR}"
    LIBDIR="${NETCDF_LIBDIR}"
    LIBS="-L${NETCDF_LIBDIR}"
elif test -d /usr/include/netcdf-3 ; then
    INCLUDES='-I/usr/include/netcdf-3'
    LIBS='-L/usr/lib/netcdf-3 -L/usr/lib64/netcdf-3'
elif test -d /usr/include/netcdf ; then
    INCLUDES='-I/usr/include/netcdf'
elif test -d /usr/local/netcdf ; then
    INCLUDES='-I/usr/local/netcdf/include'
    LIBS='-L/usr/local/netcdf/lib'
elif test -d /usr/local/include/netcdf.inc ; then
    INCLUDES='-I/usr/local/include'
    LIBS='-L/usr/local/lib64'
fi

if [ -n "$MPI_INC_DIR" -a "x$MPI" = xtrue ] ; then
    INCLUDES="$INCLUDES -I$MPI_INC_DIR"
    INCLUDEDIRS="$INCLUDEDIRS $MPI_INC_DIR"
    #- used for parallel (MPI) DIVA
    MPIINCLUDEDIR="$MPI_INC_DIR"
   #MPI_HEADER_FILES='mpif.h mpiof.h'
fi