当前位置:   article > 正文

TCL脚本控制VIVADO-VIO调试核_c调用vivado tcl

c调用vivado tcl

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

VIO相关TCL命令

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-DLWWrBnx-1656584404752)(./pic/1.png)]

Vivado TCL控制台

在控制台中输入命令,修改工作目录

cd D:/xxx/project
  • 1

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-OEkQOKBb-1656584404753)(./pic/2.png)]

读取VIO输入

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

refresh_hw_vio [get_hw_vios {hw_vio_2}]
get_property INPUT_VALUE [get_hw_probes axigpio_int]
  • 1
  • 2

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-dpPeco5f-1656584404754)(./pic/3.png)]

写 VIO 输出

向gpio写入1111。

set_property OUTPUT_VALUE 1111 [get_hw_probes gpio]
commit_hw_vio [get_hw_probes {gpio}]
  • 1
  • 2

编写VIO控制脚本

新建tcl脚本vio.tcl,将脚本存入工程目录C:/xxx/xxx/project,在TCL控制台运行如下指令:

cd C:/xxx/xxx/project
source vio.tcl
reset
  • 1
  • 2
  • 3

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]] 
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

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

声明:本文内容由网友自发贡献,转载请注明出处:【wpsshop】
推荐阅读
相关标签
  

闽ICP备14008679号