xref: /libCEED/Makefile (revision 4c4eae0c6458f4f5e2e2f29cbd7577672e4fdd9c)
19bca2fcfSJed Brown# Copyright (c) 2017-2022, Lawrence Livermore National Security, LLC and other CEED contributors.
29bca2fcfSJed Brown# All Rights Reserved. See the top-level LICENSE and NOTICE files for details.
30d9661cdSTzanio#
49bca2fcfSJed Brown# SPDX-License-Identifier: BSD-2-Clause
50d9661cdSTzanio#
69bca2fcfSJed Brown# This file is part of CEED:  http://github.com/ceed
70d9661cdSTzanio
8b0ab70ddSJed BrownCONFIG ?= config.mk
9b0ab70ddSJed Brown-include $(CONFIG)
10777ff853SJeremy L ThompsonCOMMON ?= common.mk
11777ff853SJeremy L Thompson-include $(COMMON)
121571c99dSValeria Barra
13dc753d40SJed Brownifeq (,$(filter-out undefined default,$(origin CC)))
146ed738d9SJed Brown  CC = gcc
15dc753d40SJed Brownendif
16241a4b83SYohannifeq (,$(filter-out undefined default,$(origin CXX)))
17241a4b83SYohann  CXX = g++
18241a4b83SYohannendif
19dc753d40SJed Brownifeq (,$(filter-out undefined default,$(origin FC)))
2081c9eb91SStan Tomov  FC = gfortran
21dc753d40SJed Brownendif
22241a4b83SYohannifeq (,$(filter-out undefined default,$(origin LINK)))
23241a4b83SYohann  LINK = $(CC)
24241a4b83SYohannendif
251d013790SJed Brownifeq (,$(filter-out undefined default,$(origin AR)))
261d013790SJed Brown  AR = ar
271d013790SJed Brownendif
281d013790SJed Brownifeq (,$(filter-out undefined default,$(origin ARFLAGS)))
291d013790SJed Brown  ARFLAGS = crD
301d013790SJed Brownendif
31196a75e4SJed BrownNVCC ?= $(CUDA_DIR)/bin/nvcc
323c83ce1dSJed BrownNVCC_CXX ?= $(CXX)
33023b8a51Sabdelfattah83HIPCC ?= $(ROCM_DIR)/bin/hipcc
34bd882c8aSJames WrightSYCLCXX ?= $(CXX)
351d013790SJed BrownSED ?= sed
360bd9ac94SJed Brownifneq ($(EMSCRIPTEN),)
370bd9ac94SJed Brown  STATIC = 1
380bd9ac94SJed Brown  EXE_SUFFIX = .wasm
390bd9ac94SJed Brown  EM_LDFLAGS = -s TOTAL_MEMORY=256MB
400bd9ac94SJed Brownendif
41e86995feScamierjs
423b56482dScamierjs# ASAN must be left empty if you don't want to use it
430a7eccc5ScamierjsASAN ?=
446850bcb5Scamierjs
453696039aSJed Brown# These are the values automatically detected here in the makefile. They are
463696039aSJed Brown# augmented with LDFLAGS and LDLIBS from the environment/passed by command line,
473696039aSJed Brown# if any. If the user sets CEED_LDFLAGS or CEED_LDLIBS, they are used *instead
483696039aSJed Brown# of* what we populate here (thus that's advanced usage and not recommended).
493696039aSJed BrownCEED_LDFLAGS ?=
503696039aSJed BrownCEED_LDLIBS ?=
517c735608SJed Brown
5232d74c32SThilina RathnayakeUNDERSCORE ?= 1
531b58aefaScamierjs
548df0376fSJeremy L Thompson# Verbose mode, V or VERBOSE
558df0376fSJeremy L ThompsonV ?= $(VERBOSE)
568df0376fSJeremy L Thompson
57f9fa8c39Sjeremylt# MFEM_DIR env variable should point to sibling directory
58bf3e26f6SVeselin Dobrevifneq ($(wildcard ../mfem/libmfem.*),)
599ba53df8Sjeremylt  MFEM_DIR ?= ../mfem
60f9fa8c39Sjeremyltendif
61f9fa8c39Sjeremylt
624d1cd9fcSJeremy L Thompson# NEK5K_DIR env variable should point to sibling directory
634d1cd9fcSJeremy L Thompsonifneq ($(wildcard ../Nek5000/*),)
6486a4271fSThilina Rathnayake  NEK5K_DIR ?= $(abspath ../Nek5000)
654d1cd9fcSJeremy L Thompsonendif
6686a4271fSThilina Rathnayakeexport NEK5K_DIR
6786a4271fSThilina RathnayakeMPI ?= 1
6886a4271fSThilina Rathnayake
6986a4271fSThilina Rathnayake# CEED_DIR env for NEK5K testing
7086a4271fSThilina Rathnayakeexport CEED_DIR = $(abspath .)
714d1cd9fcSJeremy L Thompson
720be03a92SJeremy L Thompson# XSMM_DIR env variable should point to XSMM main (github.com/hfp/libxsmm)
738d713cf6SjeremyltXSMM_DIR ?= ../libxsmm
748d713cf6Sjeremylt
750be03a92SJeremy L Thompson# OCCA_DIR env variable should point to OCCA main (github.com/libocca/occa)
760be03a92SJeremy L ThompsonOCCA_DIR ?= ../occa/install
77f797d7b2Scamierjs
785a9ca9adSVeselin Dobrev# env variable MAGMA_DIR can be used too
79ab352fbeSnbeamsMAGMA_DIR ?= ../magma
8096f2f974SJed Brown
81952aa241SJed Brown# Often /opt/cuda or /usr/local/cuda, but sometimes present on machines that don't support CUDA
8296f2f974SJed BrownCUDA_DIR  ?=
83bd057117SnbeamsCUDA_ARCH ?=
8496f2f974SJed Brown
8596f2f974SJed Brown# Often /opt/rocm, but sometimes present on machines that don't support HIP
86023b8a51Sabdelfattah83ROCM_DIR ?=
87bd057117SnbeamsHIP_ARCH ?=
8882b77998SStan Tomov
892f4d9adbSJeremy L Thompson# Check for PETSc in ../petsc
902f4d9adbSJeremy L Thompsonifneq ($(wildcard ../petsc/lib/libpetsc.*),)
912f4d9adbSJeremy L Thompson  PETSC_DIR ?= ../petsc
922f4d9adbSJeremy L Thompsonendif
932f4d9adbSJeremy L Thompson
94bf000209STzanio# Warning: SANTIZ options still don't run with /gpu/occa
9512123fd5Scamierjs# export LSAN_OPTIONS=suppressions=.asanignore
96fb651866SJed BrownAFLAGS ?= -fsanitize=address #-fsanitize=undefined -fno-omit-frame-pointer
9732d74c32SThilina Rathnayake
988ca0bbaeSjeremylt# Note: Intel oneAPI C/C++ compiler is now icx/icpx
99*4c4eae0cSSebastian GrimbergCC_VENDOR := $(firstword $(filter gcc (GCC) clang icc icc_orig oneAPI XL emcc,$(subst -, ,$(shell $(CC) --version))))
100*4c4eae0cSSebastian GrimbergCC_VENDOR := $(subst (GCC),gcc,$(subst icc_orig,icc,$(CC_VENDOR)))
1010be03a92SJeremy L ThompsonFC_VENDOR := $(if $(FC),$(firstword $(filter GNU ifort ifx XL,$(shell $(FC) --version 2>&1 || $(FC) -qversion))))
10213d950b4SJed Brown
10313d950b4SJed Brown# Default extra flags by vendor
10413d950b4SJed BrownMARCHFLAG.gcc           := -march=native
10513d950b4SJed BrownMARCHFLAG.clang         := $(MARCHFLAG.gcc)
10613d950b4SJed BrownMARCHFLAG.icc           :=
1070be03a92SJeremy L ThompsonMARCHFLAG.oneAPI        := $(MARCHFLAG.clang)
10813d950b4SJed BrownOMP_SIMD_FLAG.gcc       := -fopenmp-simd
10913d950b4SJed BrownOMP_SIMD_FLAG.clang     := $(OMP_SIMD_FLAG.gcc)
11013d950b4SJed BrownOMP_SIMD_FLAG.icc       := -qopenmp-simd
11158c07c4fSSebastian GrimbergOMP_SIMD_FLAG.oneAPI    := $(OMP_SIMD_FLAG.icc)
11258c07c4fSSebastian GrimbergOMP_FLAG.gcc            := -fopenmp
11358c07c4fSSebastian GrimbergOMP_FLAG.clang          := $(OMP_FLAG.gcc)
11458c07c4fSSebastian GrimbergOMP_FLAG.icc            := -qopenmp
11558c07c4fSSebastian GrimbergOMP_FLAG.oneAPI         := $(OMP_FLAG.icc)
116bd882c8aSJames WrightSYCL_FLAG.gcc           :=
117bd882c8aSJames WrightSYCL_FLAG.clang         := -fsycl
118bd882c8aSJames WrightSYCL_FLAG.icc           :=
1196ca0f394SUmesh UnnikrishnanSYCL_FLAG.oneAPI        := -fsycl -fno-sycl-id-queries-fit-in-int
1200bd9ac94SJed BrownOPT.gcc                 := -g -ffp-contract=fast
12113d950b4SJed BrownOPT.clang               := $(OPT.gcc)
12258c07c4fSSebastian GrimbergOPT.icc                 := $(OPT.gcc)
1230be03a92SJeremy L ThompsonOPT.oneAPI              := $(OPT.clang)
1240bd9ac94SJed BrownOPT.emcc                :=
1250bd9ac94SJed BrownCFLAGS.gcc              := $(if $(STATIC),,-fPIC) -std=c99 -Wall -Wextra -Wno-unused-parameter -MMD -MP
1268b45a169SnbeamsCFLAGS.clang            := $(CFLAGS.gcc)
12713d950b4SJed BrownCFLAGS.icc              := $(CFLAGS.gcc)
1280be03a92SJeremy L ThompsonCFLAGS.oneAPI           := $(CFLAGS.clang)
1290bd9ac94SJed BrownCFLAGS.XL               := $(if $(STATIC),,-qpic) -MMD
1300bd9ac94SJed BrownCFLAGS.emcc             := $(CFLAGS.clang)
1310bd9ac94SJed BrownCXXFLAGS.gcc            := $(if $(STATIC),,-fPIC) -std=c++11 -Wall -Wextra -Wno-unused-parameter -MMD -MP
1328b45a169SnbeamsCXXFLAGS.clang          := $(CXXFLAGS.gcc)
13313d950b4SJed BrownCXXFLAGS.icc            := $(CXXFLAGS.gcc)
1340be03a92SJeremy L ThompsonCXXFLAGS.oneAPI         := $(CXXFLAGS.clang)
1350bd9ac94SJed BrownCXXFLAGS.XL             := $(if $(STATIC),,-qpic) -std=c++11 -MMD
1360bd9ac94SJed BrownCXXFLAGS.emcc           := $(CXXFLAGS.clang)
1370bd9ac94SJed BrownFFLAGS.GNU              := $(if $(STATIC),,-fPIC) -cpp -Wall -Wextra -Wno-unused-parameter -Wno-unused-dummy-argument -MMD -MP
1380bd9ac94SJed BrownFFLAGS.ifort            := $(if $(STATIC),,-fPIC) -cpp
1390be03a92SJeremy L ThompsonFFLAGS.ifx              := $(FFLAGS.ifort)
1400bd9ac94SJed BrownFFLAGS.XL               := $(if $(STATIC),,-qpic) -ffree-form -qpreprocess -qextname -MMD
141cf4a56afSJed Brown
142d9bc9eefSJed Brown# This check works with compilers that use gcc and clang.  It fails with some
143d9bc9eefSJed Brown# compilers; e.g., xlc apparently ignores all options when -E is passed, thus
144d9bc9eefSJed Brown# succeeds with any flags.  Users can pass MARCHFLAG=... if desired.
145d9bc9eefSJed Browncc_check_flag = $(shell $(CC) -E -Werror $(1) -x c /dev/null > /dev/null 2>&1 && echo 1)
14613d950b4SJed BrownMARCHFLAG := $(MARCHFLAG.$(CC_VENDOR))
147f766a8abSJed BrownMARCHFLAG := $(if $(call cc_check_flag,$(MARCHFLAG)),$(MARCHFLAG),-mcpu=native)
148f766a8abSJed BrownMARCHFLAG := $(if $(call cc_check_flag,$(MARCHFLAG)),$(MARCHFLAG))
149b9c05c73SJed Brown
15013d950b4SJed BrownOMP_SIMD_FLAG := $(OMP_SIMD_FLAG.$(CC_VENDOR))
151f766a8abSJed BrownOMP_SIMD_FLAG := $(if $(call cc_check_flag,$(OMP_SIMD_FLAG)),$(OMP_SIMD_FLAG))
152cf4a56afSJed Brown
1532c2ea1dbSJeremy L Thompson# Error checking flags
1542c2ea1dbSJeremy L ThompsonPEDANTIC      ?=
1552c2ea1dbSJeremy L ThompsonPEDANTICFLAGS ?= -Werror -pedantic
1562c2ea1dbSJeremy L Thompson
1570bd9ac94SJed BrownOPT    ?= -O $(MARCHFLAG) $(OPT.$(CC_VENDOR)) $(OMP_SIMD_FLAG)
1582c2ea1dbSJeremy L ThompsonCFLAGS ?= $(OPT) $(CFLAGS.$(CC_VENDOR)) $(if $(PEDANTIC),$(PEDANTICFLAGS))
1592c2ea1dbSJeremy L ThompsonCXXFLAGS ?= $(OPT) $(CXXFLAGS.$(CC_VENDOR)) $(if $(PEDANTIC),$(PEDANTICFLAGS))
16058c07c4fSSebastian GrimbergFFLAGS ?= $(OPT) $(FFLAGS.$(FC_VENDOR))
1611d013790SJed BrownLIBCXX ?= -lstdc++
162b0ab70ddSJed BrownNVCCFLAGS ?= -ccbin $(CXX) -Xcompiler "$(OPT)" -Xcompiler -fPIC
163bd057117Snbeamsifneq ($(CUDA_ARCH),)
164bd057117Snbeams  NVCCFLAGS += -arch=$(CUDA_ARCH)
165bd057117Snbeamsendif
166b3c5430cSnbeamsHIPCCFLAGS ?= $(filter-out $(OMP_SIMD_FLAG),$(OPT)) -fPIC -munsafe-fp-atomics
167bd057117Snbeamsifneq ($(HIP_ARCH),)
168bd057117Snbeams  HIPCCFLAGS += --amdgpu-target=$(HIP_ARCH)
169bd057117Snbeamsendif
170bd882c8aSJames WrightSYCL_FLAG := $(SYCL_FLAG.$(CC_VENDOR))
171bd882c8aSJames WrightSYCLFLAGS ?= $(SYCL_FLAG) -fPIC -std=c++17 $(filter-out -std=c++11,$(CXXFLAGS)) $(filter-out $(OMP_SIMD_FLAG),$(OPT))
17258c07c4fSSebastian Grimberg
17358c07c4fSSebastian GrimbergOPENMP ?=
17458c07c4fSSebastian Grimbergifneq ($(OPENMP),)
17558c07c4fSSebastian Grimberg  OMP_FLAG := $(OMP_FLAG.$(CC_VENDOR))
17658c07c4fSSebastian Grimberg  OMP_FLAG := $(if $(call cc_check_flag,$(OMP_FLAG)),$(OMP_FLAG))
17758c07c4fSSebastian Grimberg  CFLAGS += $(OMP_FLAG)
17858c07c4fSSebastian Grimberg  CEED_LDFLAGS += $(OMP_FLAG)
17958c07c4fSSebastian Grimbergendif
18032d74c32SThilina Rathnayake
181a6f4783aSJed Brownifeq ($(COVERAGE), 1)
182a6f4783aSJed Brown  CFLAGS += --coverage
183568410ffSJeremy L Thompson  CXXFLAGS += --coverage
1843696039aSJed Brown  CEED_LDFLAGS += --coverage
185a6f4783aSJed Brownendif
186a6f4783aSJed Brown
1875766aa57SJeremy L ThompsonCFLAGS += $(if $(ASAN),$(AFLAGS))
1884dd6f121ScamierjsFFLAGS += $(if $(ASAN),$(AFLAGS))
1893696039aSJed BrownCEED_LDFLAGS += $(if $(ASAN),$(AFLAGS))
19041a90898SJed BrownCPPFLAGS += -I./include
1913696039aSJed BrownCEED_LDLIBS = -lm
19291b7489eSJed BrownOBJDIR := build
19372fa462dSJed Brownfor_install := $(filter install,$(MAKECMDGOALS))
19472fa462dSJed BrownLIBDIR := $(if $(for_install),$(OBJDIR),lib)
19572fa462dSJed Brown
1966ea7c6c1SJed Brown
197d5217624SJed Brown# Installation variables
198d5217624SJed Brownprefix ?= /usr/local
199d5217624SJed Brownbindir = $(prefix)/bin
200d5217624SJed Brownlibdir = $(prefix)/lib
201d5217624SJed Brownincludedir = $(prefix)/include
202d5217624SJed Brownpkgconfigdir = $(libdir)/pkgconfig
203d5217624SJed BrownINSTALL = install
204d5217624SJed BrownINSTALL_PROGRAM = $(INSTALL)
205d5217624SJed BrownINSTALL_DATA = $(INSTALL) -m644
206d5217624SJed Brown
2073b56482dScamierjs# Get number of processors of the machine
20869762e1fScamierjsNPROCS := $(shell getconf _NPROCESSORS_ONLN)
2093b56482dScamierjs# prepare make options to run in parallel
21082985883ScamierjsMFLAGS := -j $(NPROCS) --warn-undefined-variables \
21121ae6867Scamierjs                       --no-print-directory --no-keep-going
21287e762eaSJed Brown
2138ec9d54bSJed BrownPYTHON ?= python3
214bfa078e6SJed BrownPROVE ?= prove
2153a1ec3cdSJed BrownPROVE_OPTS ?= -j $(NPROCS)
2165c719ab0SJed BrownDARWIN := $(filter Darwin,$(shell uname -s))
2175c719ab0SJed BrownSO_EXT := $(if $(DARWIN),dylib,so)
2189df38c42SVeselin Dobrev
2196ea7c6c1SJed Brownceed.pc := $(LIBDIR)/pkgconfig/ceed.pc
2201d013790SJed Brownlibceed.so := $(LIBDIR)/libceed.$(SO_EXT)
2211d013790SJed Brownlibceed.a := $(LIBDIR)/libceed.a
22278a9fcb6SJeremy L Thompsonlibceed := $(if $(STATIC),$(libceed.a),$(libceed.so))
2237e68d260SJed BrownCEED_LIBS = -lceed
22472fa462dSJed Brownlibceed.c := $(filter-out interface/ceed-cuda.c interface/ceed-hip.c interface/ceed-jit-source-root-$(if $(for_install),default,install).c, $(wildcard interface/ceed*.c backends/*.c gallery/*.c))
225288c0443SJeremy L Thompsongallery.c := $(wildcard gallery/*/ceed*.c)
226288c0443SJeremy L Thompsonlibceed.c += $(gallery.c)
2278e3e54ccSjeremyltlibceeds = $(libceed)
228265be9c8SjeremyltBACKENDS_BUILTIN := /cpu/self/ref/serial /cpu/self/ref/blocked /cpu/self/opt/serial /cpu/self/opt/blocked
229422b683aSjeremyltBACKENDS_MAKE := $(BACKENDS_BUILTIN)
230422b683aSjeremyltTEST_BACKENDS := /cpu/self/tmpl /cpu/self/tmpl/sub
231bf000209STzanio
232bf000209STzanio# Tests
23357c64913Sjeremylttests.c   := $(sort $(wildcard tests/t[0-9][0-9][0-9]-*.c))
23480a9ef05SNatalie Beamstests.f   := $(if $(FC),$(sort $(wildcard tests/t[0-9][0-9][0-9]-*.f90)))
235e3e35afdSJed Browntests     := $(tests.c:tests/%.c=$(OBJDIR)/%$(EXE_SUFFIX))
2363f3e7340Scamierjsctests    := $(tests)
237e3e35afdSJed Browntests     += $(tests.f:tests/%.f90=$(OBJDIR)/%$(EXE_SUFFIX))
23886a4271fSThilina Rathnayake# Examples
239182fbe45STzanioexamples.c := $(sort $(wildcard examples/ceed/*.c))
24080a9ef05SNatalie Beamsexamples.f := $(if $(FC),$(sort $(wildcard examples/ceed/*.f)))
241e3e35afdSJed Brownexamples  := $(examples.c:examples/ceed/%.c=$(OBJDIR)/%$(EXE_SUFFIX))
242e3e35afdSJed Brownexamples  += $(examples.f:examples/ceed/%.f=$(OBJDIR)/%$(EXE_SUFFIX))
24386a4271fSThilina Rathnayake# MFEM Examples
2442158b1b0Sjeremyltmfemexamples.cpp := $(sort $(wildcard examples/mfem/*.cpp))
24516c6c054SJed Brownmfemexamples  := $(mfemexamples.cpp:examples/mfem/%.cpp=$(OBJDIR)/mfem-%)
24686a4271fSThilina Rathnayake# Nek5K Examples
24786a4271fSThilina Rathnayakenekexamples  := $(OBJDIR)/nek-bps
24886a4271fSThilina Rathnayake# PETSc Examples
2496f87d196Sjeremyltpetscexamples.c := $(wildcard examples/petsc/*.c)
250e797ab98SJed Brownpetscexamples   := $(petscexamples.c:examples/petsc/%.c=$(OBJDIR)/petsc-%)
251ccaff030SJeremy L Thompson# Fluid Dynamics Examples
252ccaff030SJeremy L Thompsonfluidsexamples.c := $(sort $(wildcard examples/fluids/*.c))
253ccaff030SJeremy L Thompsonfluidsexamples  := $(fluidsexamples.c:examples/fluids/%.c=$(OBJDIR)/fluids-%)
254ccaff030SJeremy L Thompson# Solid Mechanics Examples
255ccaff030SJeremy L Thompsonsolidsexamples.c := $(sort $(wildcard examples/solids/*.c))
256ccaff030SJeremy L Thompsonsolidsexamples   := $(solidsexamples.c:examples/solids/%.c=$(OBJDIR)/solids-%)
257e797ab98SJed Brown
2588e3e54ccSjeremylt# Backends/[ref, blocked, memcheck, opt, avx, occa, magma]
259ae3cba82Scamierjsref.c          := $(sort $(wildcard backends/ref/*.c))
26089c6efa4Sjeremyltblocked.c      := $(sort $(wildcard backends/blocked/*.c))
26189c6efa4Sjeremyltceedmemcheck.c := $(sort $(wildcard backends/memcheck/*.c))
26289c6efa4Sjeremyltopt.c          := $(sort $(wildcard backends/opt/*.c))
26389c6efa4Sjeremyltavx.c          := $(sort $(wildcard backends/avx/*.c))
26489c6efa4Sjeremyltxsmm.c         := $(sort $(wildcard backends/xsmm/*.c))
2659f0427d9SYohanncuda.c         := $(sort $(wildcard backends/cuda/*.c))
266c9c2c079SJeremy L Thompsoncuda.cpp       := $(sort $(wildcard backends/cuda/*.cpp))
2677fcac036SJeremy L Thompsoncuda-ref.c     := $(sort $(wildcard backends/cuda-ref/*.c))
2687fcac036SJeremy L Thompsoncuda-ref.cpp   := $(sort $(wildcard backends/cuda-ref/*.cpp))
2697fcac036SJeremy L Thompsoncuda-ref.cu    := $(sort $(wildcard backends/cuda-ref/kernels/*.cu))
270c532df63SYohanncuda-shared.c  := $(sort $(wildcard backends/cuda-shared/*.c))
271b2573fe1SJeremy L Thompsoncuda-shared.cu := $(sort $(wildcard backends/cuda-shared/kernels/*.cu))
272241a4b83SYohanncuda-gen.c     := $(sort $(wildcard backends/cuda-gen/*.c))
273241a4b83SYohanncuda-gen.cpp   := $(sort $(wildcard backends/cuda-gen/*.cpp))
274b2573fe1SJeremy L Thompsoncuda-gen.cu    := $(sort $(wildcard backends/cuda-gen/kernels/*.cu))
2759647a07eSDavid Medinaocca.cpp       := $(sort $(shell find backends/occa -type f -name *.cpp))
276a07e8cf1SNatalie Beamsmagma.c        := $(sort $(wildcard backends/magma/*.c))
2772dc3fb5fSabdelfattah83magma.cpp      := $(sort $(wildcard backends/magma/*.cpp))
278969f2b10Snbeamsmagma.cu       := $(sort $(wildcard backends/magma/kernels/cuda/*.cu))
279969f2b10Snbeamsmagma.hip      := $(sort $(wildcard backends/magma/kernels/hip/*.hip.cpp))
28030f4f45fSnbeamship.c          := $(sort $(wildcard backends/hip/*.c))
281f0f820a0SJeremy L Thompsonhip.cpp        := $(sort $(wildcard backends/hip/*.cpp))
2827fcac036SJeremy L Thompsonhip-ref.c      := $(sort $(wildcard backends/hip-ref/*.c))
2837fcac036SJeremy L Thompsonhip-ref.cpp    := $(sort $(wildcard backends/hip-ref/*.cpp))
2847fcac036SJeremy L Thompsonhip-ref.hip    := $(sort $(wildcard backends/hip-ref/kernels/*.hip.cpp))
2857d8d0e25Snbeamship-shared.c   := $(sort $(wildcard backends/hip-shared/*.c))
2867d8d0e25Snbeamship-gen.c      := $(sort $(wildcard backends/hip-gen/*.c))
2877d8d0e25Snbeamship-gen.cpp    := $(sort $(wildcard backends/hip-gen/*.cpp))
288bd882c8aSJames Wrightsycl-core.cpp  := $(sort $(wildcard backends/sycl/*.sycl.cpp))
289bd882c8aSJames Wrightsycl-ref.cpp   := $(sort $(wildcard backends/sycl-ref/*.sycl.cpp))
290bd882c8aSJames Wrightsycl-shared.cpp:= $(sort $(wildcard backends/sycl-shared/*.sycl.cpp))
2916ca0f394SUmesh Unnikrishnansycl-gen.cpp   := $(sort $(wildcard backends/sycl-gen/*.sycl.cpp))
29282985883Scamierjs
293f150ce52SJed Brownhip-all.c := interface/ceed-hip.c $(hip.c) $(hip-ref.c) $(hip-shared.c) $(hip-gen.c)
294f150ce52SJed Brownhip-all.cpp := $(hip.cpp) $(hip-ref.cpp) $(hip-gen.cpp)
295f150ce52SJed Brown
296777ff853SJeremy L Thompson# Quiet, color output
297777ff853SJeremy L Thompsonquiet ?= $($(1))
29821ae6867Scamierjs
299da72e7fcSJed Brown# Cancel built-in and old-fashioned implicit rules which we don't use
3009df38c42SVeselin Dobrev.SUFFIXES:
301da72e7fcSJed Brown
30291b7489eSJed Brown.SECONDEXPANSION: # to expand $$(@D)/.DIR
3039df38c42SVeselin Dobrev
30491b7489eSJed Brown%/.DIR :
30591b7489eSJed Brown	@mkdir -p $(@D)
30691b7489eSJed Brown	@touch $@
30791b7489eSJed Brown
30891b7489eSJed Brown.PRECIOUS: %/.DIR
30991b7489eSJed Brown
31023072ed2SVeselin Dobrevlib: $(libceed) $(ceed.pc)
31123072ed2SVeselin Dobrev# run 'lib' target in parallel
3122f4d9adbSJeremy L Thompsonpar:;@$(MAKE) $(MFLAGS) V=$(V) lib
313422b683aSjeremyltbackend_status = $(if $(filter $1,$(BACKENDS_MAKE)), [backends: $1], [not found])
314bf3e26f6SVeselin Dobrevinfo:
315bf3e26f6SVeselin Dobrev	$(info ------------------------------------)
316bf3e26f6SVeselin Dobrev	$(info CC            = $(CC))
317241a4b83SYohann	$(info CXX           = $(CXX))
318bf3e26f6SVeselin Dobrev	$(info FC            = $(FC))
319bf3e26f6SVeselin Dobrev	$(info CPPFLAGS      = $(CPPFLAGS))
3204e62717cSJames Wright	$(info CFLAGS        = $(CFLAGS))
3214e62717cSJames Wright	$(info CXXFLAGS      = $(CXXFLAGS))
3224e62717cSJames Wright	$(info FFLAGS        = $(FFLAGS))
3234e62717cSJames Wright	$(info NVCCFLAGS     = $(NVCCFLAGS))
3244e62717cSJames Wright	$(info HIPCCFLAGS    = $(HIPCCFLAGS))
3254e62717cSJames Wright	$(info SYCLFLAGS     = $(SYCLFLAGS))
3264e62717cSJames Wright	$(info CEED_LDFLAGS  = $(CEED_LDFLAGS))
3274e62717cSJames Wright	$(info CEED_LDLIBS   = $(CEED_LDLIBS))
3281d013790SJed Brown	$(info AR            = $(AR))
3291d013790SJed Brown	$(info ARFLAGS       = $(ARFLAGS))
330bf3e26f6SVeselin Dobrev	$(info OPT           = $(OPT))
331bf3e26f6SVeselin Dobrev	$(info AFLAGS        = $(AFLAGS))
332bf3e26f6SVeselin Dobrev	$(info ASAN          = $(or $(ASAN),(empty)))
3338df0376fSJeremy L Thompson	$(info VERBOSE       = $(or $(V),(empty)) [verbose=$(if $(V),on,off)])
334bf3e26f6SVeselin Dobrev	$(info ------------------------------------)
335ae945beaSJeremy L Thompson	$(info MEMCHK_STATUS = $(MEMCHK_STATUS)$(call backend_status,$(MEMCHK_BACKENDS)))
336ae945beaSJeremy L Thompson	$(info AVX_STATUS    = $(AVX_STATUS)$(call backend_status,$(AVX_BACKENDS)))
337ae945beaSJeremy L Thompson	$(info XSMM_DIR      = $(XSMM_DIR)$(call backend_status,$(XSMM_BACKENDS)))
3389647a07eSDavid Medina	$(info OCCA_DIR      = $(OCCA_DIR)$(call backend_status,$(OCCA_BACKENDS)))
33940461fa4Snbeams	$(info MAGMA_DIR     = $(MAGMA_DIR)$(call backend_status,$(MAGMA_BACKENDS)))
340ab9cabdeSVeselin Dobrev	$(info CUDA_DIR      = $(CUDA_DIR)$(call backend_status,$(CUDA_BACKENDS)))
341023b8a51Sabdelfattah83	$(info ROCM_DIR      = $(ROCM_DIR)$(call backend_status,$(HIP_BACKENDS)))
342bd882c8aSJames Wright	$(info SYCL_DIR      = $(SYCL_DIR)$(call backend_status,$(SYCL_BACKENDS)))
343bf3e26f6SVeselin Dobrev	$(info ------------------------------------)
344bf3e26f6SVeselin Dobrev	$(info MFEM_DIR      = $(MFEM_DIR))
3454d1cd9fcSJeremy L Thompson	$(info NEK5K_DIR     = $(NEK5K_DIR))
346bf3e26f6SVeselin Dobrev	$(info PETSC_DIR     = $(PETSC_DIR))
347bf3e26f6SVeselin Dobrev	$(info ------------------------------------)
348bf3e26f6SVeselin Dobrev	$(info prefix        = $(prefix))
349bf3e26f6SVeselin Dobrev	$(info includedir    = $(value includedir))
350bf3e26f6SVeselin Dobrev	$(info libdir        = $(value libdir))
351bf3e26f6SVeselin Dobrev	$(info pkgconfigdir  = $(value pkgconfigdir))
352bf3e26f6SVeselin Dobrev	$(info ------------------------------------)
353bf3e26f6SVeselin Dobrev	@true
35423072ed2SVeselin Dobrevinfo-backends:
355d20f937dSJed Brown	$(info make: 'lib' with optional backends: $(filter-out $(BACKENDS_BUILTIN),$(BACKENDS)))
356422b683aSjeremylt	@true
357422b683aSjeremyltinfo-backends-all:
358422b683aSjeremylt	$(info make: 'lib' with backends: $(filter-out $(TEST_BACKENDS),$(BACKENDS)))
359422b683aSjeremylt	@true
3600e439e50SJed Brown
3613696039aSJed Brown$(libceed.so) : CEED_LDFLAGS += $(if $(DARWIN), -install_name @rpath/$(notdir $(libceed.so)))
36269762e1fScamierjs
36348fffa06Sjeremylt# Standard Backends
36487174f08SJed Brownlibceed.c += $(ref.c)
3654a2e7687Sjeremyltlibceed.c += $(blocked.c)
36689c6efa4Sjeremyltlibceed.c += $(opt.c)
36723072ed2SVeselin Dobrev
3685120064bSJeremy L Thompson# Memcheck Backends
369bdc3149dSjeremyltMEMCHK_STATUS   = Disabled
3706b5c14f7SJed BrownMEMCHK         := $(shell echo "$(HASH)include <valgrind/memcheck.h>" | $(CC) $(CPPFLAGS) -E - >/dev/null 2>&1 && echo 1)
371ae945beaSJeremy L ThompsonMEMCHK_BACKENDS = /cpu/self/memcheck/serial /cpu/self/memcheck/blocked
372bdc3149dSjeremyltifeq ($(MEMCHK),1)
373bdc3149dSjeremylt  MEMCHK_STATUS = Enabled
374fc7cf9a0Sjeremylt  libceed.c += $(ceedmemcheck.c)
375422b683aSjeremylt  BACKENDS_MAKE += $(MEMCHK_BACKENDS)
376fc7cf9a0Sjeremyltendif
377fc7cf9a0Sjeremylt
3785120064bSJeremy L Thompson# AVX Backeds
37948fffa06SjeremyltAVX_STATUS   = Disabled
380cf4a56afSJed BrownAVX_FLAG    := $(if $(filter clang,$(CC_VENDOR)),+avx,-mavx)
38159e56409SJed BrownAVX         := $(filter $(AVX_FLAG),$(shell $(CC) $(CFLAGS:-M%=) -v -E -x c /dev/null 2>&1))
382ae945beaSJeremy L ThompsonAVX_BACKENDS = /cpu/self/avx/serial /cpu/self/avx/blocked
383cf4a56afSJed Brownifneq ($(AVX),)
38448fffa06Sjeremylt  AVX_STATUS = Enabled
38548fffa06Sjeremylt  libceed.c += $(avx.c)
386422b683aSjeremylt  BACKENDS_MAKE += $(AVX_BACKENDS)
38748fffa06Sjeremyltendif
38848fffa06Sjeremylt
3891d013790SJed Brown# Collect list of libraries and paths for use in linking and pkg-config
3901d013790SJed BrownPKG_LIBS =
3917c735608SJed Brown# Stubs that will not be RPATH'd
3927c735608SJed BrownPKG_STUBS_LIBS =
3931d013790SJed Brown
3948d713cf6Sjeremylt# libXSMM Backends
395ae945beaSJeremy L ThompsonXSMM_BACKENDS = /cpu/self/xsmm/serial /cpu/self/xsmm/blocked
3968d713cf6Sjeremyltifneq ($(wildcard $(XSMM_DIR)/lib/libxsmm.*),)
3974548da4eSSebastian Grimberg  PKG_LIBS += -L$(abspath $(XSMM_DIR))/lib -lxsmm
39800723591Sjeremylt  MKL ?=
39900723591Sjeremylt  ifeq (,$(MKL)$(MKLROOT))
4004548da4eSSebastian Grimberg    BLAS_LIB ?= -lblas -ldl
4015462ed45Sjeremylt  else
40272e1b2f7SJeremy L Thompson    ifneq ($(MKLROOT),)
403ff56800aSJed Brown      # Some installs put everything inside an intel64 subdirectory, others not
404ff56800aSJed Brown      MKL_LIBDIR = $(dir $(firstword $(wildcard $(MKLROOT)/lib/intel64/libmkl_sequential.* $(MKLROOT)/lib/libmkl_sequential.*)))
4051d013790SJed Brown      MKL_LINK = -L$(MKL_LIBDIR)
40672e1b2f7SJeremy L Thompson    endif
4074548da4eSSebastian Grimberg    BLAS_LIB ?= $(MKL_LINK) -Wl,--push-state,--no-as-needed -lmkl_intel_lp64 -lmkl_sequential -lmkl_core -lpthread -lm -ldl -Wl,--pop-state
4085462ed45Sjeremylt  endif
4091d013790SJed Brown  PKG_LIBS += $(BLAS_LIB)
4108d713cf6Sjeremylt  libceed.c += $(xsmm.c)
411683faae0SJed Brown  $(xsmm.c:%.c=$(OBJDIR)/%.o) $(xsmm.c:%=%.tidy) : CPPFLAGS += -I$(XSMM_DIR)/include
412422b683aSjeremylt  BACKENDS_MAKE += $(XSMM_BACKENDS)
4138d713cf6Sjeremyltendif
4148d713cf6Sjeremylt
41548fffa06Sjeremylt# OCCA Backends
41628688798SjeremyltOCCA_BACKENDS = /cpu/self/occa
4177f5ff99bSVeselin Dobrevifneq ($(wildcard $(OCCA_DIR)/lib/libocca.*),)
4180be03a92SJeremy L Thompson  OCCA_MODES := $(shell LD_LIBRARY_PATH=$(OCCA_DIR)/lib $(OCCA_DIR)/bin/occa modes)
41928688798Sjeremylt  OCCA_BACKENDS += $(if $(filter OpenMP,$(OCCA_MODES)),/cpu/openmp/occa)
4200be03a92SJeremy L Thompson  OCCA_BACKENDS += $(if $(filter dpcpp,$(OCCA_MODES)),/gpu/dpcpp/occa)
4210be03a92SJeremy L Thompson  OCCA_BACKENDS += $(if $(filter OpenCL,$(OCCA_MODES)),/gpu/opencl/occa)
42228688798Sjeremylt  OCCA_BACKENDS += $(if $(filter HIP,$(OCCA_MODES)),/gpu/hip/occa)
42328688798Sjeremylt  OCCA_BACKENDS += $(if $(filter CUDA,$(OCCA_MODES)),/gpu/cuda/occa)
4249647a07eSDavid Medina  $(libceeds) : CPPFLAGS += -I$(OCCA_DIR)/include
4251d013790SJed Brown  PKG_LIBS += -L$(abspath $(OCCA_DIR))/lib -locca
4261d013790SJed Brown  LIBCEED_CONTAINS_CXX = 1
4279647a07eSDavid Medina  libceed.cpp += $(occa.cpp)
428422b683aSjeremylt  BACKENDS_MAKE += $(OCCA_BACKENDS)
42921ae6867Scamierjsendif
43023072ed2SVeselin Dobrev
43186a4271fSThilina Rathnayake# CUDA Backends
43268c150f8SJed Brownifneq ($(CUDA_DIR),)
43368c150f8SJed Brown  CUDA_LIB_DIR := $(wildcard $(foreach d,lib lib64 lib/x86_64-linux-gnu,$(CUDA_DIR)/$d/libcudart.${SO_EXT}))
4345a9ca9adSVeselin Dobrev  CUDA_LIB_DIR := $(patsubst %/,%,$(dir $(firstword $(CUDA_LIB_DIR))))
43568c150f8SJed Brownendif
4363dd0010eSvaleriabarraCUDA_LIB_DIR_STUBS := $(CUDA_LIB_DIR)/stubs
437461525f5SNatalie BeamsCUDA_BACKENDS = /gpu/cuda/ref /gpu/cuda/shared /gpu/cuda/gen
4385a9ca9adSVeselin Dobrevifneq ($(CUDA_LIB_DIR),)
4399d77422eSJed Brown  $(libceeds) : CPPFLAGS += -I$(CUDA_DIR)/include
4401d013790SJed Brown  PKG_LIBS += -L$(abspath $(CUDA_LIB_DIR)) -lcudart -lnvrtc -lcuda -lcublas
4417c735608SJed Brown  PKG_STUBS_LIBS += -L$(CUDA_LIB_DIR_STUBS)
4421d013790SJed Brown  LIBCEED_CONTAINS_CXX = 1
443af7ca75eSjeremylt  libceed.c     += interface/ceed-cuda.c
4447fcac036SJeremy L Thompson  libceed.c     += $(cuda.c) $(cuda-ref.c) $(cuda-shared.c) $(cuda-gen.c)
445c9c2c079SJeremy L Thompson  libceed.cpp   += $(cuda.cpp) $(cuda-ref.cpp) $(cuda-gen.cpp)
4467fcac036SJeremy L Thompson  libceed.cu    += $(cuda-ref.cu) $(cuda-shared.cu) $(cuda-gen.cu)
447422b683aSjeremylt  BACKENDS_MAKE += $(CUDA_BACKENDS)
4489f0427d9SYohannendif
4499f0427d9SYohann
45030f4f45fSnbeams# HIP Backends
451023b8a51Sabdelfattah83HIP_LIB_DIR := $(wildcard $(foreach d,lib lib64,$(ROCM_DIR)/$d/libamdhip64.${SO_EXT}))
45230f4f45fSnbeamsHIP_LIB_DIR := $(patsubst %/,%,$(dir $(firstword $(HIP_LIB_DIR))))
4537d8d0e25SnbeamsHIP_BACKENDS = /gpu/hip/ref /gpu/hip/shared /gpu/hip/gen
45430f4f45fSnbeamsifneq ($(HIP_LIB_DIR),)
455f150ce52SJed Brown  HIPCONFIG_CPPFLAGS := $(subst =,,$(shell $(ROCM_DIR)/bin/hipconfig -C))
456f150ce52SJed Brown  $(hip-all.c:%.c=$(OBJDIR)/%.o) $(hip-all.c:%=%.tidy): CPPFLAGS += $(HIPCONFIG_CPPFLAGS)
45730f4f45fSnbeams  ifneq ($(CXX), $(HIPCC))
458f150ce52SJed Brown    $(hip-all.cpp:%.cpp=$(OBJDIR)/%.o) $(hip-all.cpp:%=%.tidy): CPPFLAGS += $(HIPCONFIG_CPPFLAGS)
45930f4f45fSnbeams  endif
4601d013790SJed Brown  PKG_LIBS += -L$(abspath $(HIP_LIB_DIR)) -lamdhip64 -lhipblas
4611d013790SJed Brown  LIBCEED_CONTAINS_CXX = 1
462f150ce52SJed Brown  libceed.c     += $(hip-all.c)
463f150ce52SJed Brown  libceed.cpp   += $(hip-all.cpp)
4647fcac036SJeremy L Thompson  libceed.hip   += $(hip-ref.hip)
465422b683aSjeremylt  BACKENDS_MAKE += $(HIP_BACKENDS)
46630f4f45fSnbeamsendif
46730f4f45fSnbeams
468bd882c8aSJames Wright# SYCL Backends
4696ca0f394SUmesh UnnikrishnanSYCL_BACKENDS = /gpu/sycl/ref /gpu/sycl/shared /gpu/sycl/gen
470bd882c8aSJames Wrightifneq ($(SYCL_DIR),)
471bd882c8aSJames Wright  SYCL_LIB_DIR := $(wildcard $(foreach d,lib lib64,$(SYCL_DIR)/$d/libsycl.${SO_EXT}))
472bd882c8aSJames Wright  SYCL_LIB_DIR := $(patsubst %/,%,$(dir $(firstword $(SYCL_LIB_DIR))))
473bd882c8aSJames Wrightendif
474bd882c8aSJames Wrightifneq ($(SYCL_LIB_DIR),)
475bd882c8aSJames Wright  PKG_LIBS += $(SYCL_FLAG) -lze_loader
476bd882c8aSJames Wright  LIBCEED_CONTAINS_CXX = 1
4776ca0f394SUmesh Unnikrishnan  libceed.sycl += $(sycl-core.cpp) $(sycl-ref.cpp) $(sycl-shared.cpp) $(sycl-gen.cpp)
478bd882c8aSJames Wright  BACKENDS_MAKE += $(SYCL_BACKENDS)
479bd882c8aSJames Wrightendif
480bd882c8aSJames Wright
4815120064bSJeremy L Thompson# MAGMA Backends
4829f0427d9SYohannifneq ($(wildcard $(MAGMA_DIR)/lib/libmagma.*),)
48345f29434Snbeams  MAGMA_ARCH=$(shell nm -g $(MAGMA_DIR)/lib/libmagma.* | grep -c "hipblas")
48445f29434Snbeams  ifeq ($(MAGMA_ARCH), 0)  # CUDA MAGMA
4859f0427d9SYohann    ifneq ($(CUDA_LIB_DIR),)
486dacf7c88SJed Brown      cuda_link = $(if $(STATIC),,-Wl,-rpath,$(CUDA_LIB_DIR)) -L$(CUDA_LIB_DIR) -lcublas -lcusparse -lcudart
4871dc2661bSVeselin Dobrev      omp_link = -fopenmp
4881dc2661bSVeselin Dobrev      magma_link_static = -L$(MAGMA_DIR)/lib -lmagma $(cuda_link) $(omp_link)
489dacf7c88SJed Brown      magma_link_shared = -L$(MAGMA_DIR)/lib $(if $(STATIC),,-Wl,-rpath,$(abspath $(MAGMA_DIR)/lib)) -lmagma
4907692a9b0SVeselin Dobrev      magma_link := $(if $(wildcard $(MAGMA_DIR)/lib/libmagma.${SO_EXT}),$(magma_link_shared),$(magma_link_static))
4911d013790SJed Brown      PKG_LIBS += $(magma_link)
492a07e8cf1SNatalie Beams      libceed.c   += $(magma.c)
4932dc3fb5fSabdelfattah83      libceed.cpp += $(magma.cpp)
494a07e8cf1SNatalie Beams      libceed.cu  += $(magma.cu)
495a07e8cf1SNatalie Beams      $(magma.c:%.c=$(OBJDIR)/%.o) $(magma.c:%=%.tidy) : CPPFLAGS += -DADD_ -I$(MAGMA_DIR)/include -I$(CUDA_DIR)/include
4962dc3fb5fSabdelfattah83      $(magma.cpp:%.cpp=$(OBJDIR)/%.o) $(magma.cpp:%=%.tidy) : CPPFLAGS += -DADD_ -I$(MAGMA_DIR)/include -I$(CUDA_DIR)/include
497a11a3c55Snbeams      $(magma.cu:%.cu=$(OBJDIR)/%.o) : CPPFLAGS += --compiler-options=-fPIC -DADD_ -I$(MAGMA_DIR)/include -I$(MAGMA_DIR)/magmablas -I$(CUDA_DIR)/include
49840461fa4Snbeams      MAGMA_BACKENDS = /gpu/cuda/magma /gpu/cuda/magma/det
49945f29434Snbeams    endif
50045f29434Snbeams  else  # HIP MAGMA
501969f2b10Snbeams    ifneq ($(HIP_LIB_DIR),)
502969f2b10Snbeams      omp_link = -fopenmp
503ae93e896SSebastian Grimberg      hip_link = $(if $(STATIC),,-Wl,-rpath,$(HIP_LIB_DIR)) -L$(HIP_LIB_DIR) -lhipblas -lhipsparse -lamdhip64
504969f2b10Snbeams      magma_link_static = -L$(MAGMA_DIR)/lib -lmagma $(hip_link) $(omp_link)
505023b8a51Sabdelfattah83      magma_link_shared = -L$(MAGMA_DIR)/lib $(hip_link) $(omp_link) $(if $(STATIC),,-Wl,-rpath,$(abspath $(MAGMA_DIR)/lib)) -lmagma
506969f2b10Snbeams      magma_link := $(if $(wildcard $(MAGMA_DIR)/lib/libmagma.${SO_EXT}),$(magma_link_shared),$(magma_link_static))
5071d013790SJed Brown      PKG_LIBS += $(magma_link)
508969f2b10Snbeams      libceed.c   += $(magma.c)
5092dc3fb5fSabdelfattah83      libceed.cpp += $(magma.cpp)
510969f2b10Snbeams      libceed.hip += $(magma.hip)
511ae93e896SSebastian Grimberg      $(magma.c:%.c=$(OBJDIR)/%.o) $(magma.c:%=%.tidy) : CPPFLAGS += $(HIPCONFIG_CPPFLAGS) -I$(MAGMA_DIR)/include -I$(ROCM_DIR)/include -DCEED_MAGMA_USE_HIP -DADD_
512ae93e896SSebastian Grimberg      $(magma.cpp:%.cpp=$(OBJDIR)/%.o) $(magma.cpp:%=%.tidy) : CPPFLAGS += $(HIPCONFIG_CPPFLAGS) -I$(MAGMA_DIR)/include -I$(ROCM_DIR)/include -DCEED_MAGMA_USE_HIP -DADD_
513ae93e896SSebastian Grimberg      $(magma.hip:%.hip.cpp=$(OBJDIR)/%.o) : CPPFLAGS += -I$(MAGMA_DIR)/include -I$(MAGMA_DIR)/magmablas -I$(ROCM_DIR)/include -DCEED_MAGMA_USE_HIP -DADD_
51440461fa4Snbeams      MAGMA_BACKENDS = /gpu/hip/magma /gpu/hip/magma/det
515969f2b10Snbeams    endif
51682b77998SStan Tomov  endif
5171d013790SJed Brown  LIBCEED_CONTAINS_CXX = 1
518422b683aSjeremylt  BACKENDS_MAKE += $(MAGMA_BACKENDS)
5195a9ca9adSVeselin Dobrevendif
520755585ceSStan Tomov
5215de894e4SJeremy L ThompsonBACKENDS ?= $(BACKENDS_MAKE)
522ce41f623SJed Brownexport BACKENDS
523ce41f623SJed Brown
5241d013790SJed Brown_pkg_ldflags = $(filter -L%,$(PKG_LIBS))
5251d013790SJed Brown_pkg_ldlibs = $(filter-out -L%,$(PKG_LIBS))
526dacf7c88SJed Brown$(libceeds) : CEED_LDFLAGS += $(_pkg_ldflags) $(if $(STATIC),,$(_pkg_ldflags:-L%=-Wl,-rpath,%)) $(PKG_STUBS_LIBS)
5273696039aSJed Brown$(libceeds) : CEED_LDLIBS += $(_pkg_ldlibs)
5281d013790SJed Brownifeq ($(STATIC),1)
5290bd9ac94SJed Brown  $(examples) $(tests) : CEED_LDFLAGS += $(EM_LDFLAGS) $(_pkg_ldflags) $(if $(STATIC),,$(_pkg_ldflags:-L%=-Wl,-rpath,%)) $(PKG_STUBS_LIBS)
5303696039aSJed Brown  $(examples) $(tests) : CEED_LDLIBS += $(_pkg_ldlibs)
5311d013790SJed Brownendif
5321d013790SJed Brown
5331d013790SJed Brownpkgconfig-libs-private = $(PKG_LIBS)
5341d013790SJed Brownifeq ($(LIBCEED_CONTAINS_CXX),1)
5351d013790SJed Brown  $(libceeds) : LINK = $(CXX)
5361d013790SJed Brown  ifeq ($(STATIC),1)
5373696039aSJed Brown    $(examples) $(tests) : CEED_LDLIBS += $(LIBCXX)
5381d013790SJed Brown    pkgconfig-libs-private += $(LIBCXX)
5391d013790SJed Brown  endif
5401d013790SJed Brownendif
5411d013790SJed Brown
5421d013790SJed Brown# File names *-weak.c contain weak symbol definitions, which must be listed last
5431d013790SJed Brown# when creating shared or static libraries.
5441d013790SJed Brownweak_last = $(filter-out %-weak.o,$(1)) $(filter %-weak.o,$(1))
5451d013790SJed Brown
546bd882c8aSJames Wrightlibceed.o = $(libceed.c:%.c=$(OBJDIR)/%.o) $(libceed.cpp:%.cpp=$(OBJDIR)/%.o) $(libceed.cu:%.cu=$(OBJDIR)/%.o) $(libceed.hip:%.hip.cpp=$(OBJDIR)/%.o) $(libceed.sycl:%.sycl.cpp=$(OBJDIR)/%.o)
5474c7bddedSJed Brown$(filter %fortran.o,$(libceed.o)) : CPPFLAGS += $(if $(filter 1,$(UNDERSCORE)),-DUNDERSCORE)
54823072ed2SVeselin Dobrev$(libceed.o): | info-backends
5491d013790SJed Brown$(libceed.so) : $(call weak_last,$(libceed.o)) | $$(@D)/.DIR
5503696039aSJed Brown	$(call quiet,LINK) $(LDFLAGS) $(CEED_LDFLAGS) -shared -o $@ $^ $(CEED_LDLIBS) $(LDLIBS)
55191b7489eSJed Brown
5521d013790SJed Brown$(libceed.a) : $(call weak_last,$(libceed.o)) | $$(@D)/.DIR
5531d013790SJed Brown	$(call quiet,AR) $(ARFLAGS) $@ $^
5541d013790SJed Brown
55558e8d3b7SJed Brown$(OBJDIR)/%.o : $(CURDIR)/%.c | $$(@D)/.DIR
556b5b03409SJed Brown	$(call quiet,CC) $(CPPFLAGS) $(CFLAGS) -c -o $@ $(abspath $<)
557ae3cba82Scamierjs
558241a4b83SYohann$(OBJDIR)/%.o : $(CURDIR)/%.cpp | $$(@D)/.DIR
559241a4b83SYohann	$(call quiet,CXX) $(CPPFLAGS) $(CXXFLAGS) -c -o $@ $(abspath $<)
560241a4b83SYohann
56158e8d3b7SJed Brown$(OBJDIR)/%.o : $(CURDIR)/%.cu | $$(@D)/.DIR
562777ff853SJeremy L Thompson	$(call quiet,NVCC) $(filter-out -Wno-unused-function, $(CPPFLAGS)) $(NVCCFLAGS) -c -o $@ $(abspath $<)
563755585ceSStan Tomov
564cfb6011cSnbeams$(OBJDIR)/%.o : $(CURDIR)/%.hip.cpp | $$(@D)/.DIR
565f150ce52SJed Brown	$(call quiet,HIPCC) $(CPPFLAGS) $(HIPCCFLAGS) -c -o $@ $(abspath $<)
56630f4f45fSnbeams
567bd882c8aSJames Wright$(OBJDIR)/%.o : $(CURDIR)/%.sycl.cpp | $$(@D)/.DIR
568bd882c8aSJames Wright	$(call quiet,SYCLCXX) $(SYCLFLAGS) $(CPPFLAGS) -c -o $@ $(abspath $<)
569bd882c8aSJames Wright
5706ca0f394SUmesh Unnikrishnan$(OBJDIR)/%.o : $(CURDIR)/%.sycl.cpp | $$(@D)/.DIR
5716ca0f394SUmesh Unnikrishnan	$(call quiet,SYCLCXX) $(SYCLFLAGS) $(CPPFLAGS) -c -o $@ $(abspath $<)
5726ca0f394SUmesh Unnikrishnan
573e3e35afdSJed Brown$(OBJDIR)/%$(EXE_SUFFIX) : tests/%.c | $$(@D)/.DIR
5743696039aSJed Brown	$(call quiet,LINK.c) $(CEED_LDFLAGS) -o $@ $(abspath $<) $(CEED_LIBS) $(CEED_LDLIBS) $(LDLIBS)
57578b5556aScamierjs
576e3e35afdSJed Brown$(OBJDIR)/%$(EXE_SUFFIX) : tests/%.f90 | $$(@D)/.DIR
5773696039aSJed Brown	$(call quiet,LINK.F) -DSOURCE_DIR='"$(abspath $(<D))/"' $(CEED_LDFLAGS) -o $@ $(abspath $<) $(CEED_LIBS) $(CEED_LDLIBS) $(LDLIBS)
57832d74c32SThilina Rathnayake
579e3e35afdSJed Brown$(OBJDIR)/%$(EXE_SUFFIX) : examples/ceed/%.c | $$(@D)/.DIR
5803696039aSJed Brown	$(call quiet,LINK.c) $(CEED_LDFLAGS) -o $@ $(abspath $<) $(CEED_LIBS) $(CEED_LDLIBS) $(LDLIBS)
58191b7489eSJed Brown
582e3e35afdSJed Brown$(OBJDIR)/%$(EXE_SUFFIX) : examples/ceed/%.f | $$(@D)/.DIR
5833696039aSJed Brown	$(call quiet,LINK.F) -DSOURCE_DIR='"$(abspath $(<D))/"' $(CEED_LDFLAGS) -o $@ $(abspath $<) $(CEED_LIBS) $(CEED_LDLIBS) $(LDLIBS)
584673d494eSThilina Rathnayake
58516c6c054SJed Brown$(OBJDIR)/mfem-% : examples/mfem/%.cpp $(libceed) | $$(@D)/.DIR
586c4216f28SJed Brown	+$(MAKE) -C examples/mfem CEED_DIR=`pwd` \
587722eb117SJeremy L Thompson	  MFEM_DIR="$(abspath $(MFEM_DIR))" CXX=$(CXX) $*
588636cccdbSjeremylt	cp examples/mfem/$* $@
58916c6c054SJed Brown
59086a4271fSThilina Rathnayake# Note: Multiple Nek files cannot be built in parallel. The '+' here enables
59186a4271fSThilina Rathnayake#       this single Nek bps file to be built in parallel with other examples,
59286a4271fSThilina Rathnayake#       such as when calling `make prove-all -j2`.
59386a4271fSThilina Rathnayake$(OBJDIR)/nek-bps : examples/nek/bps/bps.usr examples/nek/nek-examples.sh $(libceed) | $$(@D)/.DIR
59486a4271fSThilina Rathnayake	+$(MAKE) -C examples MPI=$(MPI) CEED_DIR=`pwd` NEK5K_DIR="$(abspath $(NEK5K_DIR))" nek
59586a4271fSThilina Rathnayake	mv examples/nek/build/bps $(OBJDIR)/bps
59686a4271fSThilina Rathnayake	cp examples/nek/nek-examples.sh $(OBJDIR)/nek-bps
59786a4271fSThilina Rathnayake
598386a09edSJed Brown# Several executables have common utilities, but we can't build the utilities
599386a09edSJed Brown# from separate submake invocations because they'll compete with each
600386a09edSJed Brown# other/corrupt output. So we put it in this utility library, but we don't want
601386a09edSJed Brown# to manually list source dependencies up at this level, so we'll just always
602386a09edSJed Brown# call recursive make to check that this utility is up to date.
603386a09edSJed Brownexamples/petsc/libutils.a.PHONY: $(libceed) $(ceed.pc)
604386a09edSJed Brown	+$(call quiet,MAKE) -C examples/petsc CEED_DIR=`pwd` AR=$(AR) ARFLAGS=$(ARFLAGS) \
605386a09edSJed Brown	  PETSC_DIR="$(abspath $(PETSC_DIR))" OPT="$(OPT)" $(basename $(@F))
606386a09edSJed Brown
607386a09edSJed Brown$(OBJDIR)/petsc-% : examples/petsc/%.c examples/petsc/libutils.a.PHONY $(libceed) $(ceed.pc) | $$(@D)/.DIR
608386a09edSJed Brown	+$(call quiet,MAKE) -C examples/petsc CEED_DIR=`pwd` \
609f766a8abSJed Brown	  PETSC_DIR="$(abspath $(PETSC_DIR))" OPT="$(OPT)" $*
610636cccdbSjeremylt	cp examples/petsc/$* $@
611e797ab98SJed Brown
612b868981dSJed Brown$(OBJDIR)/fluids-% : examples/fluids/%.c examples/fluids/src/*.c examples/fluids/*.h examples/fluids/problems/*.c examples/fluids/qfunctions/*.h $(libceed) $(ceed.pc) | $$(@D)/.DIR
6139aeb05eaSJed Brown	+$(call quiet,MAKE) -C examples/fluids CEED_DIR=`pwd` \
614f766a8abSJed Brown	  PETSC_DIR="$(abspath $(PETSC_DIR))" OPT="$(OPT)" $*
615636cccdbSjeremylt	cp examples/fluids/$* $@
616ccaff030SJeremy L Thompson
617b571f289SJed Brown$(OBJDIR)/solids-% : examples/solids/%.c examples/solids/%.h \
618b571f289SJed Brown    examples/solids/problems/*.c examples/solids/src/*.c \
619b571f289SJed Brown    examples/solids/include/*.h examples/solids/problems/*.h examples/solids/qfunctions/*.h \
620b571f289SJed Brown    $(libceed) $(ceed.pc) | $$(@D)/.DIR
6219aeb05eaSJed Brown	+$(call quiet,MAKE) -C examples/solids CEED_DIR=`pwd` \
622722eb117SJeremy L Thompson	  PETSC_DIR="$(abspath $(PETSC_DIR))" OPT="$(OPT)" $*
623636cccdbSjeremylt	cp examples/solids/$* $@
6242774d5cbSJeremy L Thompson
625265be9c8Sjeremylt$(examples) : $(libceed)
6268e3e54ccSjeremylt$(tests) : $(libceed)
627dacf7c88SJed Brown$(tests) $(examples) : override LDFLAGS += $(if $(STATIC),,-Wl,-rpath,$(abspath $(LIBDIR))) -L$(LIBDIR)
6284859b599SJed Brown
6291b16049aSZach Atkins# Set number processes for testing
6301b16049aSZach AtkinsNPROC_TEST ?= 1
6311b16049aSZach Atkinsexport NPROC_TEST
6321b16049aSZach Atkins
633dad465e7SJed Brownrun-% : $(OBJDIR)/%
6341b16049aSZach Atkins	@$(PYTHON) tests/junit.py --mode tap --ceed-backends $(BACKENDS) --nproc $(NPROC_TEST) $(<:$(OBJDIR)/%=%)
635686de4acSJed Brown
636686de4acSJed Brownexternal_examples := \
637686de4acSJed Brown	$(if $(MFEM_DIR),$(mfemexamples)) \
638686de4acSJed Brown	$(if $(PETSC_DIR),$(petscexamples)) \
639b974e86eSJed Brown	$(if $(NEK5K_DIR),$(nekexamples)) \
640ccaff030SJeremy L Thompson	$(if $(PETSC_DIR),$(fluidsexamples)) \
641ccaff030SJeremy L Thompson	$(if $(PETSC_DIR),$(solidsexamples))
642686de4acSJed Brown
643686de4acSJed Brownallexamples = $(examples) $(external_examples)
644686de4acSJed Brown
645686de4acSJed Brown# The test and prove targets can be controlled via pattern searches.  The
646686de4acSJed Brown# default is to run tests and those examples that have no external dependencies.
647686de4acSJed Brown# Examples of finer grained control:
648686de4acSJed Brown#
649686de4acSJed Brown#   make test search='petsc mfem'      # PETSc and MFEM examples
650686de4acSJed Brown#   make prove search='t3'             # t3xx series tests
651686de4acSJed Brown#   make junit search='ex petsc'       # core ex* and PETSc tests
652686de4acSJed Brownsearch ?= t ex
653686de4acSJed Brownrealsearch = $(search:%=%%)
654686de4acSJed Brownmatched = $(foreach pattern,$(realsearch),$(filter $(OBJDIR)/$(pattern),$(tests) $(allexamples)))
6551b16049aSZach AtkinsJUNIT_BATCH ?= ''
656686de4acSJed Brown
6572158b1b0Sjeremylt# Test core libCEED
658686de4acSJed Browntest : $(matched:$(OBJDIR)/%=run-%)
6592158b1b0Sjeremylt
66086a4271fSThilina Rathnayake# Run test target in parallel
6616850bcb5Scamierjstst : ;@$(MAKE) $(MFLAGS) V=$(V) test
6623b56482dScamierjs# CPU C tests only for backend %
6633f3e7340Scamierjsctc-% : $(ctests);@$(foreach tst,$(ctests),$(tst) /cpu/$*;)
6644859b599SJed Brown
66586a4271fSThilina Rathnayakeprove : $(matched)
666a5dc8077SJed Brown	$(info Testing backends: $(BACKENDS))
6671b16049aSZach Atkins	$(PROVE) $(PROVE_OPTS) --exec 'tests/junit.py --mode tap --ceed-backends $(BACKENDS) --nproc $(NPROC_TEST)' $(matched:$(OBJDIR)/%=%)
66886a4271fSThilina Rathnayake# Run prove target in parallel
6696850bcb5Scamierjsprv : ;@$(MAKE) $(MFLAGS) V=$(V) prove
670bfa078e6SJed Brown
671686de4acSJed Brownprove-all :
672686de4acSJed Brown	+$(MAKE) prove realsearch=%
673686de4acSJed Brown
6748ec9d54bSJed Brownjunit-% : $(OBJDIR)/%
6751b16049aSZach Atkins	@printf "  %10s %s\n" TEST $(<:$(OBJDIR)/%=%); $(PYTHON) tests/junit.py --ceed-backends $(BACKENDS) --nproc $(NPROC_TEST) --junit-batch $(JUNIT_BATCH) $(<:$(OBJDIR)/%=%)
6768ec9d54bSJed Brown
67776174befSjeremyltjunit : $(matched:$(OBJDIR)/%=junit-%)
6788ec9d54bSJed Brown
6792f4d9adbSJeremy L Thompsonall: $(alltests)
6802f4d9adbSJeremy L Thompson
6812f4d9adbSJeremy L Thompsonexamples : $(allexamples)
68286a4271fSThilina Rathnayakeceedexamples : $(examples)
68386a4271fSThilina Rathnayakenekexamples : $(nekexamples)
68486a4271fSThilina Rathnayakemfemexamples : $(mfemexamples)
68586a4271fSThilina Rathnayakepetscexamples : $(petscexamples)
6862f4d9adbSJeremy L Thompson
6872f4d9adbSJeremy L Thompson# Benchmarks
6880c59ef15SJeremy L Thompsonallbenchmarks = petsc-bps
6894e79ff5bSVeselin Dobrevbench_targets = $(addprefix bench-,$(allbenchmarks))
6904e79ff5bSVeselin Dobrev.PHONY: $(bench_targets) benchmarks
6914e79ff5bSVeselin Dobrev$(bench_targets): bench-%: $(OBJDIR)/%
692422b683aSjeremylt	cd benchmarks && ./benchmark.sh --ceed "$(BACKENDS_MAKE)" -r $(*).sh
6934e79ff5bSVeselin Dobrevbenchmarks: $(bench_targets)
6942c6ea02fSJed Brown
6956ea7c6c1SJed Brown$(ceed.pc) : pkgconfig-prefix = $(abspath .)
696d5217624SJed Brown$(OBJDIR)/ceed.pc : pkgconfig-prefix = $(prefix)
697d5217624SJed Brown.INTERMEDIATE : $(OBJDIR)/ceed.pc
6986ea7c6c1SJed Brown%/ceed.pc : ceed.pc.template | $$(@D)/.DIR
6991d013790SJed Brown	@$(SED) \
7001d013790SJed Brown	    -e "s:%prefix%:$(pkgconfig-prefix):" \
7011d013790SJed Brown	    -e "s:%libs_private%:$(pkgconfig-libs-private):" $< > $@
7020e439e50SJed Brown
7036ed4cbd1SJeremy L Thompson$(OBJDIR)/interface/ceed-jit-source-root-default.o : CPPFLAGS += -DCEED_JIT_SOURCE_ROOT_DEFAULT="\"$(abspath ./include)/\""
7046ed4cbd1SJeremy L Thompson$(OBJDIR)/interface/ceed-jit-source-root-install.o : CPPFLAGS += -DCEED_JIT_SOURCE_ROOT_DEFAULT="\"$(abspath $(includedir))/\""
7055766aa57SJeremy L Thompson
706d5217624SJed Browninstall : $(libceed) $(OBJDIR)/ceed.pc
707bf3e26f6SVeselin Dobrev	$(INSTALL) -d $(addprefix $(if $(DESTDIR),"$(DESTDIR)"),"$(includedir)"\
708a0154adeSJed Brown	  "$(includedir)/ceed/" "$(includedir)/ceed/jit-source/"\
709a0154adeSJed Brown	  "$(includedir)/ceed/jit-source/cuda/" "$(includedir)/ceed/jit-source/hip/"\
710ae93e896SSebastian Grimberg	  "$(includedir)/ceed/jit-source/gallery/" "$(includedir)/ceed/jit-source/magma/"\
711ae93e896SSebastian Grimberg	  "$(includedir)/ceed/jit-source/sycl/" "$(libdir)" "$(pkgconfigdir)")
712ec3da8bcSJed Brown	$(INSTALL_DATA) include/ceed/ceed.h "$(DESTDIR)$(includedir)/ceed/"
713c9c2c079SJeremy L Thompson	$(INSTALL_DATA) include/ceed/types.h "$(DESTDIR)$(includedir)/ceed/"
71480a9ef05SNatalie Beams	$(INSTALL_DATA) include/ceed/ceed-f32.h "$(DESTDIR)$(includedir)/ceed/"
71580a9ef05SNatalie Beams	$(INSTALL_DATA) include/ceed/ceed-f64.h "$(DESTDIR)$(includedir)/ceed/"
716ec3da8bcSJed Brown	$(INSTALL_DATA) include/ceed/fortran.h "$(DESTDIR)$(includedir)/ceed/"
717ec3da8bcSJed Brown	$(INSTALL_DATA) include/ceed/backend.h "$(DESTDIR)$(includedir)/ceed/"
718ec3da8bcSJed Brown	$(INSTALL_DATA) include/ceed/cuda.h "$(DESTDIR)$(includedir)/ceed/"
719ec3da8bcSJed Brown	$(INSTALL_DATA) include/ceed/hip.h "$(DESTDIR)$(includedir)/ceed/"
7201e25a746SJed Brown	$(INSTALL_DATA) $(libceed) "$(DESTDIR)$(libdir)/"
7211e25a746SJed Brown	$(INSTALL_DATA) $(OBJDIR)/ceed.pc "$(DESTDIR)$(pkgconfigdir)/"
722ec3da8bcSJed Brown	$(INSTALL_DATA) include/ceed.h "$(DESTDIR)$(includedir)/"
723ec3da8bcSJed Brown	$(INSTALL_DATA) include/ceedf.h "$(DESTDIR)$(includedir)/"
724a0154adeSJed Brown	$(INSTALL_DATA) $(wildcard include/ceed/jit-source/cuda/*.h) "$(DESTDIR)$(includedir)/ceed/jit-source/cuda/"
725a0154adeSJed Brown	$(INSTALL_DATA) $(wildcard include/ceed/jit-source/hip/*.h) "$(DESTDIR)$(includedir)/ceed/jit-source/hip/"
726a0154adeSJed Brown	$(INSTALL_DATA) $(wildcard include/ceed/jit-source/gallery/*.h) "$(DESTDIR)$(includedir)/ceed/jit-source/gallery/"
727ae93e896SSebastian Grimberg	$(INSTALL_DATA) $(wildcard include/ceed/jit-source/magma/*.h) "$(DESTDIR)$(includedir)/ceed/jit-source/magma/"
728ae93e896SSebastian Grimberg	$(INSTALL_DATA) $(wildcard include/ceed/jit-source/sycl/*.h) "$(DESTDIR)$(includedir)/ceed/jit-source/sycl/"
729d5217624SJed Brown
7302b730f8bSJeremy L Thompson.PHONY : all cln clean doxygen doc format lib install par print test tst prove prv prove-all junit examples tidy iwyu info info-backends info-backends-all
731d635b4c6Scamierjs
7326e5d1fd9Scamierjscln clean :
7335cd88e3aSjeremylt	$(RM) -r $(OBJDIR) $(LIBDIR) dist *egg* .pytest_cache *cffi*
7349aeb05eaSJed Brown	$(call quiet,MAKE) -C examples clean NEK5K_DIR="$(abspath $(NEK5K_DIR))"
7359aeb05eaSJed Brown	$(call quiet,MAKE) -C python/tests clean
736196a75e4SJed Brown	$(RM) benchmarks/*output.txt
7374859b599SJed Brown
73807838a1cSTzaniodistclean : clean
73921d92382SJed Brown	$(RM) -r doc/html doc/sphinx/build $(CONFIG)
74007838a1cSTzanio
7412b730f8bSJeremy L Thompson# Documentation
7424c4400c7SValeria BarraDOXYGEN ?= doxygen
7435cd6c1fbSSebastian Grimberg
7444c4400c7SValeria Barradoxygen :
74563be1c69SJed Brown	$(DOXYGEN) -q Doxyfile
7464c4400c7SValeria Barra
74774c2e4b1SJed Browndoc-html doc-latexpdf doc-epub doc-livehtml : doc-% : doxygen
7484c4400c7SValeria Barra	make -C doc/sphinx $*
7494c4400c7SValeria Barra
7504c4400c7SValeria Barradoc : doc-html
7517bd3a522STzanio
7522b730f8bSJeremy L Thompson# Style/Format
7532b730f8bSJeremy L ThompsonCLANG_FORMAT ?= clang-format
7545cd6c1fbSSebastian GrimbergCLANG_FORMAT_OPTS += -style=file -i
7555cd6c1fbSSebastian GrimbergAUTOPEP8 ?= autopep8
7562fee3251SSebastian GrimbergAUTOPEP8_OPTS += --in-place --aggressive --max-line-length 120
7572b730f8bSJeremy L Thompson
75854936541SJames Wrightformat.ch := $(filter-out include/ceedf.h $(wildcard tests/t*-f.h), $(shell git ls-files '*.[ch]pp' '*.[ch]'))
7592fee3251SSebastian Grimbergformat.py := $(filter-out tests/junit-xml/junit_xml/__init__.py, $(shell git ls-files '*.py'))
7602b730f8bSJeremy L Thompson
7612b730f8bSJeremy L Thompsonformat-c  :
7625cd6c1fbSSebastian Grimberg	$(CLANG_FORMAT) $(CLANG_FORMAT_OPTS) $(format.ch)
7630dbfdfc5SJed Brown
7642b730f8bSJeremy L Thompsonformat-py :
7655cd6c1fbSSebastian Grimberg	$(AUTOPEP8) $(AUTOPEP8_OPTS) $(format.py)
7667a7b0fa3SJed Brown
7672b730f8bSJeremy L Thompsonformat    : format-c format-py
7687a7b0fa3SJed Brown
7692b730f8bSJeremy L Thompson# Tidy
770683faae0SJed BrownCLANG_TIDY ?= clang-tidy
7719647a07eSDavid Medina
772683faae0SJed Brown%.c.tidy : %.c
7736ed4cbd1SJeremy L Thompson	$(CLANG_TIDY) $(TIDY_OPTS) $^ -- $(CPPFLAGS) --std=c99 -I$(CUDA_DIR)/include -I$(ROCM_DIR)/include -DCEED_JIT_SOURCE_ROOT_DEFAULT="\"$(abspath ./include)/\""
774683faae0SJed Brown
7759647a07eSDavid Medina%.cpp.tidy : %.cpp
776023b8a51Sabdelfattah83	$(CLANG_TIDY) $(TIDY_OPTS) $^ -- $(CPPFLAGS) --std=c++11 -I$(CUDA_DIR)/include -I$(OCCA_DIR)/include -I$(ROCM_DIR)/include
7779647a07eSDavid Medina
7782b730f8bSJeremy L Thompsontidy-c   : $(libceed.c:%=%.tidy)
7792b730f8bSJeremy L Thompsontidy-cpp : $(libceed.cpp:%=%.tidy)
7809647a07eSDavid Medina
7812b730f8bSJeremy L Thompsontidy : tidy-c tidy-cpp
782683faae0SJed Brown
78349aac155SJeremy L Thompson# Include-What-You-Use
784db52d626SJeremy L Thompsonifneq ($(wildcard ../iwyu/*),)
785db52d626SJeremy L Thompson  IWYU_DIR ?= ../iwyu
7869c06f60aSJeremy L Thompson  IWYU_CC  ?= $(IWYU_DIR)/build/bin/include-what-you-use
787db52d626SJeremy L Thompsonendif
78849aac155SJeremy L Thompsoniwyu :
78949aac155SJeremy L Thompson	$(MAKE) -B CC=$(IWYU_CC)
790db52d626SJeremy L Thompson
7914859b599SJed Brownprint :
7924859b599SJed Brown	@echo $(VAR)=$($(VAR))
793582447c9SJed Brown
7949df38c42SVeselin Dobrevprint-% :
7959df38c42SVeselin Dobrev	$(info [ variable name]: $*)
7969df38c42SVeselin Dobrev	$(info [        origin]: $(origin $*))
7977bcc1ce4SJed Brown	$(info [        flavor]: $(flavor $*))
7989df38c42SVeselin Dobrev	$(info [         value]: $(value $*))
7999df38c42SVeselin Dobrev	$(info [expanded value]: $($*))
8009df38c42SVeselin Dobrev	$(info )
8019df38c42SVeselin Dobrev	@true
8029df38c42SVeselin Dobrev
803b0ab70ddSJed Brown# "make configure" detects any variables passed on the command line or
804b0ab70ddSJed Brown# previously set in config.mk, caching them in config.mk as simple
805b0ab70ddSJed Brown# (:=) variables.  Variables set in config.mk or on the command line
806b0ab70ddSJed Brown# take precedence over the defaults provided in the file.  Typical
807b0ab70ddSJed Brown# usage:
808d3c6b40fSJed Brown#
809d3c6b40fSJed Brown#   make configure CC=/path/to/my/cc CUDA_DIR=/opt/cuda
810d3c6b40fSJed Brown#   make
811d3c6b40fSJed Brown#   make prove
812b0ab70ddSJed Brown#
813b0ab70ddSJed Brown# The values in the file can be updated by passing them on the command
814b0ab70ddSJed Brown# line, e.g.,
815b0ab70ddSJed Brown#
816b0ab70ddSJed Brown#   make configure CC=/path/to/other/clang
817b0ab70ddSJed Brown
818b0ab70ddSJed Brown# All variables to consider for caching
81930f4f45fSnbeamsCONFIG_VARS = CC CXX FC NVCC NVCC_CXX HIPCC \
820bd882c8aSJames Wright  OPT CFLAGS CPPFLAGS CXXFLAGS FFLAGS NVCCFLAGS HIPCCFLAGS SYCLFLAGS \
8211d013790SJed Brown  AR ARFLAGS LDFLAGS LDLIBS LIBCXX SED \
822bd882c8aSJames Wright  MAGMA_DIR OCCA_DIR XSMM_DIR CUDA_DIR CUDA_ARCH MFEM_DIR PETSC_DIR NEK5K_DIR ROCM_DIR HIP_ARCH SYCL_DIR
823b0ab70ddSJed Brown
824b0ab70ddSJed Brown# $(call needs_save,CFLAGS) returns true (a nonempty string) if CFLAGS
825b0ab70ddSJed Brown# was set on the command line or in config.mk (where it will appear as
826b0ab70ddSJed Brown# a simple variable).
827b0ab70ddSJed Brownneeds_save = $(or $(filter command line,$(origin $(1))),$(filter simple,$(flavor $(1))))
828b0ab70ddSJed Brown
829d3c6b40fSJed Brownconfigure :
830b0ab70ddSJed Brown	$(file > $(CONFIG))
831b0ab70ddSJed Brown	$(foreach v,$(CONFIG_VARS),$(if $(call needs_save,$(v)),$(file >> $(CONFIG),$(v) := $($(v)))))
832b0ab70ddSJed Brown	@echo "Configuration cached in $(CONFIG):"
833b0ab70ddSJed Brown	@cat $(CONFIG)
834d3c6b40fSJed Brown
83561130325SJed Brownwheel : export MARCHFLAG = -march=generic
83661130325SJed Brownwheel : export WHEEL_PLAT = manylinux2010_x86_64
83737c134eaSJed Brownwheel :
838dabe13fcSJed Brown	docker run -it --user $(shell id -u):$(shell id -g) --rm -v $(PWD):/io -w /io \
83961130325SJed Brown	  -e MARCHFLAG -e WHEEL_PLAT \
84061130325SJed Brown	  quay.io/pypa/$(WHEEL_PLAT) python/make-wheels.sh
841d3c6b40fSJed Brown
84237c134eaSJed Brown.PHONY : configure wheel
84337c134eaSJed Brown
84437c134eaSJed Brown# Include *.d deps when not -B = --always-make: useful if the paths are wonky in a container
84537c134eaSJed Brown-include $(if $(filter B,$(MAKEFLAGS)),,$(libceed.c:%.c=$(OBJDIR)/%.d) $(tests.c:tests/%.c=$(OBJDIR)/%.d))
846