--- MITgcm/tools/genmake 2001/08/23 19:33:44 1.47 +++ MITgcm/tools/genmake 2002/02/15 21:26:37 1.61 @@ -1,6 +1,6 @@ #!/bin/csh -f # -# $Header: /home/ubuntu/mnt/e9_copy/MITgcm/tools/Attic/genmake,v 1.47 2001/08/23 19:33:44 heimbach Exp $ +# $Header: /home/ubuntu/mnt/e9_copy/MITgcm/tools/Attic/genmake,v 1.61 2002/02/15 21:26:37 heimbach Exp $ # $Name: $ # # Makefile generator for MITgcm UV codes @@ -9,7 +9,7 @@ # modified by aja 01/00 # Default lists -set DISABLE = ( aim autodiff cal cost ctrl ecco exf grdchk ) +set DISABLE = ( aim autodiff cal cost ctrl ecco exf grdchk flt ) set DEFINES = ( ) set ENABLE = ( ) set MODS = ( ) @@ -133,6 +133,11 @@ # If platform wasn't specified then determine platform type of the host if (! $?platform) then set platform = (`uname`) +# This let's us distinguish between different Linux platforms + if ($platform == Linux) then + set machine = (`uname -m`) + set platform = ($platform'-'$machine) + endif endif # If name of makefile wasn't specified then use default "Makefile" if (! $?mfile) set mfile = ( Makefile ) @@ -258,7 +263,9 @@ case mom_fluxform: set DEFINES = ($DEFINES '-DDISABLE_MOM_FLUXFORM'); breaksw case mom_vecinv: - set DEFINES = ($DEFINES '-DDISABLE_MOM_MOMVECINV'); breaksw + set DEFINES = ($DEFINES '-DDISABLE_MOM_VECINV'); breaksw + case generic_advdiff: + set DEFINES = ($DEFINES '-DDISABLE_GENERIC_ADVDIFF'); breaksw default: breaksw endsw @@ -280,12 +287,15 @@ # Platform specific options are chosen below set LN = ( 'ln -s' ) set CPP = ( '/lib/cpp -P' ) +set S64 = ( '$(TOOLSDIR)/set64bitConst.sh' ) set KPP = ( ) set FC = ( 'f77' ) set LINK = ( 'f77' ) +set MAKEDEPEND = ( 'makedepend' ) set INCLUDES = ( -I. ) set FFLAGS = ( ) set FOPTIM = ( ) +set CFLAGS = ( ) set KFLAGS1 = ( ) set KFLAGS2 = ( ) set LIBS = ( ) @@ -384,21 +394,23 @@ case SunOS: set LN = ( '/usr/bin/ln -s' ) 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 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 mon_printstats_rl.F mon_printstats_rs.F') + set MAKEDEPEND = ( ${TOOLSDIR}/xmakedepend ) + set DEFINES = ( ${DEFINES} '-DTARGET_SUN -DWORDLENGTH=4 -D_d=E' ) + set FFLAGS = ( '-stackvar -explicitpar -vpara -e -u -noautopar -xtypemap=real:64,double:64,integer:32 -fsimple=0' ) + set FOPTIM = ( '-dalign -O3 -xarch=v9' ) + set CFLAGS = ( '-dalign -O3 -xarch=v9' ) + set NOOPTFLAGS = ( '-dalign -O0 -xarch=v9' ) + 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 aim_aim2dyn.F aim_dyn2aim.F aim_aim2dyn_exchanges.F aim_external_fields_load.F aim_calc_diags.F aim_external_forcing.F aim_do_atmos_physics.F aim_write_diags.F aim_do_inphys.F ') breaksw case SunOS+mpi: set LN = ( '/usr/bin/ln -s' ) set CPP = ( '/usr/ccs/lib/cpp -P' ) - set DEFINES = ( ${DEFINES} '-DTARGET_SUN -DWORDLENGTH=4' ) + set DEFINES = ( ${DEFINES} '-DTARGET_SUN -DWORDLENGTH=4 -D_d=E' ) set INCLUDES = ( '-I/usr/local/mpi/include' ) - set FFLAGS = ( '-stackvar -explicitpar -vpara -e -u -noautopar') - set FOPTIM = ( '-fast -O3' ) - set NOOPTFLAGS = ( '-O0' ) set LIBS = ( '-L/usr/local/mpi/lib/solaris/ch_shmem -lmpi -lthread' \ + set FFLAGS = ( '-stackvar -explicitpar -vpara -e -u -noautopar -xtypemap=real:64,double:64,integer:32 -fsimple=0' ) + set FOPTIM = ( '-dalign -O3 -xarch=v9' ) + set NOOPTFLAGS = ( '-dalign -O0 -xarch=v9' ) '-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 mon_printstats_rl.F mon_printstats_rs.F') breaksw @@ -428,20 +440,22 @@ set NOOPTFILES = ( 'barrier.F different_multiple.F' \ 'external_fields_load.F' ) breaksw - case Linux+mpi: + case Linux-alpha+mpi: + echo "Configuring with MPI" set LIBS = ( '-L/usr/local/lib/LINUX/ch_p4/ -lfmpich -lmpich' ) set INCLUDES = ( '-I/usr/local/include' ) - case Linux: + case Linux-alpha: + echo "Configuring for " $platform set LN = ( '/bin/ln -s' ) set CPP = ( '/lib/cpp -traditional -P' ) set DEFINES = ( ${DEFINES} '-D_BYTESWAPIO -DWORDLENGTH=4' ) set FC = ( 'g77' ) - set FFLAGS = ( '-Wimplicit -Wunused -Wuninitialized' ) - if ($?IEEE) set FFLAGS = ( $FFLAGS '-ffloat-store' ) - set FOPTIM = ( '-O3 -malign-double -funroll-loops' ) + set FFLAGS = ( ' ' ) + if ($?IEEE) set FFLAGS = ( $FFLAGS '-ffloat-store' ) + set FOPTIM = ( '-ffast-math -fexpensive-optimizations -fomit-frame-pointer -O3' ) set LINK = ( 'g77' ) breaksw - case Linux+pgi+mpi: + case Linux*+pgi+mpi: if ($?include_jam_libs) then set INCLUDES = ( '-I/usr/local/mpich-1.2.1/pgi_fortran_binding/include' ) set LIBS = ( '-L/usr/local/mpich-1.2.1/pgi_fortran_binding/lib/ -lfmpich -lmpich' ) @@ -449,7 +463,8 @@ set INCLUDES = ( '-I/usr/local/include' ) set LIBS = ( '-L/usr/local/lib/LINUX/ch_p4/ -lfmpich -lmpich' ) endif - case Linux+pgi: + case Linux*+pgi: + echo "Configuring for " $platform set LN = ( '/bin/ln -s' ) set CPP = ( '/lib/cpp -traditional -P' ) set DEFINES = ( ${DEFINES} '-DWORDLENGTH=4' ) @@ -458,8 +473,23 @@ set FOPTIM = ( '-tp p6 -v -O2 -Munroll -Mvect=cachesize:512000,transform -Kieee' ) set LINK = ( 'pgf77' ) breaksw + case Linux*+mpi: + set LIBS = ( '-L/usr/local/lib/LINUX/ch_p4/ -lfmpich -lmpich' ) + set INCLUDES = ( '-I/usr/local/include' ) + case Linux*: + echo "Configuring for " $platform + set LN = ( '/bin/ln -s' ) + set CPP = ( '/lib/cpp -traditional -P' ) + set DEFINES = ( ${DEFINES} '-D_BYTESWAPIO -DWORDLENGTH=4' ) + set FC = ( 'g77' ) + set FFLAGS = ( '-Wimplicit -Wunused -Wuninitialized' ) + if ($?IEEE) set FFLAGS = ( $FFLAGS '-ffloat-store' ) + set FOPTIM = ( '-O3 -malign-double -funroll-loops' ) + set LINK = ( 'g77' ) + breaksw case T3E: case sn6312: + echo "Configuring for T3E" set CPP = ( '/opt/ctl/bin/cpp -P') set DEFINES = ( ${DEFINES} '-DTARGET_T3E -DWORDLENGTH=4' ) set FC = ( 'f90' ) @@ -468,6 +498,7 @@ breaksw case T90: case sn7113: + echo "Configuring for T90" set FC = ( 'f90' ) set LINK = ( 'f90' ) set LN = ( '/bin/ln -s' ) @@ -490,6 +521,30 @@ set NOOPTFLAGS = ( '-O0' ) set NOOPTFILES = ( 'barrier.F different_multiple.F external_fields_load.F') breaksw + case SP3: +# originally from A. Biastoch, SIO. + echo "Configuring for IBM SP POWER3" + set SOURCEDIRS = ( ./ $SOURCEDIRS ) + set LN = ( 'ln -s' ) + set DEFINES = ( ${DEFINES} '-DTARGET_PWR3 -DTARGET_SGI -DWORDLENGTH=4' ) + set INCLUDES = ( '-I/usr/lpp/ppe.poe/include' ) +# set CPP = ( '/lib/cpp' ) + set FC = ( 'mpxlf95' ) + set LINK = ( 'mpxlf95' ) + set FLAGS = ( '-O3 -qarch=pwr3 -qtune=pwr3 -qcache=auto -qmaxmem=-1' \ + '-bmaxdata:0x80000000 -bloadmap:mitgcmuv.map' ) + set FFLAGS = ( '-qfixed=132 -O3 -qarch=pwr3 -qtune=pwr3 -qcache=auto -qmaxmem=-1' \ + '-bmaxdata:0x80000000 ' ) + set LDFLAGS = ( '-O3 -qarch=pwr3 -qtune=pwr3 -qcache=auto -qmaxmem=-1' \ + '-bmaxdata:0x80000000' ) + set LIBS = ( ' -L/usr/local/apps/mass -lmass' ) +# set FFLAGS = ( '-extend_source -mp -mpio -bytereclen -r10000 -mips4' ) +# set FOPTIM = ( '-O3' ) +# set NOOPTFLAGS = ( '-O0' ) +# set NOOPTFILES = ( 'barrier.F different_multiple.F ' \ +# 'external_fields_load.F' ) + set RMFILES = ( 'rii_files' ) + breaksw default: echo "Error: platform not recognized: uname -p = " $platform$USEMPI exit @@ -581,6 +636,7 @@ # CPP : C-preprocessor command # INCLUDES : Directories searched for header files # DEFINES : Macro definitions for CPP +# MAKEDEPEND : Dependency generator # KPP : Special preprocessor command (specific to platform) # KFLAGS : Flags for KPP # FC : Fortran compiler command @@ -638,7 +694,9 @@ # Unix ln (link) LN = ${LN} # C preprocessor -CPP = cat \$< | \$(TOOLSDIR)/set64bitConst.sh | ${CPP} +CPP = cat \$< | ${S64} | ${CPP} +# Dependency generator +MAKEDEPEND = ${MAKEDEPEND} # Special preprocessor (KAP on DECs, FPP on Crays) KPP = ${KPP} # Fortran compiler @@ -656,6 +714,8 @@ # Optim./debug for FC FFLAGS = ${FFLAGS} FOPTIM = ${FOPTIM} +# Flags for CC +CFLAGS = ${CFLAGS} # Files that should not be optimized NOOPTFILES = ${NOOPTFILES} NOOPTFLAGS = ${NOOPTFLAGS} @@ -682,14 +742,14 @@ \$(LINK) -o \$@ \$(FFLAGS) \$(FOPTIM) \$(OBJFILES) \$(LIBS) depend: @make links - makedepend -o .f \$(INCLUDES) \$(SRCFILES) + \$(MAKEDEPEND) -o .f \$(DEFINES) \$(INCLUDES) \$(SRCFILES) links: \$(SRCFILES) \$(CSRCFILES) \$(HEADERFILES) small_f: \$(F77FILES) output.txt: \$(EXECUTABLE) - @echo -n "running ... " + @printf 'running ... ' @\$(EXECUTABLE) > \$@ clean: @@ -714,6 +774,8 @@ \$(CPP) \$(DEFINES) \$(INCLUDES) > \$@ .f.o: \$(FC) \$(FFLAGS) \$(FOPTIM) -c \$< +.c.o: + \$(CC) \$(CFLAGS) -c \$< # Special exceptions that use the ( .F - .p - .f - .o ) rule-chain .F.p: