SHELL=/bin/bash # # This makefile was produced by /usr/bin/fmgen at 11:46:34 AM on 03/15/95 # If it is invoked by the command line # make -f makefile # it will compile the fortran modules indicated by SRC into the object # modules indicated by OBJ and produce an executable named field. # # If it is invoked by the command line # make -f makefile field.prof # it will compile the fortran modules indicated by SRC into the object # modules indicated by OBJ and produce an executable which profiles # named field.prof. # # To remove all the objects but leave the executables use the command line # make -f makefile clean # # To remove everything but the source files use the command line # make -f makefile clobber # # To remove the source files created by /usr/bin/fmgen and this makefile # use the command line # make -f makefile void # # The parameters SRC and OBJ should not need to be changed. If, however, # you need to add a new module add the name of the source module to the # SRC parameter and add the name of the resulting object file to the OBJ # parameter. The new modules are not limited to fortran, but may be C, YACC, # LEX, or CAL. An explicit rule will need to be added for PASCAL modules. # SRC= modules.f bound.f const.f fdump.f frmin.f frmout.f h12.f \ i1mach.f init.f interp.f j4save.f nest.f pcort.f phase.f \ psfin.f psfout.f separ.f star.f wghts.f wind.f wnlit.f \ wnlsm.f wnnls.f xerabt.f xerctl.f xerprt.f xerror.f xerrwv.f \ xersav.f xgetua.f amatrix.f \ omu.f radd.f rodist.f interad.f wght.f \ srotm.f srotmg.f OBJ= ${SRC:.f=.o} # Tunable parameters # # FC Name of the fortran compiling system to use # LDFLAGS Flags to the loader # LIBS List of libraries # CMD Name of the executable # PROFLIB Library needed for profiling # ISIZE = 4 RSIZE = 4 FC = ifort #LDFLAGS = -L/usrx/local/intel/mkl/lib/intel64 -lmkl_blas95_lp64 -lmkl_lapack95_lp64 MKLROOT= /usrx/local/intel/mkl LDFLAGS = -Wl, $(MKLROOT)/lib/intel64/libmkl_intel_lp64.a $(MKLROOT)/lib/intel64/libmkl_sequential.a $(MKLROOT)/lib/intel64/libmkl_core.a -Wl, -lpthread -lm LIBS = -L/nwprod/lib -lw3nco_d CMD = gfdl_chgvortx PROFLIB = -lprof # To perform the default compilation, use the first line # To compile with flowtracing turned on, use the second line # To compile giving profile additonal information, use the third line # WARNING: SIMULTANEOUSLY PROFILING AND FLOWTRACING IS NOT RECOMMENDED #FFLAGS = -Zv -F #FFLAGS = -Zv -Wf"-ez" #FFLAGS = -O2 -qintsize=$(ISIZE) -qrealsize=$(RSIZE) FFLAGS = -O2 -i4 -convert big_endian # Lines from here on down should not need to be changed. They are the # actual rules which make uses to build field. # .f.o: $(FC) $(FFLAGS) -c $*.f all: $(CMD) $(CMD): $(OBJ) $(FC) -o $(@) $(OBJ) $(LIBS) $(LDFLAGS) # Make the profiled version of the command and call it field.prof # $(CMD).prof: $(OBJ) $(FC) $(LDFLAGS) -o $(@) $(OBJ) $(PROFLIB) $(LIBS) clean: -rm -f $(OBJ) *.mod copy_summ: cp summary.o.hold summary.o allclean: clean all clobber: clean -rm -f $(CMD) $(CMD).prof void: clobber -rm -f $(SRC) makefile