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。

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

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

相关推荐
小清兔10 分钟前
c#基础知识
开发语言·数据库·学习·unity·c#·游戏引擎·.net
天上掉下来个程小白1 小时前
微服务-25.网关登录校验-网关传递用户到微服务
java·数据库·微服务
哦你看看1 小时前
计算机网络技术(下)
网络·计算机网络
幽络源小助理1 小时前
如何从零开始学习黑客技术?网络安全入门指南
网络·学习·web安全
Rverdoser2 小时前
网站开发用什么语言好
服务器
ta是个码农3 小时前
Mysql——日志
java·数据库·mysql·日志
hhzz3 小时前
SQL 窗口函数(Window Function)终极指南
数据库·sql
四时久成3 小时前
服务器认证系统
运维·服务器
徐子元竟然被占了!!3 小时前
Windows Server 2019 DateCenter搭建 FTP 服务器
运维·服务器·windows
wayuncn5 小时前
影响服务器托管费用的因素
运维·服务器·数据中心·服务器托管·物理服务器租用·服务器机柜·idc机房托管