xref: /libCEED/Makefile (revision 7697cb4195838e6e4258d9aba3df78853e4b47c5)
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
1721ae6867ScamierjsCC ?= gcc
18e86995feScamierjs
19e86995feScamierjsNDEBUG ?=
20e86995feScamierjsLDFLAGS ?=
211b58aefaScamierjsLOADLIBES ?=
221b58aefaScamierjsTARGET_ARCH ?=
231b58aefaScamierjs
2421ae6867Scamierjs# 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)
3121ae6867ScamierjsCFLAGS += $(if $(NDEBUG),,)#$(SANTIZ))
321b58aefaScamierjsLDFLAGS += $(if $(NDEBUG),,)#$(SANTIZ))
3321ae6867ScamierjsCPPFLAGS = -I.
34582447c9SJed BrownLDLIBS = -lm
3591b7489eSJed BrownOBJDIR := build
3691b7489eSJed BrownLIBDIR := .
3769762e1fScamierjsNPROCS := $(shell getconf _NPROCESSORS_ONLN)
3882985883ScamierjsMFLAGS := -j $(NPROCS) --warn-undefined-variables \
3921ae6867Scamierjs			--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))
5321ae6867Scamierjsref.o     := $(ref.c:%.c=$(OBJDIR)/%.o)
54ae3cba82Scamierjsocca.c    := $(sort $(wildcard backends/occa/*.c))
5521ae6867Scamierjsocca.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
6821ae6867ScamierjsV ?= 0
6921ae6867Scamierjsifeq ($(V),0)
7021ae6867Scamierjs  quiet = @printf "  %10s %s\n" "$1" "$@"; $($(1))
7121ae6867Scamierjselse
7221ae6867Scamierjs  quiet = $($(1))
7321ae6867Scamierjsendif
7421ae6867Scamierjs
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
8521ae6867Scamierjsall dbg:; @$(MAKE) $(MFLAGS) $(libceed) $(tests)
8678b5556aScamierjsopt:;NDEBUG=1 $(MAKE) $(MFLAGS) $(libceed) $(tests)
8769762e1fScamierjs
8821ae6867Scamierjs$(libceed) : $(ref.o)
8921ae6867Scamierjsifdef OCCA_DIR
9021ae6867Scamierjs  $(libceed) : LDFLAGS += -L$(OCCA_DIR)/lib -Wl,-rpath,$(OCCA_DIR)/lib
9121ae6867Scamierjs  $(libceed) : LDLIBS += -locca -lrt -ldl
9221ae6867Scamierjs  $(libceed) : $(occa.o)
9321ae6867Scamierjs  $(occa.o) : CFLAGS += -I$(OCCA_DIR)/include
9421ae6867Scamierjsendif
9521ae6867Scamierjs$(libceed) : $(libceed.c:%.c=$(OBJDIR)/%.o) $(ref.c:%.c=$(OBJDIR)/%.o)
9621ae6867Scamierjs	$(call quiet,CC) $(LDFLAGS) -shared -o $@ $^ $(LDLIBS)
9791b7489eSJed Brown
9821ae6867Scamierjs$(OBJDIR)/%.o : $(pwd)/%.c | $$(@D)/.DIR
99*7697cb41Scamierjs	$(call quiet,CC) $(CPPFLAGS) $(CFLAGS) -c -o $@ $<
100ae3cba82Scamierjs
10121ae6867Scamierjs$(OBJDIR)/% : $(pwd)/tests/%.c | $$(@D)/.DIR
10221ae6867Scamierjs	$(call quiet,CC) $(CPPFLAGS) $(CFLAGS) $(LDFLAGS) -o $@ $^ $(LDLIBS)
10378b5556aScamierjs
10421ae6867Scamierjs$(OBJDIR)/%.o : $(pwd)/examples/%.c | $$(@D)/.DIR
105*7697cb41Scamierjs	$(call quiet,CC) $(CPPFLAGS) $(CFLAGS) -c -o $@ $<
10691b7489eSJed Brown
1072c6ea02fSJed Brown$(tests) $(examples) : $(libceed)
10891b7489eSJed Brown$(tests) $(examples) : LDFLAGS += -Wl,-rpath,$(LIBDIR) -L$(LIBDIR)
10991b7489eSJed Brown$(OBJDIR)/t% : tests/t%.c $(libceed)
11091b7489eSJed Brown$(OBJDIR)/ex% : examples/ex%.c $(libceed)
1114859b599SJed Brown
11291b7489eSJed Brownrun-t% : $(OBJDIR)/t%
113e86995feScamierjs	tests/tap.sh $(<:build/%=%)
1144859b599SJed Brown
11591b7489eSJed Browntest : $(tests:$(OBJDIR)/t%=run-t%)
116e86995feScamierjstst:;@$(MAKE) $(MFLAGS) test
1174859b599SJed Brown
118bfa078e6SJed Brownprove : $(tests)
119425fc99dScamierjs	$(PROVE) -j $(NPROCS) --exec 'tests/tap.sh' $(tests:$(OBJDIR)/%=%)
120bfa078e6SJed Brown
1212c6ea02fSJed Brownexamples : $(examples)
1222c6ea02fSJed Brown
1230dbfdfc5SJed Brown.PHONY: clean print test examples astyle
12469762e1fScamierjscln clean :
125d9c561c2Scamierjs	$(RM) *.o $(OBJDIR)/*.o *.d $(OBJDIR)/*.d $(libceed) $(tests)
126ae3cba82Scamierjs	$(RM) -r *.dSYM $(OBJDIR)/backends
1274859b599SJed Brown
1282f53e287Scamierjs### ASTYLE ###
1292f53e287ScamierjsASTYLE = astyle --options=.astylerc
130762a9394ScamierjsFORMAT_FILES = $(foreach dir,. tests examples occa,$(dir)/*.[ch])
1312f53e287Scamierjsstyle:
1322f53e287Scamierjs	@if ! $(ASTYLE) $(FORMAT_FILES) | grep Formatted; then\
1332f53e287Scamierjs	   echo "No source files were changed.";\
1342f53e287Scamierjs	fi
1350dbfdfc5SJed Brown
1364859b599SJed Brownprint :
1374859b599SJed Brown	@echo $(VAR)=$($(VAR))
138582447c9SJed Brown
1399df38c42SVeselin Dobrevprint-%:
1409df38c42SVeselin Dobrev	$(info [ variable name]: $*)
1419df38c42SVeselin Dobrev	$(info [        origin]: $(origin $*))
1429df38c42SVeselin Dobrev	$(info [         value]: $(value $*))
1439df38c42SVeselin Dobrev	$(info [expanded value]: $($*))
1449df38c42SVeselin Dobrev	$(info )
1459df38c42SVeselin Dobrev	@true
1469df38c42SVeselin Dobrev
14743fb898aSJed Brown-include $(libceed.c:%.c=build/%.d) $(tests.c:tests/%.c=build/%.d)
148