[X]关闭

MiZ702学习笔记12——封装一个普通的VGA IP

文档创建者:宋桓公
浏览次数:6558
最后更新:2016-02-10

还记得《MiZ702学习笔记(番外篇)——纯PL VGA驱动》这篇文章中,用verilog写了一个VGA驱动。我们今天要介绍的就是将这个工程打包成一个普通的IP,目的是为后面的一篇文章做个铺垫。
打包成一个普通的IP的目的,可以直接将这个IP粘贴到Block文件中。(和用文本实例化是一个意思)。应为我们调用zynq的核的时候一般是用Block的形式,为了zynq和我们的VGA模块更方便的组织起来,就需要这种IP打包方式。
为什么是强调是普通的IP,这个主意是区分带AXI接口的IP,这个在后面介绍。
这个打包过程十分简单,新建一个vivado工程之后,准备好我们的VGA verilog源文件:

我将这些文件当中,当前工程下的song文件夹下备用。然后选择Tools Create and Package IP:

点击NEXT:

选择如下标记中形式的IP:

接下来是关键的一步,选择刚才我们准备好的源文件的位置,并点击NEXT:

继续NEXT:

最后点击Finish:

点击Finish之后,会自动创建一个新的工程,专门针对这个IP的工程。注意到红色方框内,有个name属性,这里他的名字就是你顶层文件的名字加上了一个版本号,软件自动给你填写的,记住这个名字,之后添加IP的时候,就是根据这个名字来找到我们的IP。

有个警告,懒得理他不影响,我们直接打包:

按下Package IP就完成打包了,这个工程就自动关闭了,回到我最先新建的工程,就可以添加我们打包的IP了。
首先新建一个Block,然后选择add IP,搜索那个顶层文件的名字,就能找到啦~~

双击它,就可以添加到Block文件中了:

这种图形的实例化和文本的实例化,大家都需要熟练地运用,今天就到这里。

发表评论已发布 2

ace2008888

发表于 2016-2-10 16:10:26 | 显示全部楼层

    宋工,你好,我封装了一个基于STREAM的VGA驱动,采用DMA的方式,但是现在的问题是,上面传下去的数据,只能接收一次,由于,这个板子的资料比较少,能不能帮我看下什么原因,我把工程给你,帮我搞一下,谢谢。
    我QQ 77257734  ,麻烦了。

ace2008888

发表于 2016-2-10 16:15:03 | 显示全部楼层

  我电脑是2015.4版本的,里面的TPG这个IP用不了,说是要收费,帮我看看,
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则