作者:OpenS_Lee
1背景知识
在我们的FPGA设计项目中,硬件的诊断和校验可能会占去超过30%—40%的FPGA开发时间,FPGA的debug也是FPGA设计中重要的一环。掌握并灵活运用FPGA设计工具的debug功能也是加快FPGA设计的关键。
1.1 ILA(Integrated Logic Analyzer)
FPGA设计中的信号连接到ILA核的时钟和探针输入如图1。这些信号附加到探针输入,以设计速度采样,并使用片上块RAM(BRAM)存储。核参数指定探针的数量、跟踪样本深度和每个探针输入的宽度。使用与FPGA的JTAG接口连接的自动实例化调试核心集线器与ILA核进行通信。
data:image/s3,"s3://crabby-images/762ad/762ad9108f9f4994c5464c3e37bde8420d0b1260" alt="图1 ILA Core"
图1 ILA Core
1.2 VIO (Virtual Input/Output core)
VIO核是一个可定制的核,可以实时监控和驱动内部FPGA信号。不像ILA核,不需要片上或片外RAM。
VIO核有两种类型的信号:
. Input probes
.Output probes
data:image/s3,"s3://crabby-images/0f691/0f6919f5ebb668c274d9671108f5fa68f3c55891" alt="图2 VIO Block Diagram"
图2 VIO Block Diagram
2 ila 和 vio在工程中使用
我们使用uart工程来做示例。
data:image/s3,"s3://crabby-images/c6449/c64493de977e2a86894044ce223ee6176b81dfe7" alt="图3 uart示例模块图"
图3 uart示例模块图
如图3所示,整个串口工程包括波特率时钟产生模块,串口接收模块和串口发送模块。我们将使用ila IP对uart_rx模块的接收数据进行debug,使用vio IP对uart_tx模块进行debug。
data:image/s3,"s3://crabby-images/fde90/fde90f1d90fdcbd8651392a101ab91c5a92edbbb" alt=""
我们使用Ila将对 rx_data的接收数据进行实时观测,以此来判断程序是否正确。
2.1 ila IP和vio IP的创建
Ila IP的创建,首先打开 IP Catalog如图4。
data:image/s3,"s3://crabby-images/c50f0/c50f06465e89f26bf4db7f722672e64d6542b894" alt="图4 IP Catalog"
图4 IP Catalog
搜索ila如图5。
data:image/s3,"s3://crabby-images/33caf/33caf3ab37fefc8d0a3d80836934bec8d457790d" alt="图5 ila ip"
图5 ila ip
双击打开ila IP ,相关参数设置如图6。
data:image/s3,"s3://crabby-images/86812/86812b47e3d2abdcf0c552249027edd634084f5e" alt="图6 ila IP参数设置"
图6 ila IP参数设置
Ila IP的探头位宽设置如图7。
data:image/s3,"s3://crabby-images/34f6b/34f6ba96c8134c9e38fc5d39d740702edec7649b" alt="图7 Ila IP位宽的设置"
图7 Ila IP位宽的设置
Vio的设置如图8和图9。
data:image/s3,"s3://crabby-images/3f101/3f1010927c6c3a995ca93fa04ec31bce579c529b" alt="图8 探头个数的设置"
图8 探头个数的设置
data:image/s3,"s3://crabby-images/ea227/ea2275a0b2088e9b557bf9a29c7f53b85c681b9a" alt="图9 探头数据位宽和初始化值的设置"
图9 探头数据位宽和初始化值的设置
对Ila IP 和 vio IP的例化。
data:image/s3,"s3://crabby-images/6643b/6643bca433c2e275277d0b20fd5558f90a56339c" alt=""
然后我们综合实现完成后下载程序如图10。
data:image/s3,"s3://crabby-images/aaedc/aaedc79156a2fe654a6fe4ff191dd76d6b052163" alt="图10 programming FPGA"
图10 programming FPGA
2.2 ila 和vio对uart的实时数据采集
Ila的调试,我们使用rx_done 信号作为触发信号,设置触发条件等于1,如图11所示。
data:image/s3,"s3://crabby-images/62f84/62f84624109cf8dd26a91d3aab3ecd5c2e983d78" alt="图11 触发条件的设置"
图11 触发条件的设置
我们使用串口工具发送数据,触发以后我们可以观测到FPGA内部rx_data接收完成后的数据如图12。
data:image/s3,"s3://crabby-images/a0d3a/a0d3aeb14ea0cf58c05d7150cfbf3953c20f4242" alt="图12 ila IP 观测到FPGA内部信号的变化"
图12 ila IP 观测到FPGA内部信号的变化
Vio的调试,点击+号,添加三个数据端口如图所示13。
data:image/s3,"s3://crabby-images/d230f/d230f20ccadfeccc9bd9a28ff51e4b788da6f35c" alt="图13 vio观测端口的设置"
图13 vio观测端口的设置
当tx_en 为1时将tx_data上的数据从FPGA内部发送到串口工具上,如图14所示。
data:image/s3,"s3://crabby-images/611d0/611d0b6fa639f6ba1d4ea17213e92895e7acde8a" alt="图14 通过vio将数据从FPGA内部发送到串口工具"
图14 通过vio将数据从FPGA内部发送到串口工具
学会对FPGA内部信号的debug是FPGA设计过程中重要的一环。Vivado的debug相对于ISE更为简单,更加易用。
视频演示:
需要得到本实验原工程的同学可以请联系: FPGA开源工作室
评论
可不可以用VIO中的probe