1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104
|
#-------------------------------------------------------------------------------
# GraphBLAS/Makefile
#-------------------------------------------------------------------------------
# SuiteSparse:GraphBLAS, Timothy A. Davis, (c) 2017-2022, All Rights Reserved.
# SPDX-License-Identifier: Apache-2.0
#-------------------------------------------------------------------------------
# simple Makefile for GraphBLAS, relies on cmake to do the actual build. Use
# the CMAKE_OPTIONS argument to this Makefile to pass options to cmake.
# For example, to compile with 40 threads, use:
#
# make JOBS=40
#
# To compile without using Google's cpu_features package, using 40 threads:
#
# make CMAKE_OPTIONS='-DGBNCPUFEAT=1' JOBS=40
#
# To use multiple options, separate them by a space. For example, to build
# just the library but not cpu_features, and to enable AVX2 but not AVX512F:
#
# make CMAKE_OPTIONS='-DGBNCPUFEAT=1 -DGBAVX2=1' JOBS=40
JOBS ?= 8
default: library
# default is to install only in /usr/local
library:
( cd build && cmake $(CMAKE_OPTIONS) .. && cmake --build . -j${JOBS} )
# install only in SuiteSparse/lib and SuiteSparse/include
local:
( cd build && cmake $(CMAKE_OPTIONS) -DGLOBAL_INSTALL=0 -DLOCAL_INSTALL=1 .. && cmake --build . -j${JOBS} )
# install only in /usr/local (default)
global:
( cd build && cmake $(CMAKE_OPTIONS) -DGLOBAL_INSTALL=1 -DLOCAL_INSTALL=0 .. && cmake --build . -j${JOBS} )
# install in SuiteSparse/lib both and SuiteSparse/include and /usr/local
both:
( cd build && cmake $(CMAKE_OPTIONS) -DGLOBAL_INSTALL=1 -DLOCAL_INSTALL=1 .. && cmake --build . -j${JOBS} )
# enable CUDA (NOTE: not ready for production use)
cuda:
( cd build && cmake $(CMAKE_OPTIONS) -DENABLE_CUDA=1 .. && cmake --build . -j$(JOBS) )
# compile with -g
debug:
( cd build && cmake -DCMAKE_BUILD_TYPE=Debug $(CMAKE_OPTIONS) .. && cmake --build . -j$(JOBS) )
# build the dynamic library and the demos
all:
( cd build && cmake $(CMAKE_OPTIONS) -DDEMO=1 .. && cmake --build . -j$(JOBS) )
# run the demos
demos: all
( cd Demo && ./demo )
# just do 'make' in build; do not rerun the cmake script
remake:
( cd build && cmake --build . -j$(JOBS) )
# just run cmake; do not compile
setup:
( cd build && cmake $(CMAKE_OPTIONS) .. )
# build both the static and dynamic libraries; do not run the demo
static:
( cd build && cmake $(CMAKE_OPTIONS) -DBUILD_GRB_STATIC_LIBRARY=1 .. && cmake --build . -j$(JOBS) )
# installs GraphBLAS to the install location defined by cmake, usually
# /usr/local/lib and /usr/local/include
install:
( cd build && cmake --install . )
# create the Doc/GraphBLAS_UserGuide.pdf
docs:
( cd Doc && $(MAKE) )
# compile the CUDA kernels
gpu:
( cd CUDA && cmake --build . -j${JOBS} )
# remove any installed libraries and #include files
uninstall:
- xargs rm < build/install_manifest.txt
clean: distclean
purge: distclean
# remove all files not in the distribution
distclean:
- rm -rf build/* Demo/*.out Demo/complex_demo_out*.m Tcov/log.txt
- rm -rf Config/*.tmp Source/control.m4
- rm -rf Doc/html/* Doc/*.tmp
( cd GraphBLAS && $(MAKE) distclean )
( cd Test && $(MAKE) distclean )
( cd Tcov && $(MAKE) distclean )
( cd Doc && $(MAKE) distclean )
( cd alternative && $(MAKE) distclean )
|