如何方便地使用TCL恢复带BD设计的Vivado工程

恢复无BD设计的Vivado工程

当工程中无Block Design设计时,工程恢复过程相对简单。使用write_project_tcl命令可以直接生成用于恢复工程的tcl文件,如*_prj.tcl,在恢复时直接运行就可以了。

修改恢复工程的路径

*_prj.tcl在恢复工程时会将其放在tcl文件所在的文件夹。每个人都有各自喜好的工程目录结构,我比较喜欢将源文件、IP文件、BD文件和tcl文件放在不同的文件夹中,工程文件放在project文件夹中,这些文件夹处于统一层次。

所以我在恢复工程前,需要对*_prj.tcl进行小的修改。在*_prj.tcl中有两个关键变量,分别是origin_dir和orig_proj_dir。前者是指源文件的路径,我把它修改为tcl所在文件夹的上一层;后者是恢复的工程所在的路径,把它修改为tcl所在文件夹的上一层,名称为project的文件夹。修改如下。

set origin_dir "." ----> set origin_dir ".."

set orig_proj_dir "[file normalize "$origin_dir/top"]" ----> set orig_proj_dir "[file normalize "$origin_dir/project"]"

恢复带BD设计的Vivado工程

使用write_bd_tcl命令可以直接生成用于bd设计的tcl文件,如_bd.tcl。这样我们就有了两个tcl文件,_bd.tcl和*_prj.tcl。按照以下步骤修改tcl文件。

  1. 修改tcl中的路径

除*_prj.tcl外,*_bd.tcl也需要修改相应的路径。由于在原工程中,BD设计是在bds这个文件夹中,所生成的*_bd.tcl也将使用该文件夹,但是是放在tcl所在的路径下的,需要把他重新指向上层目录的bds中。

set origin_dir ./bds ----> set origin_dir ../bds

2. 为bd生成wrapper文件

在*_bd.tcl的最后添加以下代码。

make_wrapper -files [get_files $origin_dir/bds/mybd/mybd.bd] -top -import

该代码为bd设计生成顶层的wrapper.v,该文件在*_prj.tcl会用到。如果没有,恢复工程时会报找不到wrapper.v的错误。

3. 关闭project

在新建bd时是需要先打开一个project的,如果没有已打开的project,在调用_bd.tcl时会自动新建一个。这个新建的project在完成bd恢复后就没用了,可以关闭并删除。所以在*_bd.tcl的最后在添上以下代码。

close_project -delete

4. 恢复工程

为了运行方便,新建一个run.tcl,先后调用两个tcl文件,整个工程就能顺利恢复出来。

source ./*_bd.tcl
source ./*_prj.tcl

当BD中包含自定义IP如何恢复Vivado工程

在BD中调用了自己封装的IP时,按照上述流程恢复工程时会报错。这是因为*_bd.tcl在执行时会检查BD中IP的状态,而用户自己封装的IP还没有加入ip_catalog中。如*_bd.tcl中的下面这段代码。

##################################################################
# CHECK IPs
##################################################################
set bCheckIPs 1
if { $bCheckIPs == 1 } {set list_check_ips "****BD‘s IP List****”}

所以需要在CHECK IPs之前添加以下代码,用于加入用户IP路径并刷新ip_catalog。

set origin_dir ".."# Set IP repository paths
set obj [get_filesets sources_1]
set_property "ip_repo_paths" "[file normalize "$origin_dir/ips/User Created IP Directory"]" $obj# Rebuild user ip_repo's index before adding any source files
update_ip_catalog -rebuild

该方法可以恢复带BD以及自定义IP的工程。但是恢复后的工程中,除了在bds文件夹中存在BD设计文件(这是由*_bd.tcl生成的),在project->top.srcs->sources_1->bd中还会有一份同样的BD设计文件(这是由*_prj.tcl生成的)。为了避免这种情况发生,还需要删除*_prj.tcl中的proc cr_bd_xdma { parentCell }函数(也可以不删除,不调用即可)以及相关调用,如下。

cr_bd_*** ""
set_property REGISTERED_WITH_MANAGER "1" [get_files ***.bd ] 
set_property SYNTH_CHECKPOINT_MODE "Hierarchical" [get_files ***.bd ] 

然后使用add_files将BD文件添加进工程并刷新sources_1,即如下代码。这样修改后,在project文件夹下就不会再出现另一份BD设计文件了。

add_files -norecurse $origin_dir/bds/***/***.bd
export_ip_user_files -of_objects [get_files $origin_dir/bds/***/***.bd] -force -quiet
update_compile_order -fileset sources_1

以上就是我用来恢复Vivado工程的方法,过程简单,代码基本上都是由Vivado生成。不过在修改代码时要特别注意,*_bd.tcl和*_prj.tcl是顺序调用的,两个文件中有很多变量的名字是相同的。如果要修改这些变量,需要再三确认。如果后面的程序也用到这些变量,要搞清楚他们是否需要修改。如果需要修改,那么是否被重新赋予正确的值。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/19120.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

监控对象都有哪些分类

1、业务监控 这类指标是管理层非常关注的,代表企业营收,或者跟客户主流程相关,类似 BI 数据。不过相比 BI 数据,业务监控指标有两点不同。 对精确度要求没有那么高:因为监控只要发现趋势异常就可以,至于是…

极简在线商城系统,支持docker一键部署

Hmart 给大家推荐一个简约自适应电子商城系统,针对虚拟商品在线发货,支持企业微信通知,支持docker一键部署,个人资质也可搭建。 前端 后端 H2 console 运行命令 docker run -d --name mall --restartalways -p 8080:8080 -e co…

LeetCode_贪心算法_中等_763.划分字母区间

目录 1.题目2.思路3.代码实现(Java) 1.题目 给你一个字符串 s 。我们要把这个字符串划分为尽可能多的片段,同一字母最多出现在一个片段中。注意,划分结果需要满足:将所有划分结果按顺序连接,得到的字符串仍…

Jackson:String转object反序列化失败

场景 消费mq时String转Object 代码 for (MessageExt msg : msgs) {String msgBody new String(msg.getBody(), StandardCharsets.UTF_8);BinlogEvent binlogEvent JsonUtil.silentString2Object(msgBody, BinlogEvent.class);binlogEvent.setPort(Long.valueOf(port));tCo…

SAP CAP篇十二:AppRouter 深入研究

本文目录 本系列文章理解现有程序app文件夹中的package.json理解approuter.js 修改现有程序修改package.json新建index.js在Approuter中显示额外的逻辑 添加一些额外的Logger对应代码及branch 本系列文章 SAP CAP篇一: 快速创建一个Service,基于Java的实现 SAP CAP…

深入浅出Pytorch函数——torch.sum

分类目录:《深入浅出Pytorch函数》总目录 相关文章: 深入浅出Pytorch函数——torch.Tensor 函数torch.sum有两种形式: torch.sum(input, *, dtypeNone):返回输入张量input所有元素的和。torch.sum(input, dim, keepdimFalse, *,…

2308C++技巧

struct ubiq {template <class Type>constexpr operator Type() const {return Type{};}; }; // int i ubiq{}; double d ubiq{}; char c ubiq{}; //可以多个同时初化. template <class T, std::size_t... I> constexpr auto 类型转标识数组(std::size_t* types…

(AcWing)多重背包问题 I,II

有 N 种物品和一个容量是 V 的背包。 第 i 种物品最多有 si 件&#xff0c;每件体积是 vi&#xff0c;价值是 wi。 求解将哪些物品装入背包&#xff0c;可使物品体积总和不超过背包容量&#xff0c;且价值总和最大。 输出最大价值。 输入格式 第一行两个整数 N&#xff0c;…

使用树莓派picow和drv8833驱动直流电机

raspberry pico w引脚图 1. 准备工作 板子编辑器raspberry pico wmicropython&#xff08;thonny编辑器&#xff09; 最新的raspberry pi pico w系统包下载地址。 点亮板载led灯 需要注意的是pico的板载led灯是GPIO25引脚&#xff0c;picow的板子led灯则直接用Pin包的&qu…

Spring依赖注入Bean属性

目录 1.依赖注入 1.1构造 1.2set注入 2.基于XML的自动装配 2.1根据名称: 2.2根据类型: 2.3根据构造自动注入 3.Spring 文件中 Bean属性 1.依赖注入 依赖注入&#xff0c;是IOC的一个方面&#xff0c;是个通常的概念&#xff0c;它有多种解释。这概念是说你不用创建对象&…

Unity 使用SharpZipLib解压时报错

报错信息&#xff1a; NotSupportedException: Encoding 936 data could not be found. Make sure you have correct international System.Text.Encoding.GetEncoding (System.Int32 codepage) ICSharpCode.SharpZipLib.Zip.ZipConstants.ConvertToString。 出现问题分析&…

【leetcode】138.复制带随机指针的链表

方法一&#xff1a;暴力求解 1️⃣遍历原链表&#xff0c;复制节点尾插 2️⃣更新random&#xff0c;原链表中的random对应第几个节点则复制链表中的random就对应第几个 &#x1f4d6;Note 不能通过节点中的val判断random的指向&#xff0c;因为链表中可能存在两个val相等的节点…

【PCB专题】案例:Allegro如何在PCB板上直接修改封装中的特定焊盘

在实际产品设计中我们很可能因为结构、封装的制约而将两个器件放的很近。并且也可能因为是接口器件,所以要求上锡量要多。 但是因为成本的原因我们很可能不会去为了几个器件增加钢网的阶数,以求获得更多的锡量,让PIN脚爬锡更好。而会通过扩大钢网开口的形式来增加锡量。 如…

代码随想录—力扣算法题:704二分查找.Java版(示例代码与导图详解)

版本说明 当前版本号[20230802]。 版本修改说明20230802初版 目录 文章目录 版本说明目录数组数组理论基础二分查找思路左闭右闭[left, right]左闭右开[left, right)两种方法的区别总结 数组 数组理论基础 数组是存放在连续内存空间上的相同类型数据的集合。 数组可以方便…

基于Spring Boot的美食分享网站设计与实现(Java+spring boot+MySQL)

获取源码或者论文请私信博主 演示视频&#xff1a; 基于Spring Boot的美食分享网站设计与实现&#xff08;Javaspring bootMySQL&#xff09; 使用技术&#xff1a; 前端&#xff1a;html css javascript jQuery ajax thymeleaf 微信小程序 后端&#xff1a;Java springboot…

深入解析Linux进程内存:VSS、RSS、PSS、USS及查看方式

VSS 虚拟耗用内存大小&#xff0c;是进程可以访问的所有虚拟内存的总量&#xff0c;包括进程独自占用的物理内存、和其他进程共享的内存、分配但未使用的内存。 RSS 驻留内存大小&#xff0c;是进程当前实际占用的物理内存大小&#xff0c;包括进程独自占用的物理内存、和其…

1400*C. Computer Game

Example input 6 15 5 3 2 15 5 4 3 15 5 2 1 15 5 5 1 16 7 5 2 20 5 7 3 output 4 -1 5 2 0 1 解析&#xff1a; k个电&#xff0c; 第一种为 k>a 时&#xff0c;只玩游戏 k-a; 第二种&#xff0c;k>b,一边玩一边充电 k-b 问完成n轮游戏的情况下&#xff0c;优先第…

配置VS Code 使其支持vue项目断点调试

起因 每个应用&#xff0c;不论大小&#xff0c;都需要理解程序是如何运行失败的。当我们写的程序没有按照自己写的逻辑走的时候&#xff0c;我们就会逐步一一排查问题。在平常开发过程中我们可能会借助 console.log 来排查,但是现在我们可以借助 VS Code 断点来调试项目。 前…

防火墙监控工具

防火墙监控是跟踪在高效防火墙性能中起着关键作用的重要防火墙指标&#xff0c;防火墙监控通常应包括&#xff1a; 防火墙日志监控防火墙规则监控防火墙配置监控防火墙警报监控 防火墙监控服务的一个重要方面是它应该是主动的。主动识别内部和外部安全威胁有助于在早期阶段识…

使用Gunicorn+Nginx部署Flask项目

部署-开发机上的准备工作 确认项目没有bug。用pip freeze > requirements.txt将当前环境的包导出到requirements.txt文件中&#xff0c;方便部署的时候安装。将项目上传到服务器上的/srv目录下。这里以git为例。使用git比其他上传方式&#xff08;比如使用pycharm&#xff…