- UVM中uvm_do、uvm_create和uvm_send详细区别和代码举例(涵盖start_item和finish_item关系)
zilan23
UVM硬件工程
独创:篇幅较长,但很详细哟UVM中uvm_do、uvm_create和uvm_send详细区别和代码举例(涵盖start_item和finish_item关系):在UVM验证框架中,uvm_do、uvm_create和uvm_send是生成和发送transaction的三大核心宏,它们的区别体现在控制粒度和功能组合上。以下是详细对比和示例:一、功能对比宏功能分解控制权适用场景uvm_do1.创建对
- 【UVM基础】uvm_resource_db 使用介绍
MoorePlus
数字IC验证百宝箱经验分享面试数字IC芯片验证SVUVM
文章目录介绍uvm_resource_db使用uvm_resource_db类声明:uvm_resource_db类方法uvm_resource_db::set方法uvm_resource_db::read_by_type方法介绍uvm_resource_db类为资源工具提供了一个方便的接口。在许多情况下,创建和设置资源或获取资源等基本操作可能需要使用uvm_resource_base或uvm_r
- [SystemVerilog] Clocking
S&Z3463
SystemVerilogfpga开发
SystemVerilogClocking用法详解SystemVerilog的clocking块(ClockingBlock)是一种专门用于定义信号时序行为的构造,主要用于验证环境(如UVM)中,以精确控制信号的采样和驱动时序。clocking块通过将信号与特定时钟关联,简化了测试环境中对时序敏感信号的处理,减少了手动时序管理的复杂性。本文将详细介绍SystemVerilog中clocking块的
- Debian安装配置Nvidia驱动
两斤半
LinuxDebiandebian
检查内核模块nvidia-smi检查已加载的内核模块lsmod|grepnvidia#输出参考nvidia_uvm49152000nvidia_drm11878418drm_ttm_helper163841nvidia_drmdrm_kms_helper2539522drm_ttm_helper,nvidia_drmnvidia_modeset160563225nvidia_drmnvidia60
- core-v-verif系列之lib<53>
CDerL
fpga开发
UVM环境介绍HEADcommitID:1f968ef//Copyright2020OpenHWGroup//Copyright2020DatumTechnologyCorporation//Copyright2020SiliconLabs,Inc.////LicensedundertheSolderpadHardwareLicence,Version2.0(the"License");//you
- core-v-verif系列之lib<50>
CDerL
core-v-verif
UVM环境介绍HEADcommitID:1f968ef1.core-v-verif/lib/uvm_agents/uvma_cvxif/src/uvma_cvxif_assert.sv//Copyright2021ThalesDISdesignservicesSAS////LicensedundertheSolderpadHardwareLicence,Version2.0(the"License
- core-v-verif系列之lib<49>
CDerL
core-v-verif
UVM环境介绍HEADcommitID:1f968ef1.core-v-verif/lib/uvm_agents/uvma_cvxif/src/comps/uvma_cvxif_mon.sv//Copyright2021ThalesDISdesignservicesSAS////LicensedundertheSolderpadHardwareLicence,Version2.0(the"Lice
- core-v-verif系列之lib<45>
CDerL
core-v-verif
core-v-verif系列之lib<45>UVM环境介绍HEADcommitID:1f968ef1.core-v-verif/lib/uvm_agents/uvma_clknrst/seq/uvma_clknrst_base_seq.sv////Copyright2020OpenHWGroup//Copyright2020DatumTechnologyCorporation////License
- Emacs Verilog-mode 核心功能与使用指南
yang_20250429
emacs编辑器
一、基本概念与背景1、功能定位Verilog-mode是Emacs专门为Verilog/SystemVerilog开发设计的插件12,支持包括UVM验证框架在内的硬件设计语言特性。其核心功能包括:语法高亮:区分关键字、注释、端口等元素自动缩进与格式化:根据代码层级智能调整缩进AUTO宏系统:自动生成模块端口、信号连接等重复代码2、开发者背景由MichaelMcNamara和WilsonSnyder
- core-v-verif系列之lib<30>
CDerL
core-v-verif
UVM环境介绍HEADcommitID:1f968ef1.core-v-verif/lib/uvm_agents/uvma_axi5/src/uvma_axi_amo_assert.sv//Copyright2022ThalesDISSAS////LicensedundertheSolderpadHardwareLicence,Version2.0(the"License");//youmayno
- core-v-verif系列之cv32e40p UVM环境介绍<16>
CDerL
core-v-verif
UVM环境介绍HEADcommitID:1f968ef1.tb/core/dp_ram.sv//DVTLINTERwaiversarefinebecausethisisnotaUVMcomponent.//@DVT_LINTER_WAIVER_START"MT20210811_0"disableSVTB.29.1.3.1,SVTB.29.1.7moduledp_ram#(parameterADDR
- core-v-verif系列之cv32e40p UVM环境介绍<14>
CDerL
core-v-verif
UVM环境介绍HEADcommitID:1f968ef1.tb/core/tb_riscv/riscv_random_interrupt_generator.sv////////Author:
[email protected]////////Additionalcontributionsby:DavideSchiavone-pschiavo@ii
- core-v-verif系列之cv32e40p UVM环境介绍<11>
CDerL
core-v-verif
UVM环境介绍HEADcommitID:1f968ef1.regress/cv32e40p_full_covg_no_pulp.yaml#YAMLfiletospecifyaregressiontestlist#NotethattheCOREV=YESissetforalltestsinthisregression.#ThismeansyouneedtohaveatoolchainatCOREV_
- #C8# UVM中的factory机制 #S8.1.1# 多态的实现方式(三)
那么菜
UVM
记得曾经看到过这样一句话:实现多态,有二种方式,覆盖,重载。今天,再琢磨这句话,不禁想起来什么,随便写写吧。在面向对象编程(OOP)中,多态(Polymorphism)的实现方式,有哪些呢?1.多态的分类多态通常分为两类:编译时多态(静态多态):在编译阶段确定具体调用的方法,例如方法重载(Overload)。运行时多态(动态多态):在程序运行期间动态绑定具体调用的方法,例如方法覆盖(Overrid
- uvm configuration
weifexie
UVMuvmsystemverilogconfiguration
UVMConfiguration机制详解UVM的配置机制(ConfigurationMechanism)是验证环境中实现参数传递和动态配置的核心方法,通过uvm_config_db类实现跨组件的数据共享和灵活配置。以下是其核心概念、使用方法和最佳实践的详细解析:1.核心概念目的:在不直接修改组件代码的前提下,动态传递参数、接口句柄或对象,提升验证环境的灵活性和复用性。核心类:uvm_config_
- uvm factory
weifexie
UVMuvmsystemverilogfactory
UVMFactory是验证环境中实现动态对象和组件创建的核心机制,它通过类型注册和覆盖(Override)机制,允许在不修改原有代码的情况下替换组件或事务类型,从而提升验证环境的灵活性和可重用性。以下是Factory机制的详细解析:Factory的核心概念核心作用:动态对象创建:通过类型名称(字符串)或代理类(ProxyClass)创建对象。类型覆盖:在运行时替换默认组件或事务类型(例如将普通Dr
- #C8# UVM中的factory机制 #S8.2.3# 重载sequence哪些情形
那么菜
UVM
在UVM中,重载(Override)Sequence是一种动态替换激励生成逻辑的关键技术,常用于灵活配置测试场景。以下是常见的用法和实现方式:1.在uvm_testbuild_phase中通过set_type_override重载用途:直接替换某个Sequencer的默认Sequence类型。实现步骤:在测试用例的build_phase中,调用set_type_override。指定原始Seque
- #C8# UVM中的factory机制 #S8.5# 对factory机制的重载进一步思考
那么菜
UVM
前面的重载,我们已经谈了很多,为什么还需要进一步聊聊呢。作为码农,我们喜欢拿来多种相近语言,进行对比理解,相信这是一种加深对问题理解的方式。一C++重载在C++中,重载和多态的英文术语分别是:重载→Overloading;多态→Polymorphism重载的定义:在同一作用域内定义多个同名函数或操作符,但参数列表(类型、数量或顺序)不同。多态定义:通过继承和虚函数实现,允许不同子类对象对同一方法表
- #C8# UVM中的factory机制 #S8.2.1# factory 机制重载法则
那么菜
UVM
factory机制最伟大的地方在于其具有重载功能。重载并不是factory机制的发明,前面已经介绍过的所有面向对象的语言都支持函数/任务重载,另外,SystemVerilog还额外支持对约束的重载。只是factory机制的重载与这些重载都不一样。一问题引出以8.1.1节的代码清单8-1和代码清单8-2为例,定义好bird与parrot,并在测试用例中调用print_hungry函数。只是与8.1.
- nvidia_uvm 被占用,nvidia-smi 卡死
guganly
数据中心运维实战chrome前端服务器运维linux
系统可以识别到多块NVIDIAGPU,且驱动模块已加载,但nvidia_uvm被占用,nvidia-smi卡死,通常是由于以下原因导致:可能原因GPU资源被占用某些进程正在使用NVIDIA驱动,导致模块无法卸载。驱动损坏或加载异常NVIDIA内核模块部分加载,但驱动未能正确工作。GPU挖矿或AI任务未释放某些后台程序未正常退出,导致GPU资源无法被释放。PCIe通道异常多卡环境可能由于PCIe配置
- 【UVM基础】m_sequencer 和 p_sequencer 概念与区别(面试常问)
MoorePlus
数字IC验证百宝箱经验分享面试数字IC芯片验证SV
文章目录1、基本概念m_sequencerp_sequencer2、解释m_seqeuncer和p_sequencer的区别?3、uvm_declare_p_sequencer宏做了哪几件事?参考1、基本概念m_sequencer类型是uvm_sequencer_base类型,定义在uvm_sequence_item类中,注意:类型很重要。可以理解为每个sequence中默认都有m_sequenc
- 【数字IC验证】博客内容全览
MoorePlus
数字IC验证百宝箱经验分享面试数字IC芯片验证SV
【导读】:数字IC验证百宝箱涵盖博主在实际工作中常用的技能与工具,包括但不限于SV、UVM、Formal、脚本(perl/python/shell)及EDA工具快速上手使用等。无论你是刚踏入职场的验证小白,还是希望回顾基础寻找跳槽机会的从业者,本专栏都能为你提供实用的技术支持,在达成目标的路上,助你一臂之力。“凡是能用钱买来的时间就是便宜的;凡是能用时间换来的注意力持续就是有价值的。”(附上超链接
- uvm_info打印信息(整数/浮点数/字符串/数组/多个信号),快速更改冗余度及重载严重度
星海河空
经验分享linux
前言:熟悉打印信息方法和更改冗余度及严重度有利于大型项目的debug。一.打印信息1.打印整数:%d`uvm_info("MY_COMPONENT",$sformatf("my_signalvalue:%0d",my_signal),UVM_LOW)2.打印浮点数:%f或%.nf(n为保留的几位小数)`uvm_info("MY_COMPONENT",$sformatf("my_signalvalu
- 验证环境中为什么要用virtual interface
m0_71354184
systemverilog
在UVM(UniversalVerificationMethodology)中使用virtualinterface的主要目的是解决SystemVerilog接口(interface)的静态特性与UVM验证环境的动态特性之间的不匹配问题。1.解决静态与动态的绑定问题SystemVerilog接口(interface)是静态的:在编译时确定,无法直接用于动态创建的UVM对象(如driver、monit
- UVM的基本教程
如筏喻者
UVM学习其他
文章目录一、基本介绍二、在实践中学习1.接口interface2.待测设计DUT3.传输数据包transaction4.序列sequence5.序列器sequencer6.驱动器driver7.监视器monitor8.代理agent9.记分板scoreboard10.仿真环境env11.测试用例test12.顶层top13.参考模型referencemode和直接编程接口(DPI)14.简单的ma
- 3.10 学习UVM中的uvm_test类分为几步?
啄缘之间
UVM学习总结学习veriloguvm测试用例sv
文章目录前言1.定义2.核心功能3.适用场景4.使用方法步骤1:定义测试类步骤2:构建验证环境步骤3:启动测试序列5.完整代码示例5.1事务类(Transaction)5.2序列类(Sequence)5.3驱动类(Driver)5.4环境类(Env)5.5测试类(Test)5.6顶层模块(TopModule)6.代码说明7.总结前言以下是关于UVM中uvm_test的详细解释、核心功能、适用场景、
- 3.2.2 具体的案例展示uvm_object在实际验证中的应用?
啄缘之间
UVM学习总结学习svuvmverilog测试用例
文章目录前言一、案例一:使用uvm_object_utils()简化对象类设计1.1示例代码二、案例二:基于《UVM实战》的验证平台2.1示例代码三、案例三:以太网验证平台3.1示例代码四、案例四:验证一个简单的总线接口4.1、具体实现1.定义派生自`uvm_object`的事务类2.定义序列类3.定义驱动类4.定义环境类5.定义测试类6.顶层测试平台4.2、总结五、总结前言以下是几个具体的案例或
- 1.4 学习序列(Sequence)分为几步?
啄缘之间
UVM学习总结学习svuvm
文章目录前言一、什么是UVM中的Sequence?二、如何理解Sequence?三、如何使用Sequence?四、示例代码4.1示例14.1.1代码分析4.2示例24.2.1代码分析:五、总结前言需要回顾一下UVM的基本概念,特别是Sequence的部分。我记得Sequence是UVM中用于生成测试激励的重要组件,它允许我们以一种灵活和可重用的方式定义测试场景。Sequence可以随机化生成测试数
- 1.5 学习环境(Environment)分为几步?
啄缘之间
UVM学习总结学习verilog开发语言
文章目录前言一、什么是UVM中的环境(Environment)?二、如何理解UVM中的环境(Environment)?三、如何使用UVM中的环境(Environment)?四、代码示例五、实操前言先解释清楚UVM环境是什么,它在验证平台中的位置和作用。得强调UVM环境的层次化结构和可重用性,这是UVM环境的重要特点。一、什么是UVM中的环境(Environment)?UVM中的环境(Environ
- UVM TLM之analysis_port的write函数
斐非韭
uvm
analysis端口analysis_port/analysis_export(analysis_imp)没有阻塞和非阻塞概念在analysis_imp所在的模块必须定义一个write函数;write函数收到的数据放到run_phase中处理需要存放到队列中并借助一个event;(example)具体过程:analysis_port的write函数会依次获取与其相连的analysis_imp,并调
- 矩阵求逆(JAVA)初等行变换
qiuwanchi
矩阵求逆(JAVA)
package gaodai.matrix;
import gaodai.determinant.DeterminantCalculation;
import java.util.ArrayList;
import java.util.List;
import java.util.Scanner;
/**
* 矩阵求逆(初等行变换)
* @author 邱万迟
*
- JDK timer
antlove
javajdkschedulecodetimer
1.java.util.Timer.schedule(TimerTask task, long delay):多长时间(毫秒)后执行任务
2.java.util.Timer.schedule(TimerTask task, Date time):设定某个时间执行任务
3.java.util.Timer.schedule(TimerTask task, long delay,longperiod
- JVM调优总结 -Xms -Xmx -Xmn -Xss
coder_xpf
jvm应用服务器
堆大小设置JVM 中最大堆大小有三方面限制:相关操作系统的数据模型(32-bt还是64-bit)限制;系统的可用虚拟内存限制;系统的可用物理内存限制。32位系统下,一般限制在1.5G~2G;64为操作系统对内存无限制。我在Windows Server 2003 系统,3.5G物理内存,JDK5.0下测试,最大可设置为1478m。
典型设置:
java -Xmx
- JDBC连接数据库
Array_06
jdbc
package Util;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
public class JDBCUtil {
//完
- Unsupported major.minor version 51.0(jdk版本错误)
oloz
java
java.lang.UnsupportedClassVersionError: cn/support/cache/CacheType : Unsupported major.minor version 51.0 (unable to load class cn.support.cache.CacheType)
at org.apache.catalina.loader.WebappClassL
- 用多个线程处理1个List集合
362217990
多线程threadlist集合
昨天发了一个提问,启动5个线程将一个List中的内容,然后将5个线程的内容拼接起来,由于时间比较急迫,自己就写了一个Demo,希望对菜鸟有参考意义。。
import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.CountDownLatch;
public c
- JSP简单访问数据库
香水浓
sqlmysqljsp
学习使用javaBean,代码很烂,仅为留个脚印
public class DBHelper {
private String driverName;
private String url;
private String user;
private String password;
private Connection connection;
privat
- Flex4中使用组件添加柱状图、饼状图等图表
AdyZhang
Flex
1.添加一个最简单的柱状图
? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28
<?xml version=
"1.0"&n
- Android 5.0 - ProgressBar 进度条无法展示到按钮的前面
aijuans
android
在低于SDK < 21 的版本中,ProgressBar 可以展示到按钮前面,并且为之在按钮的中间,但是切换到android 5.0后进度条ProgressBar 展示顺序变化了,按钮再前面,ProgressBar 在后面了我的xml配置文件如下:
[html]
view plain
copy
<RelativeLa
- 查询汇总的sql
baalwolf
sql
select list.listname, list.createtime,listcount from dream_list as list , (select listid,count(listid) as listcount from dream_list_user group by listid order by count(
- Linux du命令和df命令区别
BigBird2012
linux
1,两者区别
du,disk usage,是通过搜索文件来计算每个文件的大小然后累加,du能看到的文件只是一些当前存在的,没有被删除的。他计算的大小就是当前他认为存在的所有文件大小的累加和。
- AngularJS中的$apply,用还是不用?
bijian1013
JavaScriptAngularJS$apply
在AngularJS开发中,何时应该调用$scope.$apply(),何时不应该调用。下面我们透彻地解释这个问题。
但是首先,让我们把$apply转换成一种简化的形式。
scope.$apply就像一个懒惰的工人。它需要按照命
- [Zookeeper学习笔记十]Zookeeper源代码分析之ClientCnxn数据序列化和反序列化
bit1129
zookeeper
ClientCnxn是Zookeeper客户端和Zookeeper服务器端进行通信和事件通知处理的主要类,它内部包含两个类,1. SendThread 2. EventThread, SendThread负责客户端和服务器端的数据通信,也包括事件信息的传输,EventThread主要在客户端回调注册的Watchers进行通知处理
ClientCnxn构造方法
&
- 【Java命令一】jmap
bit1129
Java命令
jmap命令的用法:
[hadoop@hadoop sbin]$ jmap
Usage:
jmap [option] <pid>
(to connect to running process)
jmap [option] <executable <core>
(to connect to a
- Apache 服务器安全防护及实战
ronin47
此文转自IBM.
Apache 服务简介
Web 服务器也称为 WWW 服务器或 HTTP 服务器 (HTTP Server),它是 Internet 上最常见也是使用最频繁的服务器之一,Web 服务器能够为用户提供网页浏览、论坛访问等等服务。
由于用户在通过 Web 浏览器访问信息资源的过程中,无须再关心一些技术性的细节,而且界面非常友好,因而 Web 在 Internet 上一推出就得到
- unity 3d实例化位置出现布置?
brotherlamp
unity教程unityunity资料unity视频unity自学
问:unity 3d实例化位置出现布置?
答:实例化的同时就可以指定被实例化的物体的位置,即 position
Instantiate (original : Object, position : Vector3, rotation : Quaternion) : Object
这样你不需要再用Transform.Position了,
如果你省略了第二个参数(
- 《重构,改善现有代码的设计》第八章 Duplicate Observed Data
bylijinnan
java重构
import java.awt.Color;
import java.awt.Container;
import java.awt.FlowLayout;
import java.awt.Label;
import java.awt.TextField;
import java.awt.event.FocusAdapter;
import java.awt.event.FocusE
- struts2更改struts.xml配置目录
chiangfai
struts.xml
struts2默认是读取classes目录下的配置文件,要更改配置文件目录,比如放在WEB-INF下,路径应该写成../struts.xml(非/WEB-INF/struts.xml)
web.xml文件修改如下:
<filter>
<filter-name>struts2</filter-name>
<filter-class&g
- redis做缓存时的一点优化
chenchao051
redishadooppipeline
最近集群上有个job,其中需要短时间内频繁访问缓存,大概7亿多次。我这边的缓存是使用redis来做的,问题就来了。
首先,redis中存的是普通kv,没有考虑使用hash等解结构,那么以为着这个job需要访问7亿多次redis,导致效率低,且出现很多redi
- mysql导出数据不输出标题行
daizj
mysql数据导出去掉第一行去掉标题
当想使用数据库中的某些数据,想将其导入到文件中,而想去掉第一行的标题是可以加上-N参数
如通过下面命令导出数据:
mysql -uuserName -ppasswd -hhost -Pport -Ddatabase -e " select * from tableName" > exportResult.txt
结果为:
studentid
- phpexcel导出excel表简单入门示例
dcj3sjt126com
PHPExcelphpexcel
先下载PHPEXCEL类文件,放在class目录下面,然后新建一个index.php文件,内容如下
<?php
error_reporting(E_ALL);
ini_set('display_errors', TRUE);
ini_set('display_startup_errors', TRUE);
if (PHP_SAPI == 'cli')
die('
- 爱情格言
dcj3sjt126com
格言
1) I love you not because of who you are, but because of who I am when I am with you. 我爱你,不是因为你是一个怎样的人,而是因为我喜欢与你在一起时的感觉。 2) No man or woman is worth your tears, and the one who is, won‘t
- 转 Activity 详解——Activity文档翻译
e200702084
androidUIsqlite配置管理网络应用
activity 展现在用户面前的经常是全屏窗口,你也可以将 activity 作为浮动窗口来使用(使用设置了 windowIsFloating 的主题),或者嵌入到其他的 activity (使用 ActivityGroup )中。 当用户离开 activity 时你可以在 onPause() 进行相应的操作 。更重要的是,用户做的任何改变都应该在该点上提交 ( 经常提交到 ContentPro
- win7安装MongoDB服务
geeksun
mongodb
1. 下载MongoDB的windows版本:mongodb-win32-x86_64-2008plus-ssl-3.0.4.zip,Linux版本也在这里下载,下载地址: http://www.mongodb.org/downloads
2. 解压MongoDB在D:\server\mongodb, 在D:\server\mongodb下创建d
- Javascript魔法方法:__defineGetter__,__defineSetter__
hongtoushizi
js
转载自: http://www.blackglory.me/javascript-magic-method-definegetter-definesetter/
在javascript的类中,可以用defineGetter和defineSetter_控制成员变量的Get和Set行为
例如,在一个图书类中,我们自动为Book加上书名符号:
function Book(name){
- 错误的日期格式可能导致走nginx proxy cache时不能进行304响应
jinnianshilongnian
cache
昨天在整合某些系统的nginx配置时,出现了当使用nginx cache时无法返回304响应的情况,出问题的响应头: Content-Type:text/html; charset=gb2312 Date:Mon, 05 Jan 2015 01:58:05 GMT Expires:Mon , 05 Jan 15 02:03:00 GMT Last-Modified:Mon, 05
- 数据源架构模式之行数据入口
home198979
PHP架构行数据入口
注:看不懂的请勿踩,此文章非针对java,java爱好者可直接略过。
一、概念
行数据入口(Row Data Gateway):充当数据源中单条记录入口的对象,每行一个实例。
二、简单实现行数据入口
为了方便理解,还是先简单实现:
<?php
/**
* 行数据入口类
*/
class OrderGateway {
/*定义元数
- Linux各个目录的作用及内容
pda158
linux脚本
1)根目录“/” 根目录位于目录结构的最顶层,用斜线(/)表示,类似于
Windows
操作系统的“C:\“,包含Fedora操作系统中所有的目录和文件。 2)/bin /bin 目录又称为二进制目录,包含了那些供系统管理员和普通用户使用的重要
linux命令的二进制映像。该目录存放的内容包括各种可执行文件,还有某些可执行文件的符号连接。常用的命令有:cp、d
- ubuntu12.04上编译openjdk7
ol_beta
HotSpotjvmjdkOpenJDK
获取源码
从openjdk代码仓库获取(比较慢)
安装mercurial Mercurial是一个版本管理工具。 sudo apt-get install mercurial
将以下内容添加到$HOME/.hgrc文件中,如果没有则自己创建一个: [extensions] forest=/home/lichengwu/hgforest-crew/forest.py fe
- 将数据库字段转换成设计文档所需的字段
vipbooks
设计模式工作正则表达式
哈哈,出差这么久终于回来了,回家的感觉真好!
PowerDesigner的物理数据库一出来,设计文档中要改的字段就多得不计其数,如果要把PowerDesigner中的字段一个个Copy到设计文档中,那将会是一件非常痛苦的事情。