设计模式在芯片验证中的应用——单例

news/2024/9/25 9:20:10/

一、单例模式

单例模式(Singleton)是一种创建型设计模式,能够保证一个类只有一个实例, 并提供一个访问该实例的全局节点。验证环境配置(configuration)类、超时(timeout)处理类等可以使用单例实现。比如说验证环境需要在特定场景中监测特定接口上的超时事件,环境的每个组件都可以依赖超时处理类来设定超时的时刻。让所有组件都使用超时处理类的相同对象有助于调试。

单例模式主要包括以下两个组件:

  • 单例类(Singleton class):该类只能创建有限数量的对象,通常是一个对象。为了实现这一点,类的构造函数被定义为protected。使用静态instance()方法访问对象,该方法在第一次调用时执行初始化,后面直接返回这个类的句柄。
  • 客户端(Client):任何UVM组件都可以使用单例类的instance()方法来访问类对象。

下图为单例设计模式在timeout处理中应用的UML类图。

二、参考代码

单例设计模式用于timeout处理的参考代码如下:

class timeout;local static timeout m_inst = null;protected function new();endfunction : newstatic function timeout get_inst();if ( m_inst == null )m_inst = new();return m_inst;endfunction : get_insttask wait_timeout(int unsigned timeout_value);#(timeout_value*1ns);endtask : wait_timeoutendclass : timeout

模拟测试代码如下:

timeout inst = timeout::get_inst();forkbegin`uvm_info("START TIMEOUT COUNT 1", "", UVM_NONE)inst.wait_timeout(500);`uvm_info("END TIMEOUT COUNT 1", "", UVM_NONE)endbegin`uvm_info("START TIMEOUT COUNT 2", "", UVM_NONE)inst.wait_timeout(1000);`uvm_info("END TIMEOUT COUNT 2", "", UVM_NONE)end
join_none

输出仿真日志如下:

@ 0.000ns: [START TIMEOUT COUNT 1]
@ 0.000ns: [START TIMEOUT COUNT 2]
@ 500.000ns: [END TIMEOUT COUNT 1]
@ 1000.000ns: [END TIMEOUT COUNT 2]

根据仿真结果,timeout处理类能够同时跟踪多个超时事件,在第一个超时(time = 500ns)和第二个超时(time = 1000ns)时发出超时信号。


http://www.ppmy.cn/news/1464473.html

相关文章

NSSCTF-Web题目4

[SWPUCTF 2021 新生赛]hardrce 1、题目 2、知识点 rce:远程代码执行、url取反编码 3、解题思路 打开题目 出现一段代码,审计源代码 题目需要我们通过get方式输入变量wllm的值 但是变量的值被过滤了,不能输入字母和\t、\n等值 所以我们需…

视频汇聚EasyCVR平台视图库GA/T 1400协议与GB/T 28181协议的区别

在公安和公共安全领域,视频图像信息的应用日益广泛,尤其是在监控、安防和应急指挥等方面。为了实现视频信息的有效传输、接收和处理,GA/T 1400和GB/T 28181这两个协议被广泛应用。虽然两者都服务于视频信息处理的目的,但它们在实际…

【Paddle】Inplace相关问题:反向传播、影响内存使用和性能

【Paddle】Inplace相关问题:反向传播、影响内存使用和性能 写在最前面inplace 的好处有哪些?能降低计算复杂度吗在反向传播时,Inplace为什么会阻碍呢?“计算图的完整性受损”表达有误原地操作 sin_()为什么原地操作会阻碍反向传播…

新人学习笔记之(数据)

一、数据类型简介 1.为什么需要数据类型 (1)在计算机中,不同的数据所需占用的储存空间数不同的,为了便于把数据分成所需内存大小不同的数据,充分利用储存空间,于是定义了不同的数据类型。 (2&am…

基于xilinx FPGA的 FFT IP使用例程说明文档(可动态配置FFT点数,可计算信号频率与幅度)

目录 1 概述2 IP examples功能3 IP 使用例程3.1 IP设置3.2 fft_demo端口3.3 例程框图3.4 仿真结果3.5 仿真验证得出的结论4 注意事项5例程位置 1 概述 本文用于讲解xilinx IP 的FFT ip examples的功能说明,方便使用者快速上手。 参考文档:《PG109》 2 …

基于python flask的旅游数据大屏实现,有爬虫有数据库

背景 随着旅游行业的快速发展,数据在旅游决策和规划中的重要性日益凸显。基于 Python Flask 的旅游数据大屏实现研究旨在结合爬虫技术和数据库存储,为用户提供全面、实时的旅游信息展示平台。 爬虫技术作为数据采集的重要手段,能够从各种网…

网上打印资料A4纸一般多少钱一张

我们知道,在打印需求上A4纸(210mmx297mm)是较为常见的打印用纸,同时因为纸张的不同在价格上也存在一定的差异。当然,因在网上打印平台打印资料,能够降低一定的租金个人工成本。 因此,在网上打印…

AI在肿瘤学临床决策中的应用:一种多模态方法

在临床肿瘤学领域,多模态人工智能(AI)系统通过解读各类医学数据,展现出提升临床决策的潜力。然而,这些模型在所有医学领域中的有效性尚未确定。本文介绍了一种新型的多模态医疗AI方法,该方法利用大型语言模…