没有规则根据模式制作目标文件

时间:2017-12-18 18:02:07

标签: makefile gnu-make

您好我正在尝试构建我的C ++项目。我目前有一个makefile,列出了我想要制作的.o文件的所有名称。然后我将目录添加到我希望它们编译到的地方。最后,我有两个基本规则来处理构建每个目标文件,然后处理这些目标文件中的可执行文件。无论出于何种原因,make都无法识别模式。这是makefile

CXX=g++
SRC_DIR=/home/epi/jfrye_xilinx/Cosimulation/SystemC/Xilinx/lib
INC_DIR=-I/home/epi/jfrye_xilinx/Cosimulation/SystemC/Xilinx/include
INC_DIR += -I/home/epi/jfrye_xilinx/SystemC/systemc-2.3.2/include

LIB_DIR=-L/home/epi/jfrye_xilinx/SystemC/system-2.3.2/lib-linux64
LIB_TAGS=-lsystemc

OBJ_DIR=/home/epi/jfrye_xilinx/Cosimulation/Adder_PL/obj

ZYNQ_DEMO=/home/epi/jfrye_xilinx/Cosimulation/Adder_PL/bin/zynq_demo
ZYNQMP_DEMO=/home/epi/jfrye_xilinx/Cosimulation/Adder_PL/bin/zynqmp_demo

OBJS+ = memory.o trace.o debugdev.o demo-dma.o xilinx-zynq.o xilinx-zynqmp.o
OBJS += safeio.o remote-port-proto.o remote-port-sk.o remote-port-tlm.o
OBJS += remote-port-tlm-memory-master.o remote-port-tlm-memory-slave.o
OBJS += remote-port-tlm-wires.o

_ZYNQ_OBJS=zynq_demo.o
_ZYNQMP_OBJS=zynqmp_demo.o

_ZYNQ_OBJS += $(OBJS)
_ZYNQMP_OBJS += $(OBJS)

ZYNQ_OBJS=$(addprefix $(OBJ_DIR)/, $(_ZYNQ_OBJS))
ZYNPMP_OBJS=$(addprefix $(OBJDIR)/, $(_ZYNQMP_OBJS))

$(info $(ZYNQ_OBJS))

all: $(ZYNQ_DEMO) $(ZYNQMP_DEMO)

$(ZYNQ_DEMO): $(ZYNQ_OBJS)

$(ZYNQMP_DEMO): $(ZYNQMP_OBJS)

$(OBJ_DIR)/%.o: $(SRC_DIR)/%.cc
    $(CXX) $(INC_DIR) $(LIB_DIR) $(LIB_TAGS) -c -o $@ $<

我收到错误:

  

制作:***没有制定目标的规则   /home/epi/jfrye_xilinx/Cosimulation/Adder_PL/obj/zynq_demo.o', needed by /家/外延/ jfrye_xilinx /联合仿真/ Adder_PL / bin中/ zynq_demo&#39 ;.   停止。

第四条规则应该照顾zynq_demo.o正确。为什么它不能识别它可以用来构建该目标文件的规则?

1 个答案:

答案 0 :(得分:0)

我不喜欢模式规则。 他们适用的时间和地点对我的口味有点随意。 另一个更好的替代方案是 static pattern rules 。 要使用这些,只需在模式规则前加上这些模式适用的目标。

所以

$(OBJ_DIR)/%.o: $(SRC_DIR)/%.cc
    $(CXX) $(INC_DIR) $(LIB_DIR) $(LIB_TAGS) -c -o $@ $<

简单地变成

${ZYNC_OBJS}: $(OBJ_DIR)/%.o: $(SRC_DIR)/%.cc
    $(CXX) $(INC_DIR) $(LIB_DIR) $(LIB_TAGS) -c -o $@ $<

我说不清楚因为我没有你的源树, 但我怀疑 make 现在会给你一个不同的错误。 关于/home/epi/jfrye_xilinx/Cosimulation/SystemC/Xilinx/lib/zynq_demo.cc遗失的事情可能是(???)。