怎么在sequence中调用agent中的函数以及如何快速实验你的想法?

路科验证 2022-02-08 12:08

   |来源| 杰瑞IC验证(ID:Jerry_IC) 

 |原创作者| Jerry


最近略忙,今天就给大家表演个胸口碎……码一段代码。
通过本篇文章主要想送给广大验证初学者和爱好者2件礼物:“一条鱼”和“一只鱼竿”。希望大家连吃带拿,开开心心地。
“一条鱼”就是题目中的那个问题本身:“UVM中怎么在sequence中调用agent中的函数”。这个问题很多同学猛的听到可能还是会有一些懵,反应不出一个优雅的解决方法。
“一只鱼竿”就是当你遇到这样一个问题的时候,怎么快速写一段代码验证你的想法是不是可以实现,也就是Jerry今天带你解决这个问题的过程。
好了,我们开车~


本文由“壹伴编辑器”提供技术支持
众所周知,在UVM中一个标准的agent里面例化着driver、monitor、sequencer组件,发激励时通过“游离”在agent中的sequence产生transaction,借助sequencer给driver进而发出激励。
但是“游离”在agent中的sequence怎么访问agent中的函数呢?
有人说可以使用config_db机制:在某个地方如env中把agent set出去,然后在sequence中用config_db机制的get拿到agent的资源,进一步在sequence中调用agent中的函数。
这样确实可以实现功能,但是不太优雅,他需要借助除了sequence本身的“外力”, 需要在别处多写几行代码来set agent。
当然了,对于这种函数调用需求我们其实还可以通过之前讲的单例模式(IC验证er一起学点设计模式(1)---单例模式),做成全局组件来实现,本文就不提了,大家自己探索。



那怎么做才能比较优雅呢?
先说结论:p_sequencer机制+get_parent()“两步跳跃法”。
第一步通过UVM中的p_sequencer机制,sequence可以通过p_sequencer访问到它对应的sequencer一层的成员。
第二步到了sequencer这一层,我们发现sequencer属于UVM树结构中的一个节点,例化它的agent也属于UVM树的节点,那就好办了。通过get_parent()函数可以得到UVM树中当前实例的parent。而我们要的agent正好就是sequencer的parent。
话不多说,试验下这个玩法~

我们怎么才能快速的写一段代码来验证这个想法呢?
想想我们的目的就是写一段代码跑起来实验下能不能搞定我们的问题,不是做一个验证项目,所以没必要写一个完整的UVM验证平台,甚至没有必要维护多个文件。我们需要能快速建立一个极简的又能达到实验目的“最小化验证平台”。
想清楚需求我们就开始设计我们代码结构了,我们的“最小化验证平台”肯定没必要加DUT了,那interface也肯定不需要了,env也不要了,直接例化agent,我们验证的问题对于agent中的driver和monitor没啥关系也都直接舍弃,transaction我们也用不到,也扔了。所以我们的UVM平台的结构就是:base_test中例化agent,agent中只例化一个sequencer,然后一个sequence,最后再加一个top module即可。
好了,4个class和1个module,基本上已经做到“最小化”了,再多再少不差那两三行了,上代码~

代码段1

首先,如代码段1,我们定义了一个极简的jerry_sequencer,其中第11行,定义了名叫hello()的函数,这个函数就一句打印信息,便于我们后面调用实验。

代码段2

接着,代码段2定义了一个极简的jerry_agent,在这里声明和例化了jerry_sequencer,此外在25行依然定义了名叫hi()的函数,也就是一句打印信息。

代码段3

然后,代码段3中我们定义了名叫jerry_seq的sequence。这个是我们实现今天功能的重点代码。

代码段4

最后在代码段4中定义了jerry_base_test来例化jerry_agent,同时通过default_seq机制启动jerry_sequence。并且定义了名叫top的module,核心就58行一句话,通过run_test启动jerry_base_test。

我们再明确下要解决的问题是“怎么在sequence中调用agent中的函数?” ,基于这几个代码段,具体化为:“怎么在jerry_sequence中调用jerry_agent中的hi()函数?”



我们重点看下前面提到的“两步跳跃法”的功能实现:

1.
在代码段3的33行,我们使用了`uvm_declare_p_sequencer宏,声明类型为jerry_sequencer。顺便提一下,在37行,通过p_sequencer调用了jerry_sequencer(代码段1)中定义的hello()函数。如果其中的句子打印成功,说明我们此时p_sequencer机制触发成功。

2.
在代码段的34行,我们声明了一个更加原始的uvm_component类型的句柄parent,在38行中把它指向了jerry_agent的对象上。
tips1:通过get_parent()函数,指向了jerry_sequencer的parent 即jerry_agent。
tips2:顺便提一嘴为什么它parent是jerry_agent?因为代码段2的22行例化时传入的“this”参数)

在39行通过$cast函数,我们让35行声明的jerry_agent类型的句柄agt,通过和parent句柄的类型匹配,指向了jerry_agent的对象上。

终于,在40行,我们通过agt句柄,调用jerry_agent中的函数hi()。如果成功打印其中的字符串就说明我们实现了我们的目标。


上面的所有代码片段,按照正确的顺序写到文件里,在前面include进来 uvm_macros.svh,以及include且import uvm_pkg后,便可以直接运行。运行成功后,屏幕上果然会打出hello()和hi()函数中的字符串:

hello,how are you!
hi,I’m fine,thank you~and you?


结语


今天jerry送给大家“一条鱼”和“一只鱼竿”;

“一条鱼”是解决了“UVM里怎么在sequence中调用agent中的函数”的问题;

更重要的“一只鱼竿”,即传递了“最小化验证平台”的实现思想和代码实现过程;

有了“最小化验证平台”的思想,可以最快最简单的把你的想法跑起来,验证它的正确性,提高学习与实验的效率。




——The  End——

路科验证 专注于数字芯片验证的系统思想和前沿工程领域。路桑是Intel资深验证专家,主持验证架构规划和方法学研究,担任过亿门级通信芯片的验证经理角色。在工程领域之外,他在西安电子科技大学和西安交通大学客座讲授芯片验证课程。著有书籍《芯片验证漫游指南》。
评论 (0)
  • 升职这件事,说到底不是单纯靠“干得多”或者“喊得响”。你可能也看过不少人,能力一般,甚至没你努力,却升得飞快;而你,日复一日地拼命干活,升职这两个字却始终离你有点远。这种“不公平”的感觉,其实在很多职场人心里都曾经出现过。但你有没有想过,问题可能就藏在一些你“没当回事”的小细节里?今天,我们就来聊聊你升职总是比别人慢,可能是因为这三个被你忽略的小细节。第一:你做得多,但说得少你可能是那种“默默付出型”的员工。项目来了接着干,困难来了顶上去,别人不愿意做的事情你都做了。但问题是,这些事情你做了,却
    优思学院 2025-03-31 14:58 76浏览
  • 引言在语音芯片设计中,输出电路的设计直接影响音频质量与系统稳定性。WT588系列语音芯片(如WT588F02B、WT588F02A/04A/08A等),因其高集成度与灵活性被广泛应用于智能设备。然而,不同型号在硬件设计上存在关键差异,尤其是DAC加功放输出电路的配置要求。本文将从硬件架构、电路设计要点及选型建议三方面,解析WT588F02B与F02A/04A/08A的核心区别,帮助开发者高效完成产品设计。一、核心硬件差异对比WT588F02B与F02A/04A/08A系列芯片均支持PWM直推喇叭
    广州唯创电子 2025-04-01 08:53 105浏览
  • 北京贞光科技有限公司作为紫光同芯产品的官方代理商,为客户提供车规安全芯片的硬件、软件SDK销售及专业技术服务,并且可以安排技术人员现场支持客户的选型和定制需求。在全球汽车电子市场竞争日益激烈的背景下,中国芯片厂商正通过与国际领先企业的深度合作,加速融入全球技术生态体系。近日,紫光同芯与德国HighTec达成的战略合作标志着国产高端车规芯片在国际化道路上迈出了关键一步,为中国汽车电子产业的发展注入了新的活力。全栈技术融合:打造国际化开发平台紫光同芯与HighTec共同宣布,HighTec汽车级编译
    贞光科技 2025-03-31 14:44 82浏览
  • 在环保与经济挑战交织的当下,企业如何在提升绩效的同时,也为地球尽一份力?普渡大学理工学院教授 查德·劳克斯(Chad Laux),和来自 Maryville 大学、俄亥俄州立大学及 Trine 大学的三位学者,联合撰写了《精益可持续性:迈向循环经济之路(Lean Sustainability: Creating a Sustainable Future through Lean Thinking)》一书,为这一问题提供了深刻的答案。这本书也荣获了 国际精益六西格玛研究所(IL
    优思学院 2025-03-31 11:15 67浏览
  • 据先科电子官方信息,其产品包装标签将于2024年5月1日进行全面升级。作为电子元器件行业资讯平台,大鱼芯城为您梳理本次变更的核心内容及影响:一、标签变更核心要点标签整合与环保优化变更前:卷盘、内盒及外箱需分别粘贴2张标签(含独立环保标识)。变更后:环保标识(RoHS/HAF/PbF)整合至单张标签,减少重复贴标流程。标签尺寸调整卷盘/内盒标签:尺寸由5030mm升级至**8040mm**,信息展示更清晰。外箱标签:尺寸统一为8040mm(原7040mm),提升一致性。关键信息新增新增LOT批次编
    大鱼芯城 2025-04-01 15:02 99浏览
  • 提到“质量”这两个字,我们不会忘记那些奠定基础的大师们:休哈特、戴明、朱兰、克劳士比、费根堡姆、石川馨、田口玄一……正是他们的思想和实践,构筑了现代质量管理的核心体系,也深远影响了无数企业和管理者。今天,就让我们一同致敬这些质量管理的先驱!(最近流行『吉卜力风格』AI插图,我们也来玩玩用『吉卜力风格』重绘质量大师画象)1. 休哈特:统计质量控制的奠基者沃尔特·A·休哈特,美国工程师、统计学家,被誉为“统计质量控制之父”。1924年,他提出世界上第一张控制图,并于1931年出版《产品制造质量的经济
    优思学院 2025-04-01 14:02 74浏览
  • 在智能语音交互设备开发中,系统响应速度直接影响用户体验。WT588F系列语音芯片凭借其灵活的架构设计,在响应效率方面表现出色。本文将深入解析该芯片从接收指令到音频输出的全过程,并揭示不同工作模式下的时间性能差异。一、核心处理流程与时序分解1.1 典型指令执行路径指令接收 → 协议解析 → 存储寻址 → 数据读取 → 数模转换 → 音频输出1.2 关键阶段时间分布(典型值)处理阶段PWM模式耗时DAC模式耗时外挂Flash模式耗时指令解析2-3ms2-3ms3-5ms存储寻址1ms1ms5-10m
    广州唯创电子 2025-03-31 09:26 185浏览
  • 在智能家居领域,无线门铃正朝着高集成度、低功耗、强抗干扰的方向发展。 WTN6040F 和 WT588F02B 两款语音芯片,凭借其 内置EV1527编解码协议 和 免MCU设计 的独特优势,为无线门铃开发提供了革命性解决方案。本文将深入解析这两款芯片的技术特性、应用场景及落地价值。一、无线门铃市场痛点与芯片方案优势1.1 行业核心痛点系统复杂:传统方案需MCU+射频模块+语音芯片组合,BOM成本高功耗瓶颈:待机电流
    广州唯创电子 2025-03-31 09:06 147浏览
  • REACH和RoHS欧盟两项重要的环保法规有什么区别?适用范围有哪些?如何办理?REACH和RoHS是欧盟两项重要的环保法规,主要区别如下:一、核心定义与目标RoHS全称为《关于限制在电子电器设备中使用某些有害成分的指令》,旨在限制电子电器产品中的铅(Pb)、汞(Hg)、镉(Cd)、六价铬(Cr6+)、多溴联苯(PBBs)和多溴二苯醚(PBDEs)共6种物质,通过限制特定材料使用保障健康和环境安全REACH全称为《化学品的注册、评估、授权和限制》,覆盖欧盟市场所有化学品(食品和药品除外),通过登
    张工13144450251 2025-03-31 21:18 65浏览
  • 引言随着物联网和智能设备的快速发展,语音交互技术逐渐成为提升用户体验的核心功能之一。在此背景下,WT588E02B-8S语音芯片,凭借其创新的远程更新(OTA)功能、灵活定制能力及高集成度设计,成为智能设备语音方案的优选。本文将从技术特性、远程更新机制及典型应用场景三方面,解析该芯片的技术优势与实际应用价值。一、WT588E02B-8S语音芯片的核心技术特性高性能硬件架构WT588E02B-8S采用16位DSP内核,内部振荡频率达32MHz,支持16位PWM/DAC输出,可直接驱动8Ω/0.5W
    广州唯创电子 2025-04-01 08:38 99浏览
  • 在不久前发布的《技术实战 | OK3588-C开发板上部署DeepSeek-R1大模型的完整指南》一文中,小编为大家介绍了DeepSeek-R1在飞凌嵌入式OK3588-C开发板上的移植部署、效果展示以及性能评测,本篇文章不仅将继续为大家带来关于DeepSeek-R1的干货知识,还会深入探讨多种平台的移植方式,并介绍更为丰富的交互方式,帮助大家更好地应用大语言模型。1、移植过程1.1 使用RKLLM-Toolkit部署至NPURKLLM-Toolkit是瑞芯微为大语言模型(LLM)专门开发的转换
    飞凌嵌入式 2025-03-31 11:22 162浏览
  • 一、温度计不准的原因温度计不准可能由多种原因导致,如温度计本身的质量问题、使用环境的变化、长时间未进行校准等。为了确保温度计的准确性,需要定期进行校准。二、校准前准备工作在进行温度计校准之前,需要做好以下准备工作:1. 选择合适的校准方法和设备,根据温度计的型号和使用需求来确定。2. 确保校准环境稳定,避免外部因素对校准结果产生影响。3. 熟悉温度计的使用说明书和校准流程,以便正确操作。三、温度计校准方法温度计校准方法一般分为以下几步:1. 将温度计放置在
    锦正茂科技 2025-03-31 10:27 49浏览
  •        在“软件定义汽车”的时代浪潮下,车载软件的重要性日益凸显,软件在整车成本中的比重逐步攀升,已成为汽车智能化、网联化、电动化发展的核心驱动力。车载软件的质量直接关系到车辆的安全性、可靠性以及用户体验,因此,构建一套科学、严谨、高效的车载软件研发流程,确保软件质量的稳定性和可控性,已成为行业共识和迫切需求。       作为汽车电子系统领域的杰出企业,经纬恒润深刻理解车载软件研发的复杂性和挑战性,致力于为O
    经纬恒润 2025-03-31 16:48 54浏览
我要评论
0
0
点击右上角,分享到朋友圈 我知道啦
请使用浏览器分享功能 我知道啦