105 lines
3.0 KiB
Makefile
105 lines
3.0 KiB
Makefile
OS := $(shell uname)
|
|
|
|
RABIT_BUILD_DMLC = 0
|
|
|
|
export WARNFLAGS= -Wall -Wextra -Wno-unused-parameter -Wno-unknown-pragmas -std=c++11
|
|
export CFLAGS = -O3 $(WARNFLAGS)
|
|
export LDFLAGS =-Llib
|
|
|
|
#download mpi
|
|
#echo $(shell scripts/mpi.sh)
|
|
|
|
MPICXX=./mpich/bin/mpicxx
|
|
|
|
export CXX = g++
|
|
|
|
|
|
#----------------------------
|
|
# Settings for power and arm arch
|
|
#----------------------------
|
|
ARCH := $(shell uname -a)
|
|
ifneq (,$(filter $(ARCH), armv6l armv7l powerpc64le ppc64le aarch64))
|
|
CFLAGS += -march=native
|
|
else
|
|
CFLAGS += -msse2
|
|
endif
|
|
|
|
ifndef WITH_FPIC
|
|
WITH_FPIC = 1
|
|
endif
|
|
ifeq ($(WITH_FPIC), 1)
|
|
CFLAGS += -fPIC
|
|
endif
|
|
|
|
ifndef LINT_LANG
|
|
LINT_LANG="all"
|
|
endif
|
|
|
|
ifeq ($(RABIT_BUILD_DMLC),1)
|
|
DMLC=dmlc-core
|
|
else
|
|
DMLC=../dmlc-core
|
|
endif
|
|
|
|
CFLAGS += -I $(DMLC)/include -I include/
|
|
|
|
# build path
|
|
BPATH=.
|
|
# objectives that makes up rabit library
|
|
MPIOBJ= $(BPATH)/engine_mpi.o
|
|
OBJ= $(BPATH)/allreduce_base.o $(BPATH)/allreduce_robust.o $(BPATH)/engine.o $(BPATH)/engine_empty.o $(BPATH)/engine_mock.o\
|
|
$(BPATH)/c_api.o $(BPATH)/engine_base.o
|
|
SLIB= lib/librabit.so lib/librabit_mock.so lib/librabit_base.so
|
|
ALIB= lib/librabit.a lib/librabit_empty.a lib/librabit_mock.a lib/librabit_base.a
|
|
MPISLIB= lib/librabit_mpi.so
|
|
MPIALIB= lib/librabit_mpi.a
|
|
HEADERS=src/*.h include/rabit/*.h include/rabit/internal/*.h
|
|
|
|
.PHONY: clean all install mpi python lint doc doxygen
|
|
|
|
all: lib/librabit.a lib/librabit_mock.a lib/librabit.so lib/librabit_base.a lib/librabit_mock.so
|
|
mpi: lib/librabit_mpi.a lib/librabit_mpi.so
|
|
|
|
$(BPATH)/allreduce_base.o: src/allreduce_base.cc $(HEADERS)
|
|
$(BPATH)/engine.o: src/engine.cc $(HEADERS)
|
|
$(BPATH)/allreduce_robust.o: src/allreduce_robust.cc $(HEADERS)
|
|
$(BPATH)/engine_mpi.o: src/engine_mpi.cc $(HEADERS)
|
|
$(BPATH)/engine_empty.o: src/engine_empty.cc $(HEADERS)
|
|
$(BPATH)/engine_mock.o: src/engine_mock.cc $(HEADERS)
|
|
$(BPATH)/engine_base.o: src/engine_base.cc $(HEADERS)
|
|
$(BPATH)/c_api.o: src/c_api.cc $(HEADERS)
|
|
|
|
lib/librabit.a lib/librabit.so: $(BPATH)/allreduce_base.o $(BPATH)/allreduce_robust.o $(BPATH)/engine.o $(BPATH)/c_api.o
|
|
lib/librabit_base.a lib/librabit_base.so: $(BPATH)/allreduce_base.o $(BPATH)/engine_base.o $(BPATH)/c_api.o
|
|
lib/librabit_mock.a lib/librabit_mock.so: $(BPATH)/allreduce_base.o $(BPATH)/allreduce_robust.o $(BPATH)/engine_mock.o $(BPATH)/c_api.o
|
|
lib/librabit_empty.a: $(BPATH)/engine_empty.o $(BPATH)/c_api.o
|
|
lib/librabit_mpi.a lib/librabit_mpi.so: $(MPIOBJ)
|
|
|
|
$(OBJ) :
|
|
$(CXX) -c $(CFLAGS) -o $@ $(firstword $(filter %.cpp %.c %.cc, $^) )
|
|
|
|
$(ALIB):
|
|
ar cr $@ $+
|
|
|
|
$(SLIB) :
|
|
$(CXX) $(CFLAGS) -shared -o $@ $(filter %.cpp %.o %.c %.cc %.a, $^) $(LDFLAGS)
|
|
|
|
$(MPIOBJ) :
|
|
$(MPICXX) -c $(CFLAGS) -I./mpich/include -o $@ $(firstword $(filter %.cpp %.c %.cc, $^) )
|
|
|
|
$(MPIALIB):
|
|
ar cr $@ $+
|
|
|
|
$(MPISLIB) :
|
|
$(MPICXX) $(CFLAGS) -I./mpich/include -shared -o $@ $(filter %.cpp %.o %.c %.cc %.a, $^) \
|
|
$(LDFLAGS) -L./mpich/lib -Wl,-rpath,./mpich/lib -lmpi
|
|
|
|
lint:
|
|
$(DMLC)/scripts/lint.py rabit $(LINT_LANG) src include
|
|
|
|
doc doxygen:
|
|
cd include; doxygen ../doc/Doxyfile; cd -
|
|
|
|
clean:
|
|
$(RM) $(OBJ) $(MPIOBJ) $(ALIB) $(MPIALIB) $(SLIB) *~ src/*~ include/*~ include/*/*~
|