UVM
  • 2025-01-11路科MCDF项目UVM环境搭建之virtual_sequence
    mcdf_base_virtual_sequence1.virtuasequence介绍:①virtualsequence可以承载不同目标sequencer的sequence群落,组织协调这些底层sequence可以发送到不同的底层sequencer上(通过宏`uvm_do_on直接创建并发送到virtualsequencer内的底层sequencer上),virtualsequencer一般只
  • 2025-01-08路科MCDF项目UVM环境搭建之mcdf_refmod
    mcdf_refmod1.创建一个get_reg_trans端口,三个chnl端口,三个tlm_fifo便于与外部模块通信;2.传递接口,创建regs[3]来模拟真实的寄存器控制通道使能(en),arb优先级(prio),整合数据包的长度(len)(定义一个结构体mcdf_reg_t)。 typedefstructpacked{biten;bit[1:0]prio;
  • 2024-12-11利用PWM实现呼吸灯
    利用PWM实现呼吸灯一、PWM理论知识1、PWM概念2、占空比的概念3、PWM输出呼吸灯二、工程创建1、设计要求2、使用STM32CubeMX配置三、代码编写四、结果演示五、总结一、PWM理论知识1、PWM概念脉冲宽度调制(PWM),是英文“PulseWidthModulation”的缩写,简称脉宽调制,
  • 2024-12-10什么是 Java 中的直接内存(堆外内存)?
    Java中的直接内存(堆外内存)在Java中,直接内存(DirectMemory)指的是不受JVM堆管理的内存区域,也称为堆外内存。直接内存的使用通常与JavaNIO(NewI/O)相关,尤其是通过ByteBuffer.allocateDirect()方法分配的内存。1.直接内存的特点不在堆中:直接内存不属于JVM堆内存,也不受
  • 2024-12-1020222409 2021-2022-2 《网络与系统攻防技术》实验八实验报告
    1.实验内容1.1本周学习内容复习前后端区别:了解了前端主要负责页面展示和交互,使用技术如HTML、CSS、JS;后端则负责数据处理和业务逻辑,使用Java、Python等语言。掌握SQL注入原理:学习了如何通过SQL注入绕过登录验证,例如利用'OR1=1--注入绕过登录。了解了普通注入与盲注入的区
  • 2024-12-04HarmonyOS Next 数据安全存储与管理平台构建
    本文旨在深入探讨华为鸿蒙HarmonyOSNext系统(截止目前API12)在数据安全存储与管理平台构建中的应用,基于实际开发实践进行总结。主要作为技术分享与交流载体,难免错漏,欢迎各位同仁提出宝贵意见和问题,以便共同进步。本文为原创内容,任何形式的转载必须注明出处及原作者。第一章:平台
  • 2024-11-26如何设计好分布式数据库,这个策略很重要(GaussDB)
    ​数据库是应用和计算机的核心组成,试想,如果没有数据库,就像人的大脑没有了记忆一样,信息也得不到共享,那么,对开发者来说,如何设计一款高效易用的数据库至关重要。GaussDB是企业级分布式数据库,具备分布式强一致、有效降低容灾成本、支持PB级海量数据、智能诊断等优点,是当下炙手可热的
  • 2024-10-23uvm factory机制
    UVM(UniversalVerificationMethodology)是一种用于设计验证的标准方法学。UVM提供了一种基于类的、重用的验证框架,可以简化和加速验证环境和测试用例的开发。UVM使用了一种称为工厂机制(FactoryMechanism)的技术,用于创建和管理各种对象实例。工厂机制允许用户通过使用工厂对
  • 2024-10-15uvm_event的变量传递+查看软链接的指向+grep只打印匹配的数据+并行进程的串行化--构建进程池+UVM动态复位问题+VIP动态复位注意事项
    uvm_event的变量传递uvm_event可以传递变量,但是变量需要为uvm_object类型,对于package,建议类型向下转换,直接传递uvm_object,并在另一端解析https://www.edaplayground.com/x/RhYcmoduletestbench;classclass1extendsuvm_object;`uvm_object_utils(class1)inta
  • 2024-10-08【学习记录丨UVM】1.2驱动器driver(1)——最简单的driver及其实例化
    《UVM白皮书》关于driver的介绍一、只有driver——最简单的验证平台UVM是一个库,其中的driver等组件都是派生(extends)自UVM库中的类(class)。类中通过function和task实现组件功能。UVM常用类及树形结构_uvm树-CSDN博客 下边这张图展示了UVM常用的类之间的派生关系。可
  • 2024-09-07数字IC验证笔面试常见100题【持续更新】
    【提要】收集整理了一些网络上和我自己在秋招、实习时遇到的题目,适合数字验证方向求职的同学进行差缺补漏或者应对八股时的速成。    对于时间比较充裕并且有条件的同学,还是强烈建议找个实习来提升自己的能力以及校招竞争性,独立完成了一两个真实项目后,能大大加深对验证
  • 2024-08-28数字验证:一文弄懂UVM的factory机制
            如果我们用SystemVerilog构建验证平台,构建好了之后,想改变平台中的某个组件,例如将driver改成driver_new,我们需要重新定义一下driver_new,当然也可以直接从driver继承。但是我们还需要在driver对象例化的地方将driverdrv;改成driver_newdrv;,如果需要多个组件的
  • 2024-08-26UVM中的TLM(事务级建模)通信(2)
    上一篇介绍了UVM中利用TLM进行的一对一通信:UVM中的TLM(事务级建模)通信(1)-CSDN博客,除此之外,UVM还有两种特殊的端口:analysis_port和analysis_export,用于完成一对多的通信。1.analysis端口    这两种端口同样也是用于传递transaction,他们与put,get的区别是:   
  • 2024-08-23UVM中的TLM(事务级建模)通信(1)
    1.验证平台内部的通信    我们希望在验证平台内部找到两个component之间适合通信的方法,在接触TLM之前,想到的方法无非有采用全局变量、通过config_db传输等等。然而全局变量因为安全性不高,是我们长期以来竭力避免使用的方法;config_db虽然相对安全,但需要拉入basetest的
  • 2024-08-22使用uvm_config_db 分层Testbench配置
    前言 对于刚接触验证方法或正在采用uvm的工程师,本文重点介绍uvm配置机制"uvm_config_db",它有助于在分层测试台组件之间传递不同的类属性。通过使用示例,本文解释了uvm_config_db的用法、技术和局限性。介绍 为满足当今验证架构的需求,有必要对组件进行分层设置,以便在不
  • 2024-08-18IC验证面试经验分享——UVM篇
    验证最需要会的技能树是什么?!那肯定是非UVM莫属了,趁着校招之际,准备IC面试的ICer赶快码住!IC验证面试经验分享UVM篇一、UVM验证平台组件二、UVM_component和uvm_object三、sequence启动方式四、seqence是怎么给到dut的?五、p_sequencer和m_sequencer的区别1)含义2)区别六、
  • 2024-07-25UVM-config_db机制和用法
    1.用途        config_db机制用于在UVM验证平台间传递参数,通常成对出现,其中set相当于寄信,get相当于收信。UVM提供的config_db机制可在组件实例化前就设定好配置信息,这样就可在tb的initial块中就进行设定了。真正将这些配置信息落实在各component,是在testbench运行过程
  • 2024-07-09SV/UVM 类的多态和虚方法解析
            类具有三大特性:封装/继承/多态,多态是面对对象编程中最神奇的特征,也是最抽象和难以理解的特征。对于初学者来说,最好对sv有了一定了解,在掌握了封装和继承之后再学习多态会更容易理解。1.类的继承    首先复习一下继承的概念:继承是利用共性构建一个基类
  • 2024-07-08[UVM]IC验证自动结束仿真函数——uvm_top.set_timeout/set_report_max_quit_count
    Title:[UVM]IC验证自动结束仿真函数——uvm_top.set_timeout/set_report_max_quit_count文章目录1-前言2-uvm_top.set_timeout3-set_report_max_quit_count4-运用5-小结1-前言​数字IC验证过程中,需要运行不同Testcase,有些TC会因为TC配置、TB机制等原因,导致m
  • 2024-05-212.3.3 加入monitor
    作用:监测DUT的行为,driver负责把transaction级别的数据转变成DUT的端口级别,并驱动给DUT,monitor的行为与其相对,用于收集DUT的端口数据,并将其转换成transaction交给后续的组件如referencemodel,scoreboard等处理。一些代码中用到的方法如下:monitor代码如下:需要注意1.所有的
  • 2024-05-202.3.2加入env
    env的作用:实例化验证平台的各个组件,作为一个容器类,在这个容器里面实例化其他组件,然后再调用run_test时传递的参数就不再是my_driver,而是这个容器类,即让UVM自动创建这个容器类的实例。所有env都应该派生自uvm_env,且与my_driver一样,容器类在仿真中也一直是存在的,使用uvm_componen
  • 2024-05-172.3.1---加入transaction
    transaction概念:可以简单地将transaction理解为一个包,在不同的验证平台中的transaction也不相同。一个简单的transaction如下:在这些代码中,其中dmac是48bit的以太网目的地址,smac是48bit的以太网源地址,ether_type是以太网类型,pload是其携带的数据大小,通过pload_cons约束可以看到