AHB—SRAM项目之5 reference_model与scoreboard(SV自学笔记)

2023-10-14 11:40

本文主要是介绍AHB—SRAM项目之5 reference_model与scoreboard(SV自学笔记),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

这一部分的内容是重难点所在。开始该部分之前应该至少掌握sram的基本架构和reference model与scoreboard的数据流向。

Reference model用于模拟DUT的功能,对DUT的行为做一个预测,来看看DUT的行为是否正确,并且把结果送入scoreboard与DUT的结果进行一个比较。

首先因为要将driver和sb连起来,所以mailbox用于通信,在两者中均声明一个mailbox传递相同类型的参数,并起同样的名字。在本例中,在两者之外实例化mailbox,即在env中实例化mailbox。操作如下:

 

  1. 在env中实例化一个mailbox,将mailbox放在env里面

  1. 在driver和scoreboard里声明mailbox传递数据包的属性,并用new函数实现mailbox与env的通信。

 接着考虑将driver内部的信号传递出去给sb,由于结束一笔trans时,我们通常会将结束的内容放入mst_pending_que_acpt,因此将其中的数据传给sb去模拟DUT即可。注意:红框内mailbox多余,相同的变量类型不可以多次声明。否则编译可以通过,但信号不会真正连接起来。

接下来在driver中将要传给scoreboard的数据发送到mailbox,注意应该判断一笔trans结束时,从pending_que中拿出要结束的trans,并且给到mst_pending_que_acpt,那么刚好mst_pending_que_acpt中就包含了所有我们写入DUT和scoreboard的信号(除了读取的数据,因为读的数据是从DUT给到总线上的,所以当hwrite为低时,应该把总线上的读信号打包入数据包内),所以将mst_pending_que_acpt这个经过DUT的数据包放入mailbox中发送给scoreboard与reference model作比较。

 

写scoreboard代码的核心部分,需要了解DUT在存数据的时候的方式。

首先要知道RTL里面地址结构是如何的。这里一定要理解这句话的含义,由于64K为2**16个地址(每个地址8bits)。因此,地址位宽16bit。每32个bit(4个bist)组成一个mem[index],因此放入一个8bit数据时,首先可以根据地址的低两位判断放在哪个bist里(也就是确定了放在哪个列里),然后杀掉低两位根据地址的其他高位确定放在哪个mem[index]里,也就是哪一行里,因为每行4个bist,不看低两位正好相当于除以4,确定了行列后,将数据放入到对应的位置上即可。

举个hsize为8bit的例子,总线位宽是32bit数据中的8个有效,地址需要放到5里,5是8’b0000_0101,根据低两位判断在bist1里,再根据高位判断在mem[1]行,对应的位置是mem[1][15:8]。

这里需要理解为什么要将数据的[15:8]放在地址[15:8]里,因为总线数据位宽是一个物理参数,只要定成了32bit就是无法改变的,每次传送数据时,都是将32bit的数据传递过来,只不过当hsize是8bit有效时,要根据相应规则判断哪8个bit为有效。因为传入的地址是4'b0101,所以[15:8]有效,同样当hsize为16bit时,也是根据传入的地址判断是哪16个bit有效,而传输如果是32bit的,那么则是一次传输的32个bit都是有效的。

对于写入数据无需进行比较,因为写到DUT和scoreboard中的数据总是相同的。但读操作有所不同,因为读操作时数据来源是不同的,要将DUT中的数据和reference model流出的数据做比较。并通过打印语句给出比较结果。

如果发现在score board的reference model里面读出来的数据和DUT流出的数据一致,则说明是匹配的,但是此处需要注意的是匹配符号应该使用===全等号,否则对于x仿真器会判别为不相等。

在测试写出的sc是否能够正确跟我们想要的结果一致的时候,我们应该设法控制输入的数据波形更容易观测。以下是我们目前搭建的验证平台基本概况。

这篇关于AHB—SRAM项目之5 reference_model与scoreboard(SV自学笔记)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/210264

相关文章

一文教你如何将maven项目转成web项目

《一文教你如何将maven项目转成web项目》在软件开发过程中,有时我们需要将一个普通的Maven项目转换为Web项目,以便能够部署到Web容器中运行,本文将详细介绍如何通过简单的步骤完成这一转换过程... 目录准备工作步骤一:修改​​pom.XML​​1.1 添加​​packaging​​标签1.2 添加

tomcat多实例部署的项目实践

《tomcat多实例部署的项目实践》Tomcat多实例是指在一台设备上运行多个Tomcat服务,这些Tomcat相互独立,本文主要介绍了tomcat多实例部署的项目实践,具有一定的参考价值,感兴趣的可... 目录1.创建项目目录,测试文China编程件2js.创建实例的安装目录3.准备实例的配置文件4.编辑实例的

GORM中Model和Table的区别及使用

《GORM中Model和Table的区别及使用》Model和Table是两种与数据库表交互的核心方法,但它们的用途和行为存在著差异,本文主要介绍了GORM中Model和Table的区别及使用,具有一... 目录1. Model 的作用与特点1.1 核心用途1.2 行为特点1.3 示例China编程代码2. Tab

springboot集成Deepseek4j的项目实践

《springboot集成Deepseek4j的项目实践》本文主要介绍了springboot集成Deepseek4j的项目实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录Deepseek4j快速开始Maven 依js赖基础配置基础使用示例1. 流式返回示例2. 进阶

SpringBoot项目启动报错"找不到或无法加载主类"的解决方法

《SpringBoot项目启动报错找不到或无法加载主类的解决方法》在使用IntelliJIDEA开发基于SpringBoot框架的Java程序时,可能会出现找不到或无法加载主类com.example.... 目录一、问题描述二、排查过程三、解决方案一、问题描述在使用 IntelliJ IDEA 开发基于

SpringBoot项目使用MDC给日志增加唯一标识的实现步骤

《SpringBoot项目使用MDC给日志增加唯一标识的实现步骤》本文介绍了如何在SpringBoot项目中使用MDC(MappedDiagnosticContext)为日志增加唯一标识,以便于日... 目录【Java】SpringBoot项目使用MDC给日志增加唯一标识,方便日志追踪1.日志效果2.实现步

Ubuntu中Nginx虚拟主机设置的项目实践

《Ubuntu中Nginx虚拟主机设置的项目实践》通过配置虚拟主机,可以在同一台服务器上运行多个独立的网站,本文主要介绍了Ubuntu中Nginx虚拟主机设置的项目实践,具有一定的参考价值,感兴趣的可... 目录简介安装 Nginx创建虚拟主机1. 创建网站目录2. 创建默认索引文件3. 配置 Nginx4

SpringBoot项目启动错误:找不到或无法加载主类的几种解决方法

《SpringBoot项目启动错误:找不到或无法加载主类的几种解决方法》本文主要介绍了SpringBoot项目启动错误:找不到或无法加载主类的几种解决方法,具有一定的参考价值,感兴趣的可以了解一下... 目录方法1:更改IDE配置方法2:在Eclipse中清理项目方法3:使用Maven命令行在开发Sprin

Nginx实现高并发的项目实践

《Nginx实现高并发的项目实践》本文主要介绍了Nginx实现高并发的项目实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录使用最新稳定版本的Nginx合理配置工作进程(workers)配置工作进程连接数(worker_co

Vue项目的甘特图组件之dhtmlx-gantt使用教程和实现效果展示(推荐)

《Vue项目的甘特图组件之dhtmlx-gantt使用教程和实现效果展示(推荐)》文章介绍了如何使用dhtmlx-gantt组件来实现公司的甘特图需求,并提供了一个简单的Vue组件示例,文章还分享了一... 目录一、首先 npm 安装插件二、创建一个vue组件三、业务页面内 引用自定义组件:四、dhtmlx