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