UVM基本概念

本文详细介绍了UVM验证平台的典型结构,包括UVM TEST、Environment、Scoreboard、Agent、Sequencer、Driver和Monitor。UVM TEST作为顶层组件,负责配置和调用sequence。UVM Environment整合组件,而Scoreboard用于检查DUT功能。Agent包含sequencer、driver和monitor,分别用于控制transaction、驱动激励和监测接口。UVM类库提供了构建验证平台的工具和类。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

UVM验证平台的典型结构

典型的UVM验证平台一般即例化DUT和UVM类库并配置其中的连接关系。UVM动态例化,可以一次编译完成多个测试用例的测试。

UVM TEST

UVM TEST是UVM的顶层Component组件,主要完成例化和配置顶层env,并通过env调用sequence产生激励从而给到DUT。

一般情况下,会有一个基本的base_test用于对env的例化以及其他共同的UVM元素组件的生成例化。然后其他的test则继承该base_test并有针对性地配置env或者选择不同的sequence来测试。

UVM Environment

UVM env主要用于将UVM组件进行有关联的分层。一般在env里例化agent、scoreboard,设置是其他的env,顶层的env用于封装用来对DUT测试的环境。

UVM Scoreboard

Scb主要用于检查DUT的行为功能是不是符合预期。通过agent的analysis port来接收DUT的输入和输出的transaction。将输入transaction灌入到reference model来产生期望的结果,然后与DUT实际的输出结果作比较。

UVM Agent

agent用于对一些UVM组件进行分层和连接,主要用于完成DUT的接口。

一个典型的agent包括一个用于管理激励序列的sequencer,一个用于施加激励到DUT接口的driver,以及一个用于监测DUT接口的monitor,另外还可能包括一些如覆盖率收集、协议检查等。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值