makefile 1.1 KB

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