--- MITgcm/tools/genmake 2001/07/13 15:16:48 1.38 +++ MITgcm/tools/genmake 2001/09/05 20:28:26 1.49 @@ -1,6 +1,6 @@ #!/bin/csh -f # -# $Header: /home/ubuntu/mnt/e9_copy/MITgcm/tools/Attic/genmake,v 1.38 2001/07/13 15:16:48 heimbach Exp $ +# $Header: /home/ubuntu/mnt/e9_copy/MITgcm/tools/Attic/genmake,v 1.49 2001/09/05 20:28:26 adcroft Exp $ # $Name: $ # # Makefile generator for MITgcm UV codes @@ -10,6 +10,7 @@ # Default lists set DISABLE = ( aim autodiff cal cost ctrl ecco exf grdchk ) +set DEFINES = ( ) set ENABLE = ( ) set MODS = ( ) @@ -77,6 +78,9 @@ echo "-enable overrides -disable, ie. a package listed in both is enabled" exit breaksw + case -ieee: + set IEEE + breaksw case -enable=*: set ENABLE = ( $ENABLE `echo $arg | sed 's/-enable=//' | sed 's/,/ /g' `) breaksw @@ -168,10 +172,10 @@ # source code in the standard directories if (! $?MODS) then set SOURCEDIRS = ( ) - set INCLUDEDIRS = ( . ) + set INCLUDEDIRS = ( ) else set SOURCEDIRS = ( $MODS ) - set INCLUDEDIRS = ( . $MODS ) + set INCLUDEDIRS = ( $MODS ) endif if (! $?BUILDDIR) set BUILDDIR = ( . ) if (! -d $BUILDDIR) then @@ -250,6 +254,14 @@ set INCLUDEDIRS = ($INCLUDEDIRS $adr) else echo " *" Package \"$dr\" NOT enabled. + switch ($dr) + case mom_fluxform: + set DEFINES = ($DEFINES '-DDISABLE_MOM_FLUXFORM'); breaksw + case mom_vecinv: + set DEFINES = ($DEFINES '-DDISABLE_MOM_MOMVECINV'); breaksw + default: + breaksw + endsw endif end if (! $?STANDARDDIRS) set STANDARDDIRS=(eesupp model) @@ -271,8 +283,7 @@ set KPP = ( ) set FC = ( 'f77' ) set LINK = ( 'f77' ) -set DEFINES = ( ) -set INCLUDES = ( ) +set INCLUDES = ( -I. ) set FFLAGS = ( ) set FOPTIM = ( ) set KFLAGS1 = ( ) @@ -294,19 +305,20 @@ # Platform specific options switch ($platform$USEMPI) - case OSF1: case OSF1+mpi: + echo "Configuring for DEC Alpha with MPI" + set LIBS = ( '-lfmpi -lmpi -lkmp_osfp10 -pthread' ) + case OSF1: echo "Configuring for DEC Alpha" set CPP = ( '/usr/bin/cpp -P' ) set DEFINES = ( ${DEFINES} '-DTARGET_DEC -DWORDLENGTH=1' ) - set KPP = ( 'kapf' ) - set KPPFILES = ( 'main.F' ) - set KFLAGS1 = ( '-scan=132 -noconc -cmp=' ) + set KPP = ( ) + set KPPFILES = ( ) + set KFLAGS1 = ( ) set FC = ( 'f77' ) set FFLAGS = ( '-convert big_endian -r8 -extend_source -automatic -call_shared -notransform_loops -align dcommons' ) set FOPTIM = ( '-O5 -fast -tune host -inline all' ) set NOOPTFLAGS = ( '-O0' ) - set LIBS = ( '-lfmpi -lmpi -lkmp_osfp10 -pthread' ) set NOOPTFILES = ( 'barrier.F different_multiple.F external_fields_load.F') set RMFILES = ( '*.p.out' ) breaksw @@ -374,9 +386,9 @@ set CPP = ( '/usr/ccs/lib/cpp -P' ) set DEFINES = ( ${DEFINES} '-DTARGET_SUN -DWORDLENGTH=4' ) set FFLAGS = ( '-stackvar -explicitpar -vpara -e -u -noautopar') - set FOPTIM = ( '-fast -O3' ) + set FOPTIM = ( '-dalign -O3' ) set NOOPTFLAGS = ( '-O0' ) - set NOOPTFILES = ( 'barrier.F different_multiple.F external_fields_load.F ini_vertical_grid.F ini_spherical_polar_grid.F ini_cori.F') + set NOOPTFILES = ( 'barrier.F different_multiple.F external_fields_load.F ini_vertical_grid.F ini_spherical_polar_grid.F ini_cori.F mon_printstats_rl.F mon_printstats_rs.F') breaksw case SunOS+mpi: set LN = ( '/usr/bin/ln -s' ) @@ -384,11 +396,11 @@ set DEFINES = ( ${DEFINES} '-DTARGET_SUN -DWORDLENGTH=4' ) set INCLUDES = ( '-I/usr/local/mpi/include' ) set FFLAGS = ( '-stackvar -explicitpar -vpara -e -u -noautopar') - set FOPTIM = ( '-fast -O3' ) + set FOPTIM = ( '-dalign -O3' ) set NOOPTFLAGS = ( '-O0' ) set LIBS = ( '-L/usr/local/mpi/lib/solaris/ch_shmem -lmpi -lthread' \ '-lsocket -lnsl' ) - set NOOPTFILES = ( 'barrier.F different_multiple.F external_fields_load.F ini_vertical_grid.F ini_spherical_polar_grid.F ini_cori.F') + set NOOPTFILES = ( 'barrier.F different_multiple.F external_fields_load.F ini_vertical_grid.F ini_spherical_polar_grid.F ini_cori.F mon_printstats_rl.F mon_printstats_rs.F') breaksw case IRIX32: echo "Configuring for SGI ONYX running IRIX64" @@ -425,7 +437,8 @@ set DEFINES = ( ${DEFINES} '-D_BYTESWAPIO -DWORDLENGTH=4' ) set FC = ( 'g77' ) set FFLAGS = ( '-Wimplicit -Wunused -Wuninitialized' ) - set FOPTIM = ( '-O3 -malign-double -funroll-loops ' ) + if ($?IEEE) set FFLAGS = ( $FFLAGS '-ffloat-store' ) + set FOPTIM = ( '-O3 -malign-double -funroll-loops' ) set LINK = ( 'g77' ) breaksw case Linux+pgi+mpi: @@ -501,8 +514,8 @@ echo "" >> srclinks.tmp echo -n 'SRCFILES = ' > srclist.inc echo -n 'CSRCFILES = ' > csrclist.inc -#echo -n 'HEADERFILES = ' > hlist.inc -foreach dr ($SOURCEDIRS) +echo -n 'HEADERFILES = ' > hlist.inc +foreach dr ($SOURCEDIRS $INCLUDEDIRS .) set deplist=( ) foreach srcfile (`cd $dr; ls *.[hcF]`) if (! -r .links.tmp/$srcfile) then @@ -521,10 +534,10 @@ echo -n " " $srcfile >> csrclist.inc breaksw case h: -# touch .links.tmp/$srcfile -# set deplist=($deplist $srcfile) -# echo ' \' >> hlist.inc -# echo -n " " $srcfile >> hlist.inc + touch .links.tmp/$srcfile + set deplist=($deplist $srcfile) + echo ' \' >> hlist.inc + echo -n " " $srcfile >> hlist.inc breaksw endsw endif @@ -539,7 +552,7 @@ rm -rf .links.tmp echo "" >> srclist.inc echo "" >> csrclist.inc -#echo "" >> hlist.inc +echo "" >> hlist.inc set THISHOSTNAME = ( `hostname` ) set THISCWD = ( `pwd` ) @@ -653,10 +666,11 @@ cat srclist.inc >> ${mfile} cat csrclist.inc >> ${mfile} +cat hlist.inc >> ${mfile} echo 'F77FILES = $(SRCFILES:.F=.f)' >> ${mfile} echo 'OBJFILES = $(SRCFILES:.F=.o) $(CSRCFILES:.c=.o)' >> ${mfile} -rm -f srclist.inc csrclist.inc flist.tmp clist.tmp +rm -f srclist.inc csrclist.inc hlist.inc flist.tmp clist.tmp cat >> ${mfile} < \$@ + clean: -rm -rf *.o *.f *.p ${RMFILES} Clean: