Vitis报错:fatal error: xxx.h: No such file or directory.

本文指导用户如何修复在使用Vitis工程时遇到的Makefile错误,重点在于修改自定义IP的Makefile,包括调整LIBSOURCES、移除或注释OUTS、添加对象编译规则,并提供正确的Makefile代码示例。
摘要由CSDN通过智能技术生成

在跑vitis工程文件时出现fatal error: xxx.h: No such file or directory.的错误,出现这种情况的主要是出现在大家用了自定义IP。

记住如果时出现Makefile出现错误,并不是你的代码问题而是软件bug,我们需要更改一些文件才能正常跑。

讲解一下怎么改(以创建自定义IP之后开始)

一、找到自定义IP的Makefile文件所在位置

一般位置ip_repo\pl_ram_1_0\drivers\pl_ram_v1_0\src

二、修改

1.LIBSOURCES=*.c更改为LIBSOURCES=$(wildcard *.c)

2.去除OUTS = *.o(或者将用#注释起来)

3.增加两句代码

OBJECTS = $(addsuffix .o, $(basename $(wildcard *.c)))
ASSEMBLY_OBJECTS = $(addsuffix .o, $(basename $(wildcard *.S)))

 

4.替换两处代码,${OUTS}更换成 ${OBJECTS} ${ASSEMBLY_OBJECTS}

整体正确代码如下

COMPILER=
ARCHIVER=
CP=cp
COMPILER_FLAGS=
EXTRA_COMPILER_FLAGS=
LIB=libxil.a

RELEASEDIR=../../../lib
INCLUDEDIR=../../../include
INCLUDES=-I./. -I${INCLUDEDIR}

INCLUDEFILES=*.h
#LIBSOURCES=*.c
LIBSOURCES=$(wildcard *.c)
# OUTS = *.o
OBJECTS = $(addsuffix .o, $(basename $(wildcard *.c)))
ASSEMBLY_OBJECTS = $(addsuffix .o, $(basename $(wildcard *.S)))

libs:
	echo "Compiling pl_ram..."
	$(COMPILER) $(COMPILER_FLAGS) $(EXTRA_COMPILER_FLAGS) $(INCLUDES) $(LIBSOURCES)
#    $(ARCHIVER) -r ${RELEASEDIR}/${LIB} ${OUTS}
	$(ARCHIVER) -r ${RELEASEDIR}/${LIB} ${OBJECTS} ${ASSEMBLY_OBJECTS}
	make clean

include:
	${CP} $(INCLUDEFILES) $(INCLUDEDIR)

clean:
#	 rm -rf ${OUTS}
	rm -rf ${OBJECTS} ${ASSEMBLY_OBJECTS}

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值