export LDFLAGS = -pthread -lm export CFLAGS = -std=c++11 -Wall -O2 -Wno-unknown-pragmas -funroll-loops\ -Iinclude -Idmlc-core/include -IHalideIR/src -fPIC # specify tensor path .PHONY: clean all test doc all: lib/libtvm.a lib/libtvm.so LIB_HALIDE_IR = HalideIR/lib/libHalideIR.a SRC = $(wildcard src/*.cc src/*/*.cc) ALL_OBJ = $(patsubst src/%.cc, build/%.o, $(SRC)) ALL_DEP = $(ALL_OBJ) $(LIB_HALIDE_IR) include tests/cpp/unittest.mk test: $(TEST) build/%.o: src/%.cc @mkdir -p $(@D) $(CXX) $(CFLAGS) -MM -MT build/$*.o $< >build/$*.d $(CXX) -c $(CFLAGS) -c $< -o $@ lib/libtvm.a: $(ALL_DEP) @mkdir -p $(@D) ar crv $@ $(filter %.o, $?) lib/libtvm.so: $(ALL_DEP) @mkdir -p $(@D) $(CXX) $(CFLAGS) -shared -o $@ $(filter %.o %.a, $^) $(LDFLAGS) $(LIB_HALIDE_IR): LIBHALIDEIR LIBHALIDEIR: + cd HalideIR; make lib/libHalideIR.a ; cd $(ROOTDIR) lint: python2 dmlc-core/scripts/lint.py tvm cpp include src doc: doxygen docs/Doxyfile clean: $(RM) -rf build lib bin *~ */*~ */*/*~ */*/*/*~ */*.o */*/*.o */*/*/*.o */*.d */*/*.d */*/*/*.d -include build/*.d -include build/*/*.d