1ROOTDIR = $(abspath $(dir $(firstword $(MAKEFILE_LIST))))
2DEPDIR = ../../..
3SRCDIR = .
4INCDIR = .
5BLDDIR = obj
6OUTDIR = .
7
8CXXFLAGS = $(NULL)
9CFLAGS = $(NULL)
10DFLAGS = $(NULL)
11
12BLAS = 2
13OMP = 1
14SYM = 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)/sparse_weight_B_mult $(OUTDIR)/sparse_weight_A_mult $(OUTDIR)/simple $(OUTDIR)/parallel_sparse_weight_B_mult $(OUTDIR)/sparse_weight_C_redmult $(OUTDIR)/parallel_sparse_weight_C_redmult
50.PHONY: all
51all: $(XFILES)
52
53.PHONY: compile
54compile: $(OBJECTS) $(FTNOBJS)
55
56$(OUTDIR)/sparse_weight_B_mult: $(OUTDIR)/.make $(BLDDIR)/sparse_weight_B_mult-c.o $(LIBDEP) $(EXTDEP)
57	$(LD) -o $@ $(BLDDIR)/sparse_weight_B_mult-c.o $(call cleanld,$(EXTLIB) $(MAINLIB) $(SLDFLAGS) $(LDFLAGS) $(CLDFLAGS))
58
59$(OUTDIR)/sparse_weight_A_mult: $(OUTDIR)/.make $(BLDDIR)/sparse_weight_A_mult-c.o $(LIBDEP) $(EXTDEP)
60	$(LD) -o $@ $(BLDDIR)/sparse_weight_A_mult-c.o $(call cleanld,$(EXTLIB) $(MAINLIB) $(SLDFLAGS) $(LDFLAGS) $(CLDFLAGS))
61
62$(OUTDIR)/simple: $(OUTDIR)/.make $(BLDDIR)/simple-c.o $(LIBDEP) $(EXTDEP)
63	$(LD) -o $@ $(BLDDIR)/simple-c.o $(call cleanld,$(EXTLIB) $(MAINLIB) $(SLDFLAGS) $(LDFLAGS) $(CLDFLAGS))
64
65$(OUTDIR)/parallel_sparse_weight_B_mult: $(OUTDIR)/.make $(BLDDIR)/parallel_sparse_weight_B_mult-c.o $(LIBDEP) $(EXTDEP)
66	$(LD) -o $@ $(BLDDIR)/parallel_sparse_weight_B_mult-c.o $(call cleanld,$(EXTLIB) $(MAINLIB) $(SLDFLAGS) $(LDFLAGS) $(CLDFLAGS))
67
68$(OUTDIR)/sparse_weight_C_redmult: $(OUTDIR)/.make $(BLDDIR)/sparse_weight_C_redmult-c.o $(LIBDEP) $(EXTDEP)
69	$(LD) -o $@ $(BLDDIR)/sparse_weight_C_redmult-c.o $(call cleanld,$(EXTLIB) $(MAINLIB) $(SLDFLAGS) $(LDFLAGS) $(CLDFLAGS))
70
71$(OUTDIR)/parallel_sparse_weight_C_redmult: $(OUTDIR)/.make $(BLDDIR)/parallel_sparse_weight_C_redmult-c.o $(LIBDEP) $(EXTDEP)
72	$(LD) -o $@ $(BLDDIR)/parallel_sparse_weight_C_redmult-c.o $(call cleanld,$(EXTLIB) $(MAINLIB) $(SLDFLAGS) $(LDFLAGS) $(CLDFLAGS))
73
74$(BLDDIR)/%-cpp.o: $(SRCDIR)/%.cpp .state $(BLDDIR)/.make $(HEADERS) Makefile $(DEPDIR)/Makefile.inc
75	$(CXX) $(DFLAGS) $(IFLAGS) $(CXXFLAGS) $(CTARGET) -c $< -o $@
76
77$(BLDDIR)/%-c.o: $(SRCDIR)/%.c .state $(BLDDIR)/.make $(HEADERS) Makefile $(DEPDIR)/Makefile.inc
78	$(CC) $(DFLAGS) $(IFLAGS) $(CFLAGS) $(CTARGET) -c $< -o $@
79
80$(BLDDIR)/%-f.o: $(SRCDIR)/%.f .state $(BLDDIR)/.make Makefile $(DEPDIR)/Makefile.inc
81	$(FC) $(FCMTFLAGS) $(DFLAGS) $(IFLAGS) $(FCFLAGS) $(FTARGET) -c $< -o $@
82
83$(BLDDIR)/%-f90.o: $(SRCDIR)/%.f90 .state $(BLDDIR)/.make Makefile $(DEPDIR)/Makefile.inc
84	$(FC) $(FCMTFLAGS) $(DFLAGS) $(IFLAGS) $(FCFLAGS) $(FTARGET) -c $< -o $@
85
86$(BLDDIR)/%-f90.o: $(SRCDIR)/%.F90 .state $(BLDDIR)/.make Makefile $(DEPDIR)/Makefile.inc
87	$(FC) $(FCMTFLAGS) $(DFLAGS) $(IFLAGS) $(FCFLAGS) $(FTARGET) -c $< -o $@
88
89$(BLDDIR)/%-f77.o: $(SRCDIR)/%.F .state $(BLDDIR)/.make Makefile $(DEPDIR)/Makefile.inc
90	$(FC) $(FCMTFLAGS) $(DFLAGS) $(IFLAGS) $(FCFLAGS) $(FTARGET) -c $< -o $@
91
92.PHONY: clean
93clean:
94ifneq ($(call qapath,$(BLDDIR)),$(ROOTDIR))
95ifneq ($(call qapath,$(BLDDIR)),$(call qapath,.))
96	@rm -rf $(BLDDIR)
97endif
98endif
99ifneq (,$(wildcard $(BLDDIR))) # still exists
100	@rm -f $(OBJECTS) $(OBJECTX) $(FTNOBJS) $(FTNOBJX) *__genmod.* fit.log *.dat
101	@rm -f $(BLDDIR)/*.gcno $(BLDDIR)/*.gcda $(BLDDIR)/*.gcov
102endif
103	@rm -f .make .state
104
105.PHONY: realclean
106realclean: clean
107ifneq ($(call qapath,$(OUTDIR)),$(ROOTDIR))
108ifneq ($(call qapath,$(OUTDIR)),$(call qapath,.))
109	@rm -rf $(OUTDIR)
110endif
111endif
112ifneq (,$(wildcard $(OUTDIR))) # still exists
113	@rm -f $(OUTDIR)/libxsmm.$(DLIBEXT) $(OUTDIR)/*.stackdump
114	@rm -f $(XFILES) $(MODULES)
115endif
116
117