码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • UVM如何处理out-of-order乱序传输


    文章目录

    • 前言
    • 1、基本思路
    • 2、支持乱序传输的sequence
    • 3、支持乱序传输的Driver
    • 总结


    前言

    乱序传输(out-of-order)是指在协议中,后发出去的req,支持先回resp,通常通过ID来保证req和resp之间的关系。很多协议支持乱序传输,例如AXI4。本文主要介绍,在UVM的环境中,构造支持乱序传输的验证环境的方法。


    1、基本思路

    在uvm环境中,要实现乱序传输,主要是处理sequence和driver之间的数据交互。

    在sequence中,需要一个存储transaction和transaction ID的关联数组,当下发一个transaction时,需要将这个transaction和对应的ID存起来,然后去获取相应resp的ID,注意这个时候获取resp ID的进程不能阻塞下一个req的发送,当获取到resp时,就需要将关联数组中对应ID的transaction删除回收。

    在driver中,首先需要关闭driver自动收集transaction的功能,改为手动收集;其次需要去获取sequence通过sequencer发过来的transaction,并对其进行相应的处理,注意这里接收transaction和处理transaction需要分开并行执行,否则处理transaction的时候,有可能会因为阻塞了接收transaction,造成本应该被接收的transaction,在sequenc中被下一条transaction覆盖,从而导致丢失;最后,为了实现接收和处理transaction这两个进程之间的数据交互,需要一个存储transaction的队列。

    2、支持乱序传输的sequence

    这里有几个关键点:
    1)packet pkt_reg[int],这里是声明存储transaction和transaction ID的关联数组。
    2)wait(pkt_req.size()<5),这句话可以理解为outstanding=5,当下游的resp被阻塞时,防止上游的req一下子全部发下去了。
    3)pkt_req[req.get_transaction_id()] = req,这里是利用关联数组,保存当前的transaction和ID。
    4)接下来的fork - join_none主要是用来对已经收到resp的req进行回收,采用fork - join_none的目的是为了不阻塞下一次req的发送。
    在这里插入图片描述
    在这里插入图片描述

    3、支持乱序传输的Driver

    这里也提几个关键点:
    1)seq_item_port.disable_auto_item_recording(),关闭driver中自动记录transaction的功能。
    2)利用fork - join启用两个进程,分别负责接收transaction以及处理transaction。
    3)在接收的进程中,接收到transaction之后,就将transaction送入队列中;在处理的进程中,一旦队列不为空,则对队列中的数据进行处理。
    在这里插入图片描述

    在这里插入图片描述


    总结

    本文主要总结一下,在uvm环境中,如何处理乱序的传输。首先给出整体思路,然后分别针对sequence和driver提供具体的代码实现供参考。

  • 相关阅读:
    计算机算法分析与设计(12)---贪心算法(最优装载问题和哈夫曼编码问题)
    DV SSL证书便宜吗?申请后多久签发?
    关于原型交互设计文档的一些建议
    鸿鹄工程项目管理系统 Spring Cloud+Spring Boot+Mybatis+Vue+ElementUI+前后端分离构建工程项目管理系统
    css选择器(通配符、(元素、类、id)、后代(子代、所有后代)、兄弟(相邻兄弟、所有兄弟)、属性(属性、指定值的属性)、交集并集)
    驱动中获取设备树节点信息
    申请专利这10个知识点一定要知道哦
    MySQL的数据库有关操作
    java数据类型-简介
    关于使用腾讯云HiFlow场景连接器每天提醒签到打卡
  • 原文地址:https://blog.csdn.net/hh199203/article/details/127442667
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号