在用vivado开发过程中,经常vio调试核,如果要vio输出信号较多,并且信号触发顺序需要控制时,每次通过手动输入就有写麻烦,使用TCL脚本控制vio,只需运行脚本就可以了,极大提升开发效率。
与VIO相关TCL命令
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-DLWWrBnx-1656584404752)(./pic/1.png)]](https://i-blog.csdnimg.cn/blog_migrate/207be96db693f39f30036fad47b3ee10.png)
Vivado TCL控制台
在控制台中输入命令,修改工作目录
cd D:/xxx/project
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-OEkQOKBb-1656584404753)(./pic/2.png)]](https://i-blog.csdnimg.cn/blog_migrate/983b238ff21255a0cc4a2d19809dd5a0.png)
读取VIO输入
当从VIO读取axigpio_int数据时,运行如下指令:
refresh_hw_vio [get_hw_vios {hw_vio_2}]
get_property INPUT_VALUE [get_hw_probes axigpio_int]
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-dpPeco5f-1656584404754)(./pic/3.png)]](https://i-blog.csdnimg.cn/blog_migrate/2f1aa73ba0e8691328cc1afa079b98ba.png)
写 VIO 输出
向gpio写入1111。
set_property OUTPUT_VALUE 1111 [get_hw_probes gpio]
commit_hw_vio [get_hw_probes {gpio}]
编写VIO控制脚本
新建tcl脚本vio.tcl,将脚本存入工程目录C:/xxx/xxx/project,在TCL控制台运行如下指令:
cd C:/xxx/xxx/project
source vio.tcl
reset
TCL脚本内容如下,实现reset复位过程,reset由0变1。
proc reset {} {
set_property OUTPUT_VALUE 0 [get_hw_probes reset -of_objects [get_hw_vios hw_vio_2]]
commit_hw_vio [get_hw_probes {reset} -of_objects [get_hw_vios hw_vio_2]]
set_property OUTPUT_VALUE 1 [get_hw_probes reset -of_objects [get_hw_vios hw_vio_2]]
commit_hw_vio [get_hw_probes {reset} -of_objects [get_hw_vios hw_vio_2]]
}
可以根据需要编写更加复杂的脚本。
本文介绍如何利用TCL脚本控制Vivado VIO,提高调试效率。包括刷新VIO输入、设置输出值及编写复位脚本等操作。
906

被折叠的 条评论
为什么被折叠?



