制作:没有实现目标的规则 - 找不到源文件

Make: No rule to make target -- Cannot find source files

本文关键字:规则 找不到 源文件 目标 实现 制作      更新时间:2023-10-16

我有一个带有以下目录结构的项目

.
 Adder_PL
    bin
    main.cc
    Makefile
    obj
 SystemC
    my_models
       include
          add.h
       lib
          add.cpp
    Xilinx
        include
           amba.h
           debugdev.h
           demo-dma.h
           genattr.h
           iconnect.h
           memory.h
           remote-port-proto.h
           remote-port-sk.h
           remote-port-tlm.h
           remote-port-tlm-memory-master.h
           remote-port-tlm-memory-slave.h
           remote-port-tlm-wires.h
           safeio.h
           tlm2apb-bridge.h
           tlm2axi-bridge.h
           tlm2axilite-bridge.h
           trace.h
           xilinx-zynq.h
           xilinx-zynqmp.h
        lib
           debugdev.cc
           demo-dma.cc
           memory.cc
           remote-port-tlm.cc
           remote-port-tlm-memory-master.cc
           remote-port-tlm-memory-slave.cc
           remote-port-tlm-wires.cc
           trace.cc
           xilinx-zynq.cc
           xilinx-zynqmp.cc

位于adder_pl中的makefile位置。我想使用我从QEMU主机和SystemC模型之间的演示中移植的Xilinx Systemc模型。我虽然构建它很难。

[jfrye@cserh4 adder_pl] $ make

make:警告:文件" makefile"的修改时间10229 s 未来

制作:***没有规则 /home/epi/jfrye_xilinx/Cosimulation/Adder_PL/obj/remote-port-tlm-memory-master.o', needed by adder_pl'。停止。

这是makefile

CXX=g++
EXEC=./bin/adder_pl
#directories
XILINX_DIR=/home/epi/jfrye_xilinx/Cosimulation/SystemC/Xilinx
MY_MODELS_DIR=/home/epi/jfrye_xilinx/Cosimulation/SystemC/my_models
SYSTEMC_DIR=/home/epi/jfrye_xilinx/SystemC/systemc-2.3.2
OBJ_DIR=/home/epi/jfrye_xilinx/Cosimulation/Adder_PL/obj/
#includes
XILINX_INC=$(XILINX_DIR)/include
MY_MODELS_INC=$(MY_MODELS_DIR)/include
SYSTEMC_INC=$(SYSTEMC_DIR)/include
INC=-I$(XILINX_INC) -I$(MY_MODELS_INC) -I$(SYSTEMC_INC)
#libs
LIB=-L/home/epi/jfrye_xilinx/SystemC/systemc-2.3.2/lib-linux64
LIBS=-lsystemc
#src and obj
XILINX_SRC_DIR=$(XILINX_DIR)/lib
MY_MODELS_SRC_DIR=$(MY_MODELS_DIR)/lib
XILINX_SRC=$(wildcard $(XILINX_SRC_DIR)/*.cc)
XILINX_OBJ=$(patsubst $(XILINX_SRC_DIR)/%.cc, $(OBJ_DIR)%.o, $(XILINX_SRC))
MY_MODELS_SRC=$(wildcard $(MY_MODELS_SRC_DIR)/*.cc)
MY_MODELS_OBJ=$(patsubst $(MY_MODELS_SRC_DIR)/%.cc, $(OBJ_DIR)/%.o, $(MY_MODELS_SRC))
MAIN_OBJ=$(OBJ_DIR)/main.o
#all objects
OBJS = $(XILINX_OBJ) $(MY_MODELS_OBJ) $(MAIN_OBJ)
#rules
adder_pl: $(OBJS)
    $(CXX) -o $(EXEC) $(OBJS) $(INC) $(LIB) $(LIBS)
$(XILINX_OBJ_DIR)/%.o: $(XILINX_SRC_DIR)/%.cc
    $(CXX) $(INC) $(LIB) $(LIBS) -c -o $@ $<
$(MY_MODELS_OBJ_DIR)/%.o: $(MY_MODELS_SRC_DIR)/%.cc
    $(CXX) $(INC) $(LIB) $(LIBS) -c -o $@ $<
$(MAIN_OBJ): main.cc
    $(CXX) $(INC) $(LIB) $(LIBS) -c main.cc -o $(MAIN_OBJ)
.PHONY: clean
clean:
    rm $(XILINX_OBJ_DIR)/*.o $(MY_MODELS_OBJ_DIR)/*.o $(EXEC)

显然,我正在正确地构建$(objs),因为它正在尝试创建/home/epi/jfrye_xilinx/cosimulation/adder_pl/adder_pl/obj/remote-port-port-tlm-memory-master.o 是我不明白为什么它在第二个规则上失败了,我认为这意味着它也会使第三个规则失败。

我从另一个示例中移植了它。$@和$&lt;意思是?也许它们是问题的根源。

您的问题是需要/home/epi/jfrye_xilinx/Cosimulation/Adder_PL/obj/remote-port-tlm-memory-master.o,但没有规则来构建它。这意味着目标模式:

$(XILINX_OBJ_DIR)/%.o: $(XILINX_SRC_DIR)/%.cc

确实匹配了目标和源。这可能是因为XILINX_OBJ_DIR从未定义。添加行:

$(info XILINX_OBJ_DIR=$(XILINX_OBJ_DIR))
$(info XILINX_OBJ_DIR=$(XILINX_SRC_DIR))

就在您的#rules行之前,然后重新运行这些变量扩展到。