xref: /libCEED/Makefile (revision 7f5ff99b87bc55436f4e3200d8756984f43ee793)
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
25*7f5ff99bSVeselin DobrevOCCA_DIR ?= ../occa
26f797d7b2Scamierjs
271b58aefaScamierjspwd = $(patsubst %/,%,$(dir $(abspath $(firstword $(MAKEFILE_LIST)))))
28e86995feScamierjs
29e86995feScamierjsSANTIZ = -fsanitize=address -fsanitize=undefined -fno-omit-frame-pointer
301b58aefaScamierjsCFLAGS = -std=c99 -Wall -Wextra -Wno-unused-parameter -fPIC -MMD -MP -march=native
314859b599SJed BrownCFLAGS += $(if $(NDEBUG),-O2,-g)
3221ae6867ScamierjsCFLAGS += $(if $(NDEBUG),,)#$(SANTIZ))
331b58aefaScamierjsLDFLAGS += $(if $(NDEBUG),,)#$(SANTIZ))
3421ae6867ScamierjsCPPFLAGS = -I.
35582447c9SJed BrownLDLIBS = -lm
3691b7489eSJed BrownOBJDIR := build
3791b7489eSJed BrownLIBDIR := .
3869762e1fScamierjsNPROCS := $(shell getconf _NPROCESSORS_ONLN)
3982985883ScamierjsMFLAGS := -j $(NPROCS) --warn-undefined-variables \
4021ae6867Scamierjs			--no-print-directory --no-keep-going
4187e762eaSJed Brown
42bfa078e6SJed BrownPROVE ?= prove
435c719ab0SJed BrownDARWIN := $(filter Darwin,$(shell uname -s))
445c719ab0SJed BrownSO_EXT := $(if $(DARWIN),dylib,so)
459df38c42SVeselin Dobrev
4691b7489eSJed Brownlibceed := $(LIBDIR)/libceed.$(SO_EXT)
47bae89548SJed Brownlibceed.c := $(wildcard ceed*.c)
48746e9b11SJed Browntests.c   := $(sort $(wildcard tests/t[0-9][0-9]-*.c))
4991b7489eSJed Browntests     := $(tests.c:tests/%.c=$(OBJDIR)/%)
502c6ea02fSJed Brownexamples.c := $(sort $(wildcard examples/*.c))
5191b7489eSJed Brownexamples  := $(examples.c:examples/%.c=$(OBJDIR)/%)
52ae3cba82Scamierjs# backends/[ref & occa]
53ae3cba82Scamierjsref.c     := $(sort $(wildcard backends/ref/*.c))
5421ae6867Scamierjsref.o     := $(ref.c:%.c=$(OBJDIR)/%.o)
55ae3cba82Scamierjsocca.c    := $(sort $(wildcard backends/occa/*.c))
5621ae6867Scamierjsocca.o    := $(occa.c:%.c=$(OBJDIR)/%.o)
5782985883Scamierjs
58f797d7b2Scamierjs# Output color rules
5982985883ScamierjsCOLOR_OFFSET = 3
6082985883ScamierjsCOLOR = $(shell echo $(rule_path)|cksum|cut -b1-2)
6182985883Scamierjsrule_path = $(notdir $(patsubst %/,%,$(dir $<)))
6282985883Scamierjsrule_file = $(basename $(notdir $@))
6382985883Scamierjsrule_dumb = @echo -e $(rule_path)/$(rule_file)
64f797d7b2Scamierjsrule_term = @echo -e \\e[38\;5\;$(shell echo $(COLOR)+$(COLOR_OFFSET)|bc -l)\;1m\
6582985883Scamierjs             $(rule_path)\\033[m/\\033[\m$(rule_file)\\033[m
66f797d7b2Scamierjs# if TERM=dumb, use it, otherwise switch to the term one
67f797d7b2Scamierjsoutput = $(if $(TERM:dumb=),$(rule_term),$(rule_dumb))
6882985883Scamierjs
6921ae6867ScamierjsV ?= 0
7021ae6867Scamierjsifeq ($(V),0)
7121ae6867Scamierjs  quiet = @printf "  %10s %s\n" "$1" "$@"; $($(1))
7221ae6867Scamierjselse
7321ae6867Scamierjs  quiet = $($(1))
7421ae6867Scamierjsendif
7521ae6867Scamierjs
769df38c42SVeselin Dobrev.SUFFIXES:
779df38c42SVeselin Dobrev.SUFFIXES: .c .o .d
7891b7489eSJed Brown.SECONDEXPANSION:		# to expand $$(@D)/.DIR
799df38c42SVeselin Dobrev
8091b7489eSJed Brown%/.DIR :
8191b7489eSJed Brown	@mkdir -p $(@D)
8291b7489eSJed Brown	@touch $@
8391b7489eSJed Brown
8491b7489eSJed Brown.PRECIOUS: %/.DIR
8591b7489eSJed Brown
8621ae6867Scamierjsall dbg:; @$(MAKE) $(MFLAGS) $(libceed) $(tests)
8778b5556aScamierjsopt:;NDEBUG=1 $(MAKE) $(MFLAGS) $(libceed) $(tests)
8869762e1fScamierjs
8921ae6867Scamierjs$(libceed) : $(ref.o)
90*7f5ff99bSVeselin Dobrevifneq ($(wildcard $(OCCA_DIR)/lib/libocca.*),)
9121ae6867Scamierjs  $(libceed) : LDFLAGS += -L$(OCCA_DIR)/lib -Wl,-rpath,$(OCCA_DIR)/lib
9221ae6867Scamierjs  $(libceed) : LDLIBS += -locca -lrt -ldl
9321ae6867Scamierjs  $(libceed) : $(occa.o)
9421ae6867Scamierjs  $(occa.o) : CFLAGS += -I$(OCCA_DIR)/include
9521ae6867Scamierjsendif
9621ae6867Scamierjs$(libceed) : $(libceed.c:%.c=$(OBJDIR)/%.o) $(ref.c:%.c=$(OBJDIR)/%.o)
9721ae6867Scamierjs	$(call quiet,CC) $(LDFLAGS) -shared -o $@ $^ $(LDLIBS)
9891b7489eSJed Brown
9921ae6867Scamierjs$(OBJDIR)/%.o : $(pwd)/%.c | $$(@D)/.DIR
1007697cb41Scamierjs	$(call quiet,CC) $(CPPFLAGS) $(CFLAGS) -c -o $@ $<
101ae3cba82Scamierjs
10221ae6867Scamierjs$(OBJDIR)/% : $(pwd)/tests/%.c | $$(@D)/.DIR
10321ae6867Scamierjs	$(call quiet,CC) $(CPPFLAGS) $(CFLAGS) $(LDFLAGS) -o $@ $^ $(LDLIBS)
10478b5556aScamierjs
10521ae6867Scamierjs$(OBJDIR)/%.o : $(pwd)/examples/%.c | $$(@D)/.DIR
1067697cb41Scamierjs	$(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
131e3df9412ScamierjsFORMAT_FILES = $(foreach dir,. tests examples backends/ref backends/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
14843fb898aSJed Brown-include $(libceed.c:%.c=build/%.d) $(tests.c:tests/%.c=build/%.d)
149