--- MITgcm/tools/genmake 2001/02/07 16:49:20 1.28 +++ MITgcm/tools/genmake 2002/11/15 17:18:57 1.70 @@ -1,6 +1,7 @@ #!/bin/csh -f # -# $Header: /home/ubuntu/mnt/e9_copy/MITgcm/tools/Attic/genmake,v 1.28 2001/02/07 16:49:20 adcroft Exp $ +# $Header: /home/ubuntu/mnt/e9_copy/MITgcm/tools/Attic/genmake,v 1.70 2002/11/15 17:18:57 cheisey Exp $ +# $Name: $ # # Makefile generator for MITgcm UV codes # created by cnh 03/98 @@ -8,7 +9,8 @@ # modified by aja 01/00 # Default lists -set DISABLE = ( aim ) +set DISABLE = ( aim autodiff cal cost ctrl ecco exf grdchk flt ptracers seaice ) +set DEFINES = ( ) set ENABLE = ( ) set MODS = ( ) @@ -50,7 +52,6 @@ echo "***" Command line \"$arg\" will override this. endif set ROOTDIR = ( `echo $arg | sed 's/-rootdir=//' `) - if (! $?EXEDIR) set EXEDIR = ( . ) breaksw case -mods: case -mods=: @@ -80,6 +81,17 @@ case -enable=*: set ENABLE = ( $ENABLE `echo $arg | sed 's/-enable=//' | sed 's/,/ /g' `) breaksw + case -cpp: + case -cpp=: + echo "To define CPP macros use -cpp=arg" + exit + breaksw + case -cpp=*: + set DEFINES = ( $DEFINES `echo $arg | sed 's/-cpp=//' | sed 's/,/ /g' `) + breaksw + case -ieee: + set IEEE + breaksw case -mpi: echo "Enabling MPI options" set USEMPI @@ -88,8 +100,43 @@ set include_jam_libs echo "Including paths to JAM libraries" breaksw + case -fc: + case -fc=: + echo "To change the compiler (\$FC) you must specify one with -fc=" + echo "eg. -fc=f90 or -fc=g77" + exit + breaksw + case -fc*: + if ($?FC) then + echo Option -fc=... can only be specified once.; exit 1 + endif + set FC = ( `echo $arg | sed 's/-fc=//' `) + breaksw case -help: - echo "usage: $0 [-help] [-makefile[=...]] [-platform=...] [-mpi]" + echo "usage: $0 [-help] [-makefile[=...]] [-platform=...] [-mpi] [-jam] [-disable=pkg1[,pkg2,...]] [-enable=pkg1[,pkg2,...]] [-mods=dir1[,dir2,...]] [-rootdir=dir]" +cat << EOF + +$0 is used to generate the Makefile in the current directory. + +Typical invocations are: + o from "bin": ../tools/genmake + o from "verification/expt/code": ../../../tools/genmake + o from "verification/expt/input": ../../../tools/genmake -mods=../code + o from a scratch directory: ~/mitgcm/tools/genmake -rootdir=~/mitgcm + or ~/mitgcm/tools/genmake -rootdir=~/mitgcm -mods=~/mymods + +Packages (collected modules of code) can be disabled to avoid unnecessary +compilation of unused code. For instance if you know you will not +use GM/Redi, KPP and OBCS and they are appropriate turned-off in the +configuration: + .../tools/genmake -disable=gmredi,kpp,obcs + +If you add some source files you can re-call the previous instance of +genmake with "make makefile". + +genmake also reads the file .genmakerc which can be used to configure +options (primarily the command-line options above) for particular experiments. +EOF exit breaksw default: @@ -106,6 +153,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 ) @@ -113,21 +165,14 @@ set mach = ( `uname -a` ) echo Operating system: $mach - # Directories for source, includes, binaries and executables # # If -rootdir wasn't specified then assume script is being run from bin # but if it was supplied then we should place the executable in the build dir if (! $?ROOTDIR) then set pwd=`pwd` - if ($pwd:t == bin) then - if (-d ../exe & -d ../model & -d ../eesupp & -d ../pkg) then - set ROOTDIR = ( .. ) - if (! $?EXEDIR) set EXEDIR = ( ../exe ) - else if (-d ../model & -d ../eesupp & -d ../pkg) then - echo In bin with no exe - if (! $?EXEDIR) set EXEDIR = ( . ) - endif + if ($pwd:t == bin & -d ../model & -d ../eesupp & -d ../pkg) then + set ROOTDIR = ( .. ) endif endif # Scan for logical ROOTDIR @@ -135,7 +180,6 @@ foreach dr (. .. ../.. ../../.. ../../../.. ../../../../..) if (-d $dr/model & -d $dr/eesupp & -d $dr/pkg) then set ROOTDIR = $dr - if (! $?EXEDIR) set EXEDIR = ( . ) echo ROOTDIR was not specified. Setting ROOTDIR = \"$ROOTDIR\" break endif @@ -153,15 +197,23 @@ # 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 echo Build directory $BUILDDIR not found.;exit 1 endif +if (! $?EXEDIR) then + set pwd=`pwd` + if ($pwd:t == bin & -d ../exe & $ROOTDIR == ..) then + set EXEDIR = ( ../exe ) + else + set EXEDIR = ( . ) + endif +endif if (! -d $EXEDIR) then echo Executable directory $EXEDIR not found.;exit 1 endif @@ -171,33 +223,48 @@ endif if (! $?EXECUTABLE) set EXECUTABLE = ( mitgcmuv ) +# We have a special set of source files in eesupp/src which +# are generated from some template source files. We'll make them +# first so the appear as regular source code +if (-r $ROOTDIR/eesupp/src/Makefile) then + echo Making source files in eesupp from templates... + (cd $ROOTDIR/eesupp/src/; make) >& make_eesupp.errs + if ($status == 0) then + rm -f make_eesupp.errs + else + cat make_eesupp.errs + exit 2 + endif +endif + # Now scan the standard source code tree foreach dr ($SOURCEDIRS) set adr=$dr if (! -d $adr) then echo mods directory $adr not found.; exit 1 endif - echo Adding mods directory $adr -end -if (! $?STANDARDDIRS) set STANDARDDIRS=(eesupp model diags) -foreach dr ($STANDARDDIRS) - set adr=$ROOTDIR/$dr/src - if (! -d $adr) then - echo Source directory $adr not found.; exit 1 - endif - echo Adding source directory $adr - set SOURCEDIRS = ($SOURCEDIRS $adr) - set idr = `echo $adr | sed 's/src/inc/'` - set INCLUDEDIRS = ($INCLUDEDIRS $idr) + echo Adding mods dir: $adr end if (! $?PACKAGES) then - set PACKAGES=(`cd $ROOTDIR/pkg; ls -1 | grep -v CVS`) + set PACKAGES=() + foreach pkg (`cd $ROOTDIR/pkg; find . -type d -print | grep -v CVS | sed 's:\./::' | grep -v "\." | sort`) + if (-d $ROOTDIR/pkg/$pkg) set PACKAGES=($PACKAGES $pkg) + end endif foreach dr ($PACKAGES) set enable foreach p ($DISABLE) + if ($p != 'all' & ! -d $ROOTDIR/pkg/$p) then + echo Specified package \"$p\" does not exist. + exit 1 + endif if ($dr == $p) unset enable if ($p == 'all') unset enable +# The following allows entire trees to be disabled + if ($dr:h == $p) unset enable + if ($dr:h:h == $p) unset enable + if ($dr:h:h:h == $p) unset enable + if ($dr:h:h:h:h == $p) unset enable end foreach p ($ENABLE) if ($dr == $p) set enable @@ -207,25 +274,91 @@ if (! -d $adr) then echo Source directory $adr not found.; exit 1 endif - echo Adding package directory $adr + echo Adding pkg dir: $adr set SOURCEDIRS = ($SOURCEDIRS $adr) set INCLUDEDIRS = ($INCLUDEDIRS $adr) + switch ($dr) + case ptracers: + set DEFINES = ($DEFINES '-DALLOW_PTRACERS'); breaksw + default: + breaksw + endsw else - echo "*" Package \"$dr\" has not been enabled. + 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_VECINV'); breaksw + case generic_advdiff: + set DEFINES = ($DEFINES '-DDISABLE_GENERIC_ADVDIFF'); breaksw + case debug: + set DEFINES = ($DEFINES '-DDISABLE_DEBUGMODE'); breaksw + default: + breaksw + endsw + endif +end +if (! $?STANDARDDIRS) set STANDARDDIRS=(eesupp model) +foreach dr ($STANDARDDIRS) + set adr=$ROOTDIR/$dr/src + if (! -d $adr) then + echo Source directory $adr not found.; exit 1 endif + echo Adding src dir: $adr + set SOURCEDIRS = ($SOURCEDIRS $adr) + set idr = `echo $adr | sed 's/src/inc/'` + set INCLUDEDIRS = ($INCLUDEDIRS $idr) end +# Find possible compilers +if ($?FC) then + echo "$FC was specified as the compiler" +else + echo " " + switch ($platform) + case Linux*: + set likelysuspects=(g77 ifc pgf77 f77 f90 f95) + breaksw + default: + set likelysuspects=(f77) + breaksw + endsw + foreach fc ($likelysuspects) + set foundfc=`which $fc |& cat - ` + if (-x $foundfc[1]) then + if ($?possiblefc) then + set possiblefc=($possiblefc $fc) + else + set possiblefc=$fc + endif + endif + end + if ($?possiblefc) then + set FC=$possiblefc[1] + echo Found these compilers: $possiblefc. Using \"$FC\" as the compiler + else + echo "No compiler found\!" + echo I tried looking for \"$likelysuspects\" in your \$PATH but found none + echo I will continue anyway and see what happens. + set FC = ( 'f77' ) +# exit 13 + endif +endif + # This is the generic configuration. # 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 DEFINES = ( ) -set INCLUDES = ( ) +#set FC = ( 'f77' ) +set LINK = $FC +set MAKEDEPEND = ( 'makedepend' ) +set INCLUDES = ( -I. ) set FFLAGS = ( ) set FOPTIM = ( ) +set CFLAGS = ( ) set KFLAGS1 = ( ) set KFLAGS2 = ( ) set LIBS = ( ) @@ -245,19 +378,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 @@ -275,7 +409,7 @@ echo "Configuring for SGI Mips" set DEFINES = ( ${DEFINES} '-DTARGET_SGI -DWORDLENGTH=4' ) set INCLUDES = ( '-I/usr/local/mpi/include' ) - set FFLAGS = ( '-extend_source -mp -mpio -bytereclen -r10000 -mips4' ) + set FFLAGS = ( '-extend_source -mp -mpio -bytereclen -r10000 -mips4 -r8 -static' ) set FOPTIM = ( '-O3' ) # set NOOPTFLAGS = ( '-O0' ) # set NOOPTFILES = ( 'barrier.F different_multiple.F ' \ @@ -323,23 +457,25 @@ 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') + 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') + 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" @@ -367,27 +503,31 @@ 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' ) - 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-cnh-install/include' ) - set LIBS = ( '-L/usr/local/mpich-cnh-install/lib/LINUX/ch_p4/ -lfmpich -lmpich' ) + 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' ) else 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' ) @@ -396,8 +536,44 @@ 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' ) + switch ($FC) + case g77: + set DEFINES = ( ${DEFINES} '-D_BYTESWAPIO -DWORDLENGTH=4' ) + set FFLAGS = ( '-Wimplicit -Wunused -Wuninitialized' ) + if ($?IEEE) set FFLAGS = ( $FFLAGS '-ffloat-store' ) + set FOPTIM = ( '-O3 -malign-double -funroll-loops' ) + breaksw + case pgf77: + set DEFINES = ( ${DEFINES} '-DWORDLENGTH=4' ) + set FC = ( 'pgf77' ) + set FFLAGS = ( '-byteswapio -r8 -Mnodclchk -Mextend' ) + set FOPTIM = ( '-tp p6 -v -O2 -Munroll -Mvect=cachesize:512000,transform -Kieee' ) + breaksw + case ifc: + set DEFINES = ( ${DEFINES} '-D_BYTESWAPIO -DWORDLENGTH=4' ) + set FFLAGS = ( '-132 -r8 -i4 -w95 -W0 -WB' ) + if ($?IEEE) set FFLAGS = ( $FFLAGS '-mp' ) + set FOPTIM = ( '-O3 -align' ) +#P3 set FOPTIM = ( $FOPTIM '-tpp6 -xWKM' ) +#P4 set FOPTIM = ( $FOPTIM '-tpp7 -xWKM' ) + set LIBS = ( '-lPEPCF90' ) + breaksw + default: + echo Error: Linux compiler not recognized: \$FC=$FC + exit + breaksw + endsw + 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' ) @@ -406,6 +582,7 @@ breaksw case T90: case sn7113: + echo "Configuring for T90" set FC = ( 'f90' ) set LINK = ( 'f90' ) set LN = ( '/bin/ln -s' ) @@ -428,6 +605,41 @@ set NOOPTFLAGS = ( '-O0' ) set NOOPTFILES = ( 'barrier.F different_multiple.F external_fields_load.F') breaksw + case cg01+pgi: + set LN = ( '/bin/ln -s' ) + set CPP = ( '/lib/cpp -traditional -P' ) + set INCLUDES = ( '-I/usr/local/pkg/mpi/mpi-1.2.4..8a-gm-1.5/pgi/include' ) + set DEFINES = ( ${DEFINES} '-DWORDLENGTH=4' ) + set FC = ( '/usr/local/pkg/mpi/mpi-1.2.4..8a-gm-1.5/pgi/bin/mpif77' ) + set FFLAGS = ( '-byteswapio -r8 -Mnodclchk -Mextend' ) +# set LIBS = ( '-L/home/cnh/src/gm-1.4/libgm') + set FOPTIM = ( '-tp p6 -v -O2 -Munroll -Mvect=cachesize:512000,transform -Kieee' ) + set LINK = ( '/usr/local/pkg/mpi/mpi-1.2.4..8a-gm-1.5/pgi/bin/mpif77' ) + 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 @@ -452,8 +664,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 @@ -472,10 +684,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 @@ -490,7 +702,7 @@ rm -rf .links.tmp echo "" >> srclist.inc echo "" >> csrclist.inc -#echo "" >> hlist.inc +echo "" >> hlist.inc set THISHOSTNAME = ( `hostname` ) set THISCWD = ( `pwd` ) @@ -519,6 +731,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 @@ -544,6 +757,7 @@ # extra stuff for Hyades ............................................ HYADES_DIR = /u/u0/cnh/jam-lib/software HYADES_DIR = /u/u0/cnh/jam-lib-twoproc +HYADES_DIR = /usr/local/jamlib/current/dual_proc WORK_DIR = \$(HYADES_DIR) DEPOSIT_DIR = linux_bin @@ -575,7 +789,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 @@ -593,6 +809,8 @@ # Optim./debug for FC FFLAGS = ${FFLAGS} FOPTIM = ${FOPTIM} +# Flags for CC +CFLAGS = ${CFLAGS} # Files that should not be optimized NOOPTFILES = ${NOOPTFILES} NOOPTFLAGS = ${NOOPTFLAGS} @@ -603,10 +821,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} + -rm -rf *.o *.f *.p ${RMFILES} work.{pc,pcl} Clean: @make clean - -find . -type l -exec rm {} \; + @make cleanlinks -rm -f Makefile.bak CLEAN: @make Clean @@ -635,11 +859,18 @@ -find \$(EXEDIR) -name "*.data" -exec rm {} \; -rm -f \$(EXECUTABLE) +makefile: + ${0} $argv +cleanlinks: + -find . -type l -exec rm {} \; + # The normal chain of rules is ( .F - .f - .o ) .F.f: \$(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: