makefile 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  1. CXX=/usr/bin/g++
  2. SRC_DIR=src
  3. INC_DIR=include
  4. BUILD_DIR=build
  5. TESTS_DIR=tests
  6. FPGA_LIB_DIR=lib/mlfpga
  7. CFLAGS=-g -Wall -pthread -std=c++11
  8. LFLAGS=-shared -Wl,--no-as-needed,-Map=$(BUILD_DIR)/project.map
  9. TF_CFLAGS=$(shell cat $(BUILD_DIR)/TF_CFLAGS)
  10. TF_LFLAGS=$(shell cat $(BUILD_DIR)/TF_LFLAGS)
  11. SRCS=$(wildcard $(SRC_DIR)/*.cpp)
  12. OBJS=$(patsubst $(SRC_DIR)/%.cpp,$(BUILD_DIR)/%.o,$(SRCS))
  13. FPGA_LIB_SRCS=$(wildcard $(FPGA_LIB_DIR)/$(SRC_DIR)/*.cpp)
  14. FPGA_LIB_OBJS=$(patsubst $(FPGA_LIB_DIR)/$(SRC_DIR)/%.cpp,$(BUILD_DIR)/%.o,$(FPGA_LIB_SRCS))
  15. TESTS_SRCS=$(wildcard $(TESTS_DIR)/*.cpp)
  16. FPGA_LIB_TESTS_SRCS=$(wildcard $(FPGA_LIB_DIR)/$(TESTS_DIR)/*.cpp)
  17. EXECUTABLE=op_lib.so
  18. TEST_EXEC=test
  19. all: config $(BUILD_DIR)/$(EXECUTABLE)
  20. config:
  21. @if [ ! -f "$(BUILD_DIR)/TF_CFLAGS" -o ! -f "$(BUILD_DIR)/TF_LFLAGS" ]; then ./configure $(BUILD_DIR) || exit 1; fi
  22. $(BUILD_DIR)/$(EXECUTABLE): $(OBJS) $(FPGA_LIB_OBJS)
  23. $(CXX) $(LFLAGS) $(TF_LFLAGS) -o $@ $^
  24. $(OBJS): $(BUILD_DIR)/%.o : $(SRC_DIR)/%.cpp $(INC_DIR)/%.hpp
  25. $(CXX) $(CFLAGS) -fPIC -c $(TF_CFLAGS) -I$(INC_DIR) -o $@ $<
  26. $(FPGA_LIB_OBJS): $(BUILD_DIR)/%.o : $(FPGA_LIB_DIR)/$(SRC_DIR)/%.cpp $(FPGA_LIB_DIR)/$(INC_DIR)/%.hpp
  27. $(CXX) $(CFLAGS) -fPIC -c -I$(FPGA_LIB_DIR)/$(INC_DIR) -o $@ $<
  28. test: config $(BUILD_DIR)/$(EXECUTABLE) $(BUILD_DIR)/$(TEST_EXEC)
  29. $(BUILD_DIR)/$(TEST_EXEC): $(TESTS_SRCS) $(FPGA_LIB_OBJS)
  30. $(CXX) $(CFLAGS) -I$(FPGA_LIB_DIR)/$(INC_DIR) -o $@ $^
  31. clean:
  32. rm -f $(BUILD_DIR)/*.o $(BUILD_DIR)/$(EXECUTABLE) $(BUILD_DIR)/$(TEST_EXEC)