SRIO入门之官方例程仿真验证

仿真SRIO事务时序

仿真之前先完成下面两步操作:

1.Vivado软件版本2020.1,创建好工程及SRIO的IP核

2.右键综合化的IP核,然后选择打开IP示例工程

直接运行仿真

分别将request和response两个模块添加到仿真窗口进行查看

运行1000us左右就可以看到信号动作

可以看到不同的事务类型

接收MAINTENANCE READ REQUEST请求

首先会由一个维护读请求事务,指定一个维护读请求,不需要响应,因此val_tresp_tvalid=0。

发送SWRITE请求

仿真后面可以看到val_ireq_tvalid拉高时发送的数据包有效,结合ftype(6)和ttype(0)值,包头对应instruction.vh头文件的流写事务,在数据发送完后tlast拉高。

接收SWRITE请求

在request模块发送完数据后,response模块接收到SWRITE请求,结合ftype(6)和ttype(0)值可以验证是SWRITE事务。

发送NWRITE_R请求

接着request模块继续发送下一个数据包事务,是NWRITE_R事务。

接收NWRITE_R请求,发送响应

在发送请求一段时间后,在response模块中接收NWRITE_R事务,和发送的请求包一致,该事务会产生响应,在一段时间后可以看到val_tresp_tvalid拉高一个周期,发送响应包val_tresp_tdata = 64'h25d0_4000_0000_0000。

发送NREAD请求

接着request模块继续发送下一个数据包事务,是NREAD事务。先发送读数据请求包,该事务请求只含包头,不包含数据。

接收NREAD请求

在发送一段时间请求包后response模块收到请求包,接收到读数据事务后根据数据类型接收模块会返回一个响应包和一串数据。

发送NREAD响应

在response模块接收到读事务一段时间后产生相应包val_tresp_tdata=64'h4bd8400000000000,并和数据一起打包,因为接收到的size=8'h3f,所以需要发送的数据个数是64字节,数据位宽是64位发送,则需要发送8个周期的数据。

接收NREAD响应

在响应包发送一段时间后在request模块中收到了响应包包头和数据,响应包包头为val_iresp_tdata=64'h4bd8400000000000,跟在包头后面的是数据0。

上述只对流写事务、带响应的写事务和读事务进行仿真时序分析,其它几个事务可以根据头文件和仿真继续分析。

本期分享结束,感谢大家看完,私信我可获取相关源码工程

相关推荐
NineData12 分钟前
数据库迁移总踩坑?用 NineData 迁移评估,提前识别所有兼容性风险
数据库·程序员·云计算
赵渝强老师2 小时前
【赵渝强老师】PostgreSQL中表的碎片
数据库·postgresql
全栈老石7 小时前
拆解低代码引擎核心:元数据驱动的"万能表"架构
数据库·低代码
YuMiao9 小时前
gstatic连接问题导致Google Gemini / Studio页面乱码或图标缺失问题
服务器·网络协议
倔强的石头_1 天前
kingbase备份与恢复实战(二)—— sys_dump库级逻辑备份与恢复(Windows详细步骤)
数据库
jiayou642 天前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库
李广坤3 天前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
Sinclair3 天前
简单几步,安卓手机秒变服务器,安装 CMS 程序
android·服务器
Rockbean4 天前
用40行代码搭建自己的无服务器OCR
服务器·python·deepseek
爱可生开源社区4 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba