xref: /libCEED/Makefile (revision 21ae68677e920847a9cd245b7cbbc80d4b353cdd)
10d9661cdSTzanio# Copyright (c) 2017, Lawrence Livermore National Security, LLC. Produced at
20d9661cdSTzanio# the Lawrence Livermore National Laboratory. LLNL-CODE-734707. All Rights
30d9661cdSTzanio# reserved. See files LICENSE and NOTICE for details.
40d9661cdSTzanio#
50d9661cdSTzanio# This file is part of CEED, a collection of benchmarks, miniapps, software
60d9661cdSTzanio# libraries and APIs for efficient high-order finite element and spectral
70d9661cdSTzanio# element discretizations for exascale applications. For more information and
80d9661cdSTzanio# source code availability see http://github.com/ceed.
90d9661cdSTzanio#
100d9661cdSTzanio# The CEED research is supported by the Exascale Computing Project 17-SC-20-SC,
110d9661cdSTzanio# a collaborative effort of two U.S. Department of Energy organizations (Office
120d9661cdSTzanio# of Science and the National Nuclear Security Administration) responsible for
130d9661cdSTzanio# the planning and preparation of a capable exascale ecosystem, including
140d9661cdSTzanio# software, applications, hardware, advanced system engineering and early
150d9661cdSTzanio# testbed platforms, in support of the nation's exascale computing imperative.
160d9661cdSTzanio
17*21ae6867ScamierjsCC ?= gcc
18e86995feScamierjs
19e86995feScamierjsNDEBUG ?=
20e86995feScamierjsLDFLAGS ?=
211b58aefaScamierjsLOADLIBES ?=
221b58aefaScamierjsTARGET_ARCH ?=
231b58aefaScamierjs
24*21ae6867Scamierjs# env variable OCCA_DIR should point to OCCA-1.0 branch
25f797d7b2Scamierjs
261b58aefaScamierjspwd = $(patsubst %/,%,$(dir $(abspath $(firstword $(MAKEFILE_LIST)))))
27e86995feScamierjs
28e86995feScamierjsSANTIZ = -fsanitize=address -fsanitize=undefined -fno-omit-frame-pointer
291b58aefaScamierjsCFLAGS = -std=c99 -Wall -Wextra -Wno-unused-parameter -fPIC -MMD -MP -march=native
304859b599SJed BrownCFLAGS += $(if $(NDEBUG),-O2,-g)
31*21ae6867ScamierjsCFLAGS += $(if $(NDEBUG),,)#$(SANTIZ))
321b58aefaScamierjsLDFLAGS += $(if $(NDEBUG),,)#$(SANTIZ))
33*21ae6867ScamierjsCPPFLAGS = -I.
34582447c9SJed BrownLDLIBS = -lm
3591b7489eSJed BrownOBJDIR := build
3691b7489eSJed BrownLIBDIR := .
3769762e1fScamierjsNPROCS := $(shell getconf _NPROCESSORS_ONLN)
3882985883ScamierjsMFLAGS := -j $(NPROCS) --warn-undefined-variables \
39*21ae6867Scamierjs			--no-print-directory --no-keep-going
4087e762eaSJed Brown
41bfa078e6SJed BrownPROVE ?= prove
425c719ab0SJed BrownDARWIN := $(filter Darwin,$(shell uname -s))
435c719ab0SJed BrownSO_EXT := $(if $(DARWIN),dylib,so)
449df38c42SVeselin Dobrev
4591b7489eSJed Brownlibceed := $(LIBDIR)/libceed.$(SO_EXT)
46bae89548SJed Brownlibceed.c := $(wildcard ceed*.c)
47746e9b11SJed Browntests.c   := $(sort $(wildcard tests/t[0-9][0-9]-*.c))
4891b7489eSJed Browntests     := $(tests.c:tests/%.c=$(OBJDIR)/%)
492c6ea02fSJed Brownexamples.c := $(sort $(wildcard examples/*.c))
5091b7489eSJed Brownexamples  := $(examples.c:examples/%.c=$(OBJDIR)/%)
51ae3cba82Scamierjs# backends/[ref & occa]
52ae3cba82Scamierjsref.c     := $(sort $(wildcard backends/ref/*.c))
53*21ae6867Scamierjsref.o     := $(ref.c:%.c=$(OBJDIR)/%.o)
54ae3cba82Scamierjsocca.c    := $(sort $(wildcard backends/occa/*.c))
55*21ae6867Scamierjsocca.o    := $(occa.c:%.c=$(OBJDIR)/%.o)
5682985883Scamierjs
57f797d7b2Scamierjs# Output color rules
5882985883ScamierjsCOLOR_OFFSET = 3
5982985883ScamierjsCOLOR = $(shell echo $(rule_path)|cksum|cut -b1-2)
6082985883Scamierjsrule_path = $(notdir $(patsubst %/,%,$(dir $<)))
6182985883Scamierjsrule_file = $(basename $(notdir $@))
6282985883Scamierjsrule_dumb = @echo -e $(rule_path)/$(rule_file)
63f797d7b2Scamierjsrule_term = @echo -e \\e[38\;5\;$(shell echo $(COLOR)+$(COLOR_OFFSET)|bc -l)\;1m\
6482985883Scamierjs             $(rule_path)\\033[m/\\033[\m$(rule_file)\\033[m
65f797d7b2Scamierjs# if TERM=dumb, use it, otherwise switch to the term one
66f797d7b2Scamierjsoutput = $(if $(TERM:dumb=),$(rule_term),$(rule_dumb))
6782985883Scamierjs
68*21ae6867ScamierjsV ?= 0
69*21ae6867Scamierjsifeq ($(V),0)
70*21ae6867Scamierjs  quiet = @printf "  %10s %s\n" "$1" "$@"; $($(1))
71*21ae6867Scamierjselse
72*21ae6867Scamierjs  quiet = $($(1))
73*21ae6867Scamierjsendif
74*21ae6867Scamierjs
759df38c42SVeselin Dobrev.SUFFIXES:
769df38c42SVeselin Dobrev.SUFFIXES: .c .o .d
7791b7489eSJed Brown.SECONDEXPANSION:		# to expand $$(@D)/.DIR
789df38c42SVeselin Dobrev
7991b7489eSJed Brown%/.DIR :
8091b7489eSJed Brown	@mkdir -p $(@D)
8191b7489eSJed Brown	@touch $@
8291b7489eSJed Brown
8391b7489eSJed Brown.PRECIOUS: %/.DIR
8491b7489eSJed Brown
85*21ae6867Scamierjsall dbg:; @$(MAKE) $(MFLAGS) $(libceed) $(tests)
8678b5556aScamierjsopt:;NDEBUG=1 $(MAKE) $(MFLAGS) $(libceed) $(tests)
8769762e1fScamierjs
884859b599SJed Brown
89*21ae6867Scamierjs$(libceed) : $(ref.o)
90*21ae6867Scamierjsifdef OCCA_DIR
91*21ae6867Scamierjs  $(libceed) : LDFLAGS += -L$(OCCA_DIR)/lib -Wl,-rpath,$(OCCA_DIR)/lib
92*21ae6867Scamierjs  $(libceed) : LDLIBS += -locca -lrt -ldl
93*21ae6867Scamierjs  $(libceed) : $(occa.o)
94*21ae6867Scamierjs  $(occa.o) : CFLAGS += -I$(OCCA_DIR)/include
95*21ae6867Scamierjsendif
96*21ae6867Scamierjs$(libceed) : $(libceed.c:%.c=$(OBJDIR)/%.o) $(ref.c:%.c=$(OBJDIR)/%.o)
97*21ae6867Scamierjs	$(call quiet,CC) $(LDFLAGS) -shared -o $@ $^ $(LDLIBS)
9891b7489eSJed Brown
99*21ae6867Scamierjs$(OBJDIR)/%.o : $(pwd)/%.c | $$(@D)/.DIR
100*21ae6867Scamierjs	$(call quiet,CC) $(CPPFLAGS) $(CFLAGS) -c -o $@ $^
101ae3cba82Scamierjs
102*21ae6867Scamierjs$(OBJDIR)/% : $(pwd)/tests/%.c | $$(@D)/.DIR
103*21ae6867Scamierjs	$(call quiet,CC) $(CPPFLAGS) $(CFLAGS) $(LDFLAGS) -o $@ $^ $(LDLIBS)
10478b5556aScamierjs
105*21ae6867Scamierjs$(OBJDIR)/%.o : $(pwd)/examples/%.c | $$(@D)/.DIR
106*21ae6867Scamierjs	$(call quiet,CC) $(CPPFLAGS) $(CFLAGS) -c -o $@ $^
10791b7489eSJed Brown
1082c6ea02fSJed Brown$(tests) $(examples) : $(libceed)
10991b7489eSJed Brown$(tests) $(examples) : LDFLAGS += -Wl,-rpath,$(LIBDIR) -L$(LIBDIR)
11091b7489eSJed Brown$(OBJDIR)/t% : tests/t%.c $(libceed)
11191b7489eSJed Brown$(OBJDIR)/ex% : examples/ex%.c $(libceed)
1124859b599SJed Brown
11391b7489eSJed Brownrun-t% : $(OBJDIR)/t%
114e86995feScamierjs	tests/tap.sh $(<:build/%=%)
1154859b599SJed Brown
11691b7489eSJed Browntest : $(tests:$(OBJDIR)/t%=run-t%)
117e86995feScamierjstst:;@$(MAKE) $(MFLAGS) test
1184859b599SJed Brown
119bfa078e6SJed Brownprove : $(tests)
120425fc99dScamierjs	$(PROVE) -j $(NPROCS) --exec 'tests/tap.sh' $(tests:$(OBJDIR)/%=%)
121bfa078e6SJed Brown
1222c6ea02fSJed Brownexamples : $(examples)
1232c6ea02fSJed Brown
1240dbfdfc5SJed Brown.PHONY: clean print test examples astyle
12569762e1fScamierjscln clean :
126d9c561c2Scamierjs	$(RM) *.o $(OBJDIR)/*.o *.d $(OBJDIR)/*.d $(libceed) $(tests)
127ae3cba82Scamierjs	$(RM) -r *.dSYM $(OBJDIR)/backends
1284859b599SJed Brown
1292f53e287Scamierjs### ASTYLE ###
1302f53e287ScamierjsASTYLE = astyle --options=.astylerc
131762a9394ScamierjsFORMAT_FILES = $(foreach dir,. tests examples occa,$(dir)/*.[ch])
1322f53e287Scamierjsstyle:
1332f53e287Scamierjs	@if ! $(ASTYLE) $(FORMAT_FILES) | grep Formatted; then\
1342f53e287Scamierjs	   echo "No source files were changed.";\
1352f53e287Scamierjs	fi
1360dbfdfc5SJed Brown
1374859b599SJed Brownprint :
1384859b599SJed Brown	@echo $(VAR)=$($(VAR))
139582447c9SJed Brown
1409df38c42SVeselin Dobrevprint-%:
1419df38c42SVeselin Dobrev	$(info [ variable name]: $*)
1429df38c42SVeselin Dobrev	$(info [        origin]: $(origin $*))
1439df38c42SVeselin Dobrev	$(info [         value]: $(value $*))
1449df38c42SVeselin Dobrev	$(info [expanded value]: $($*))
1459df38c42SVeselin Dobrev	$(info )
1469df38c42SVeselin Dobrev	@true
1479df38c42SVeselin Dobrev
148bae89548SJed Brown-include $(libceed.c:%.c=%.d) $(tests.c:%.c=%.d)
149