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 257f5ff99bSVeselin DobrevOCCA_DIR ?= ../occa 26f797d7b2Scamierjs 27e86995feScamierjsSANTIZ = -fsanitize=address -fsanitize=undefined -fno-omit-frame-pointer 281b58aefaScamierjsCFLAGS = -std=c99 -Wall -Wextra -Wno-unused-parameter -fPIC -MMD -MP -march=native 294859b599SJed BrownCFLAGS += $(if $(NDEBUG),-O2,-g) 3021ae6867ScamierjsCFLAGS += $(if $(NDEBUG),,)#$(SANTIZ)) 311b58aefaScamierjsLDFLAGS += $(if $(NDEBUG),,)#$(SANTIZ)) 32*6ea7c6c1SJed BrownCPPFLAGS = -I./include 33582447c9SJed BrownLDLIBS = -lm 3491b7489eSJed BrownOBJDIR := build 35*6ea7c6c1SJed BrownLIBDIR := lib 36*6ea7c6c1SJed Brown 3769762e1fScamierjsNPROCS := $(shell getconf _NPROCESSORS_ONLN) 3882985883ScamierjsMFLAGS := -j $(NPROCS) --warn-undefined-variables \ 3921ae6867Scamierjs --no-print-directory --no-keep-going 4087e762eaSJed Brown 41bfa078e6SJed BrownPROVE ?= prove 423a1ec3cdSJed BrownPROVE_OPTS ?= -j $(NPROCS) 435c719ab0SJed BrownDARWIN := $(filter Darwin,$(shell uname -s)) 445c719ab0SJed BrownSO_EXT := $(if $(DARWIN),dylib,so) 459df38c42SVeselin Dobrev 46*6ea7c6c1SJed Brownceed.pc := $(LIBDIR)/pkgconfig/ceed.pc 4791b7489eSJed Brownlibceed := $(LIBDIR)/libceed.$(SO_EXT) 48bae89548SJed Brownlibceed.c := $(wildcard ceed*.c) 49746e9b11SJed Browntests.c := $(sort $(wildcard tests/t[0-9][0-9]-*.c)) 5091b7489eSJed Browntests := $(tests.c:tests/%.c=$(OBJDIR)/%) 512c6ea02fSJed Brownexamples.c := $(sort $(wildcard examples/*.c)) 5291b7489eSJed Brownexamples := $(examples.c:examples/%.c=$(OBJDIR)/%) 53ae3cba82Scamierjs# backends/[ref & occa] 54ae3cba82Scamierjsref.c := $(sort $(wildcard backends/ref/*.c)) 5521ae6867Scamierjsref.o := $(ref.c:%.c=$(OBJDIR)/%.o) 56ae3cba82Scamierjsocca.c := $(sort $(wildcard backends/occa/*.c)) 5721ae6867Scamierjsocca.o := $(occa.c:%.c=$(OBJDIR)/%.o) 5882985883Scamierjs 599bdc3d68Scamierjs# Output using the 216-color rules mode 6018a724fcScamierjsrule_file = $(notdir $(1)) 6118a724fcScamierjsrule_path = $(patsubst %/,%,$(dir $(1))) 6218a724fcScamierjslast_path = $(notdir $(patsubst %/,%,$(dir $(1)))) 633c5d0cdfSJed Brownansicolor = $(shell echo $(call last_path,$(1)) | cksum | cut -b1-2 | xargs -IS expr 2 \* S + 17) 64abb87f81Scamierjsemacs_out = @printf " %10s %s/%s\n" $(1) $(call rule_path,$(2)) $(call rule_file,$(2)) 65abb87f81Scamierjscolor_out = @if [ -t 1 ]; then \ 6618a724fcScamierjs printf " %10s \033[38;5;%d;1m%s\033[m/%s\n" \ 673c5d0cdfSJed Brown $(1) $(call ansicolor,$(2)) \ 6818a724fcScamierjs $(call rule_path,$(2)) $(call rule_file,$(2)); else \ 6918a724fcScamierjs printf " %10s %s\n" $(1) $(2); fi 70abb87f81Scamierjs# if TERM=dumb, use it, otherwise switch to the term one 71abb87f81Scamierjsoutput = $(if $(TERM:dumb=),$(call color_out,$1,$2),$(call emacs_out,$1,$2)) 72abb87f81Scamierjs 739bdc3d68Scamierjs# if V is set to non-nil, turn the verbose mode 7418a724fcScamierjsquiet = $(if $(V),$($(1)),$(call output,$1,$@);$($(1))) 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 86*6ea7c6c1SJed Brownthis: $(libceed) $(ceed.pc) 879bdc3d68Scamierjsall:;@$(MAKE) $(MFLAGS) V=$(V) this 880e439e50SJed Brown 89cbc56ef6SVeselin Dobrev$(libceed) : LDFLAGS += $(if $(DARWIN), -install_name $(abspath $(libceed))) 9069762e1fScamierjs 9121ae6867Scamierjs$(libceed) : $(ref.o) 927f5ff99bSVeselin Dobrevifneq ($(wildcard $(OCCA_DIR)/lib/libocca.*),) 93fc377ca6SJed Brown $(libceed) : LDFLAGS += -L$(OCCA_DIR)/lib -Wl,-rpath,$(abspath $(OCCA_DIR)/lib) 941a5c4436SJean-Sylvain Camier $(libceed) : LDLIBS += -locca #-lrt -ldl 9521ae6867Scamierjs $(libceed) : $(occa.o) 9621ae6867Scamierjs $(occa.o) : CFLAGS += -I$(OCCA_DIR)/include 9721ae6867Scamierjsendif 98*6ea7c6c1SJed Brown$(libceed) : $(libceed.c:%.c=$(OBJDIR)/%.o) | $$(@D)/.DIR 9921ae6867Scamierjs $(call quiet,CC) $(LDFLAGS) -shared -o $@ $^ $(LDLIBS) 10091b7489eSJed Brown 101b5b03409SJed Brown$(OBJDIR)/%.o : %.c | $$(@D)/.DIR 102b5b03409SJed Brown $(call quiet,CC) $(CPPFLAGS) $(CFLAGS) -c -o $@ $(abspath $<) 103ae3cba82Scamierjs 104b5b03409SJed Brown$(OBJDIR)/% : tests/%.c | $$(@D)/.DIR 105b5b03409SJed Brown $(call quiet,CC) $(CPPFLAGS) $(CFLAGS) $(LDFLAGS) -o $@ $(abspath $<) -lceed $(LDLIBS) 10678b5556aScamierjs 107efef47cdSJed Brown$(OBJDIR)/% : examples/%.c | $$(@D)/.DIR 108efef47cdSJed Brown $(call quiet,CC) $(CPPFLAGS) $(CFLAGS) $(LDFLAGS) -o $@ $(abspath $<) -lceed $(LDLIBS) 10991b7489eSJed Brown 1102c6ea02fSJed Brown$(tests) $(examples) : $(libceed) 111fc377ca6SJed Brown$(tests) $(examples) : LDFLAGS += -Wl,-rpath,$(abspath $(LIBDIR)) -L$(LIBDIR) 11291b7489eSJed Brown$(OBJDIR)/t% : tests/t%.c $(libceed) 11391b7489eSJed Brown$(OBJDIR)/ex% : examples/ex%.c $(libceed) 1144859b599SJed Brown 115dad465e7SJed Brownrun-% : $(OBJDIR)/% 116b5b03409SJed Brown @tests/tap.sh $(<:build/%=%) 1174859b599SJed Brown 118dad465e7SJed Browntest : $(tests:$(OBJDIR)/%=run-%) $(examples:$(OBJDIR)/%=run-%) 1194859b599SJed Brown 120dad465e7SJed Brownprove : $(tests) $(examples) 121dad465e7SJed Brown $(PROVE) $(PROVE_OPTS) --exec 'tests/tap.sh' $(tests:$(OBJDIR)/%=%) $(examples:$(OBJDIR)/%=%) 122bfa078e6SJed Brown 1232c6ea02fSJed Brownexamples : $(examples) 1242c6ea02fSJed Brown 125*6ea7c6c1SJed Brown$(ceed.pc) : pkgconfig-prefix = $(abspath .) 126*6ea7c6c1SJed Brown%/ceed.pc : ceed.pc.template | $$(@D)/.DIR 127*6ea7c6c1SJed Brown @sed "s:%prefix%:$(pkgconfig-prefix):" $< > $@ 1280e439e50SJed Brown 1299bdc3d68Scamierjs.PHONY: all cln clean print test tst examples astyle 1306e5d1fd9Scamierjscln clean : 131*6ea7c6c1SJed Brown $(RM) *.o *.d $(libceed) 132*6ea7c6c1SJed Brown $(RM) -r *.dSYM $(OBJDIR) $(LIBDIR)/pkgconfig 133e12c42aaSVeselin Dobrev $(MAKE) -C examples clean 134f3ea3031SVeselin Dobrev $(MAKE) -C examples/mfem clean 1354859b599SJed Brown 1360dbfdfc5SJed Brownastyle : 1374e3516aeSJed Brown astyle --style=google --indent=spaces=2 --max-code-length=80 \ 1380dbfdfc5SJed Brown --keep-one-line-statements --keep-one-line-blocks --lineend=linux \ 139746e9b11SJed Brown --suffix=none --preserve-date --formatted \ 140ea474a52STzanio *.[ch] tests/*.[ch] backends/*/*.[ch] examples/*.[ch] examples/mfem/*.[ch]pp 1410dbfdfc5SJed Brown 1424859b599SJed Brownprint : 1434859b599SJed Brown @echo $(VAR)=$($(VAR)) 144582447c9SJed Brown 1459df38c42SVeselin Dobrevprint-%: 1469df38c42SVeselin Dobrev $(info [ variable name]: $*) 1479df38c42SVeselin Dobrev $(info [ origin]: $(origin $*)) 1489df38c42SVeselin Dobrev $(info [ value]: $(value $*)) 1499df38c42SVeselin Dobrev $(info [expanded value]: $($*)) 1509df38c42SVeselin Dobrev $(info ) 1519df38c42SVeselin Dobrev @true 1529df38c42SVeselin Dobrev 15343fb898aSJed Brown-include $(libceed.c:%.c=build/%.d) $(tests.c:tests/%.c=build/%.d) 154