copy_ip你用过吗?

在Vivado工程中使用IP是非常常见的情形,而且还会出现同一个IP被多次使用。例如,设计中需要用到4个单端口RAM,其区别仅仅是深度或宽度(数据位宽)不一样,那么这时候怎么做比较快捷呢?

 

一种方式是在Vivado IP Catalog中找到Block Memory Generator,依次根据需求定制4个单端口RAM,这个过程需要4次打开Block Memory Generator,除了深度和宽度之外,重复设定同样的参数。

 

还有一种方式就是我们这里将要介绍的Tcl命令copy_ip。从名字就可以猜出来其功能就是对IP进行复制。所以,对于上述情形,更简洁的方式是利用Block Memory Generator创建一个IP,其余3个用copy_ip进行复制,然后再修改其中的深度和宽度两个参数。这种方式尤其在IP的参数很多时更为高效,因为这样可以继承诸多参数而避免重复设置。

 

来看个案例,设计中有个IP名为char_fifo,现在还需要一个FIFO,那么可以通过如下方式操作:

 

 

这里选项-name后为新IP的名字,中括号为Tcl的命令置换方式,中括号中的内容为命令get_ips,用于获取指定IP,也就是要复制的IP对象。copy_ip还可以跟随选项-dir,用于指定IP的位置。如果没有跟随-dir,那么复制后的IP将被放置在与原有IP相同的目录下,同时出现在Vivado的IP目录下,如下图所示。

 

 

如果不习惯用Tcl命令的方式,那么也可以用图形界面方式。只需选中目标IP,点击鼠标右键,在弹出菜单中选择Copy IP即可。而这个操作实质上对应的命令就是copy_ip,这可在Vivado Tcl Console中看到。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值