1ROOTDIR = $(abspath $(dir $(firstword $(MAKEFILE_LIST)))) 2DEPDIR = ../../.. 3SRCDIR = . 4INCDIR = . 5BLDDIR = obj 6OUTDIR = . 7 8CXXFLAGS = $(NULL) 9CFLAGS = $(NULL) 10DFLAGS = $(NULL) 11 12BLAS = 0 13SYM = 1 14OMP = 1 15 16# include common Makefile artifacts 17include $(DEPDIR)/Makefile.inc 18 19# necessary include directories 20IFLAGS += -I$(call quote,$(INCDIR)) 21IFLAGS += -I$(call quote,$(DEPDIR)/include) 22 23OUTNAME := $(shell basename "$(ROOTDIR)") 24HEADERS := $(wildcard $(INCDIR)/*.h) $(wildcard $(INCDIR)/*.hpp) $(wildcard $(INCDIR)/*.hxx) $(wildcard $(INCDIR)/*.hh) \ 25 $(wildcard $(SRCDIR)/*.h) $(wildcard $(SRCDIR)/*.hpp) $(wildcard $(SRCDIR)/*.hxx) $(wildcard $(SRCDIR)/*.hh) \ 26 $(DEPDIR)/include/libxsmm_source.h 27CPPSRCS := $(wildcard $(SRCDIR)/*.cpp) 28CXXSRCS := $(wildcard $(SRCDIR)/*.cxx) 29CCXSRCS := $(wildcard $(SRCDIR)/*.cc) 30CSOURCS := $(wildcard $(SRCDIR)/*.c) 31CPPOBJS := $(patsubst %,$(BLDDIR)/%,$(notdir $(CPPSRCS:.cpp=-cpp.o))) 32CXXOBJS := $(patsubst %,$(BLDDIR)/%,$(notdir $(CXXSRCS:.cxx=-cxx.o))) 33CCXOBJS := $(patsubst %,$(BLDDIR)/%,$(notdir $(CCXSRCS:.cc=-cc.o))) 34COBJCTS := $(patsubst %,$(BLDDIR)/%,$(notdir $(CSOURCS:.c=-c.o))) 35ifneq (,$(strip $(FC))) 36FXXSRCS := $(wildcard $(SRCDIR)/*.f) 37F77SRCS := $(wildcard $(SRCDIR)/*.F) 38F90SRCS := $(wildcard $(SRCDIR)/*.f90) $(wildcard $(SRCDIR)/*.F90) 39FXXOBJS := $(patsubst %,$(BLDDIR)/%,$(notdir $(FXXSRCS:.f=-f.o))) 40F77OBJS := $(patsubst %,$(BLDDIR)/%,$(notdir $(F77SRCS:.F=-f77.o))) 41F90OBJS := $(patsubst %,$(BLDDIR)/%,$(notdir $(F90SRCS:.f90=-f90.o))) 42F90OBJS := $(patsubst %,$(BLDDIR)/%,$(notdir $(F90OBJS:.F90=-f90.o))) 43endif 44SOURCES := $(CPPSRCS) $(CXXSRCS) $(CCXSRCS) $(CSOURCS) 45OBJECTS := $(CPPOBJS) $(CXXOBJS) $(CCXOBJS) $(COBJCTS) 46FTNSRCS := $(FXXSRCS) $(F77SRCS) $(F90SRCS) 47MODULES := $(addsuffix .mod,$(basename $(FTNSRCS))) $(addsuffix .modmic,$(basename $(FTNSRCS))) 48FTNOBJS := $(FXXOBJS) $(F77OBJS) $(F90OBJS) 49XFILES := $(OUTDIR)/$(OUTNAME) $(OUTDIR)/$(OUTNAME)f $(OUTDIR)/$(OUTNAME)f_udt 50 51.PHONY: all 52all: $(XFILES) 53 54.PHONY: compile 55compile: $(OBJECTS) $(FTNOBJS) 56 57ifneq (,$(strip $(FC))) 58$(OUTDIR)/$(OUTNAME)f: $(OUTDIR)/.make $(BLDDIR)/$(OUTNAME)-f.o $(FORTDEP) $(LIBDEP) $(EXTDEP) 59 $(FLD) -o $@ $(BLDDIR)/$(OUTNAME)-f.o $(FORTLIB) $(MAINLIB) \ 60 $(FCMTFLAGS) $(SLDFLAGS) $(LDFLAGS) $(FLDFLAGS) $(ELDFLAGS) 61$(OUTDIR)/$(OUTNAME)f_udt: $(OUTDIR)/.make $(BLDDIR)/$(OUTNAME)_udt-f.o $(FORTDEP) $(LIBDEP) $(EXTDEP) 62 $(FLD) -o $@ $(BLDDIR)/$(OUTNAME)_udt-f.o $(FORTLIB) $(MAINLIB) \ 63 $(FCMTFLAGS) $(SLDFLAGS) $(LDFLAGS) $(FLDFLAGS) $(ELDFLAGS) 64else 65.PHONY: $(OUTDIR)/$(OUTNAME)f 66.PHONY: $(OUTDIR)/$(OUTNAME)f_udt 67endif 68 69$(OUTDIR)/$(OUTNAME): $(OUTDIR)/.make $(OBJECTS) $(LIBDEP) $(EXTDEP) 70 $(LD) -o $@ $(OBJECTS) $(MAINLIB) $(SLDFLAGS) $(LDFLAGS) $(CLDFLAGS) 71 72$(BLDDIR)/%-cpp.o: $(SRCDIR)/%.cpp .state $(BLDDIR)/.make $(HEADERS) Makefile $(DEPDIR)/Makefile.inc 73 $(CXX) $(DFLAGS) $(IFLAGS) $(CXXFLAGS) $(CTARGET) -c $< -o $@ 74 75$(BLDDIR)/%-c.o: $(SRCDIR)/%.c .state $(BLDDIR)/.make $(HEADERS) Makefile $(DEPDIR)/Makefile.inc 76 $(CC) $(DFLAGS) $(IFLAGS) $(CFLAGS) $(CTARGET) -c $< -o $@ 77 78$(BLDDIR)/%-f.o: $(SRCDIR)/%.f .state $(BLDDIR)/.make Makefile $(DEPDIR)/Makefile.inc 79 $(FC) $(FCMTFLAGS) $(DFLAGS) $(IFLAGS) $(FCFLAGS) $(FTARGET) -c $< -o $@ 80 81$(BLDDIR)/%-f90.o: $(SRCDIR)/%.f90 .state $(BLDDIR)/.make Makefile $(DEPDIR)/Makefile.inc 82 $(FC) $(FCMTFLAGS) $(DFLAGS) $(IFLAGS) $(FCFLAGS) $(FTARGET) -c $< -o $@ 83 84$(BLDDIR)/%-f90.o: $(SRCDIR)/%.F90 .state $(BLDDIR)/.make Makefile $(DEPDIR)/Makefile.inc 85 $(FC) $(FCMTFLAGS) $(DFLAGS) $(IFLAGS) $(FCFLAGS) $(FTARGET) -c $< -o $@ 86 87$(BLDDIR)/%-f77.o: $(SRCDIR)/%.F .state $(BLDDIR)/.make Makefile $(DEPDIR)/Makefile.inc 88 $(FC) $(FCMTFLAGS) $(DFLAGS) $(IFLAGS) $(FCFLAGS) $(FTARGET) -c $< -o $@ 89 90.PHONY: clean 91clean: 92ifneq ($(call qapath,$(BLDDIR)),$(ROOTDIR)) 93ifneq ($(call qapath,$(BLDDIR)),$(call qapath,.)) 94 @rm -rf $(BLDDIR) 95endif 96endif 97ifneq (,$(wildcard $(BLDDIR))) # still exists 98 @rm -f $(OBJECTS) $(OBJECTX) $(FTNOBJS) $(FTNOBJX) *__genmod.* fit.log *.dat 99 @rm -f $(BLDDIR)/*.gcno $(BLDDIR)/*.gcda $(BLDDIR)/*.gcov 100endif 101 @rm -f .make .state 102 103.PHONY: realclean 104realclean: clean 105ifneq ($(call qapath,$(OUTDIR)),$(ROOTDIR)) 106ifneq ($(call qapath,$(OUTDIR)),$(call qapath,.)) 107 @rm -rf $(OUTDIR) 108endif 109endif 110ifneq (,$(wildcard $(OUTDIR))) # still exists 111 @rm -f $(OUTDIR)/libxsmm.$(DLIBEXT) $(OUTDIR)/*.stackdump 112 @rm -f $(XFILES) $(MODULES) 113endif 114 115