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。

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

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

相关推荐
IvorySQL几秒前
PostgreSQL 18 - 时间约束 (Temporal Constraints)
数据库·postgresql·开源
q***614110 分钟前
从MySQL迁移到PostgreSQL的完整指南
数据库·mysql·postgresql
0和1的舞者16 分钟前
《网络编程核心概念与 UDP Socket 组件深度解析》
java·开发语言·网络·计算机网络·udp·socket
2501_9219392623 分钟前
11.25Nginx服务器和Wordpress服务器
运维·服务器·nginx
华普微HOPERF26 分钟前
Matter协议,如何赋能智能家居构建跨生态的互操作网络?
网络·智能家居
N***738531 分钟前
SQL锁机制
java·数据库·sql
小羊在奋斗39 分钟前
MySQL表的约束:从基础到核心(附场景+案例)
android·数据库·mysql
Wang's Blog43 分钟前
MongoDB小课堂: 文档查询之匹配查询与比较操作符深度解析
数据库·mongodb
cookqq1 小时前
mongodb根据索引IXSCAN 查询记录流程
数据结构·数据库·sql·mongodb·nosql
wanhengidc1 小时前
云手机中分布式存储的功能
运维·服务器·分布式·游戏·智能手机·云计算