TCL脚本控制VIVADO-VIO调试核

作者: 硬码农二毛哥,文章来源: 硬码农二毛哥微信公众号

注:本文由作者授权转发,如需转载请联系作者本人

在用vivado开发过程中,经常vio调试核,如果要vio输出信号较多,并且信号触发顺序需要控制时,每次通过手动输入就有些麻烦,使用TCL脚本控制vio,只需运行脚本就可以了,极大提升开发效率。

与VIO相关TCL命令

Vivado TCL控制台
在控制台中输入命令,修改工作目录
cd D:/xxx/project

读取VIO输入
当从VIO读取axigpio_int数据时,运行如下指令:

refresh_hw_vio [get_hw_vios {hw_vio_2}]
get_property INPUT_VALUE [get_hw_probes axigpio_int]

写 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]]
}

可以根据需要编写更加复杂的脚本。

最新文章