寄存器模型

article/2025/8/24 20:41:45

8.layering sequence

(1)概述

  • 转化:高抽象级item,中间的sequence,低抽象级item。

(2)寄存器模型的示意图

(3)示例代码:bus packet sequence

(4)示例代码:layer packet sequence

  • adapter_seq负责从高层次的transaction从高层次的sequence(layer_sequence)获取,继而转换为低层次的transaction,最终由低层次的sequence(physcial)发送出去。

  • adapter_seq宏声明了p_sequencer,类型为phy_master_sequencer,所以phy_master_sequencer是virtual sequencer。

  • layering_sequencer up_sqr; 从up_sqr中获得item。

  • 'uvm_do(pkt):将packet_seq挂载到adapter_seq上。

(5)示例代码:top sequence、layering_sequencer、phy_master_sequencer

(6)示例代码:phy_master_driver、agent

(7)示例代码:test

virtual sequence在顶层需要连接。

(8)图示

(9)示例解释



1.寄存器模型概述

(1)寄存器与硬件的关系

  • 寄存器模型的作用:反映硬件的状态:比如mcdf中fifo的状态。

(2)寄存器模型+UVC

(3)域、属性

(4)寄存器块、reserved

(5)寄存器模型、总线访问寄存器的方式、寄存器模型访问的方式


2.中心化管理方式

(1)示图

(2)

(3)

(4)


3.MCDF寄存器模型

(1)uvm_reg相关概念

  • 包含关系:uvm_reg_block>uvm_reg>uvm_reg_field;uvm_reg_block还包括uvm_reg_map。            

(2) 代码示例

[1]uvm_reg中new()函数中把这个寄存器的宽度作为参数传递给super.new函数:

如super.new(name, 16, UVM_NO_COVERAGE); 第1个参数是name, 第2个参数是寄存器的宽度,第3个参数是否要加入coverage。

[2]uvm_reg也是属于uvm_object类,uvm_reg_field是寄存器模型最小单位。

[3]rand的作用:设置寄存器模型期望值随机化。

[4]uvm_reg中的build类似于component中的build_phase,做创建和配置。

[5]reserved.configure(this, 26, 6, "RO", 0, 26'h0, 1, 0, 0);9个参数依次是:parent、位数(size)、起始bit位(lsb_pos)、“RO”(access)、volatile(表示是否是易失的(volatile),一般不会使用)、26‘h0:reset value、has_reset、is_rand、individually accessible(表示这个域是否可以单独存取)。

[6]uvm_reg中配置了uvm_reg_field的属性:比如RW;但是uvm_reg的属性在uvm_reg_map中配置。

[7]在reg_block中要对reg进行create、configure、build,config是将reg和当前的block关联起来,不像之前中env中run()会自动调用其子模块的run()。

[8]在reg_block中例化uvm_map,create_map("map",'h0,4,UVM_LITTLE_ENDIAN,0):其中第一个参数是名字,第二个参数是基地址,第三个参数则是系统总线的宽度,这里的单位是byte而不是bit,第四个参数是大小端,最后一个参数表示是否能够按照byte寻址。

[9]map.add_reg():配置reg的基地址和属性。

[10]以lock_model()结尾,该函数的功能是结束地址映射关系,并且保证模型不会被其它用户修改。

(3)总结



4.模型使用流程

(1)概述

(2)图示

  • 寄存器模型的三个优势:

  • 寄存器序列激励更好,可读与复用性更强。

  • 检查硬件的寄存器模型更方便。

  • 收集寄存器覆盖率。

(3)总结


5.总线UVC的实现

(1)UVC

  • UVC的全称是UVM component,往往是构建环境中所用到的最底层的组件。

(2)MCDF访问寄存器总线接口

  • 8位地址、32位数据线指的是地址有2^8个,每个地址对应的单元是32位的数据。

(3)MCDF访问寄存器接口的UVC代码:uvm_sequence_item、uvm_sequencer

  • 在sequencer(component)中调用了mcdf_if接口;

(4)MCDF访问寄存器接口的UVC代码:uvm_monitor

  • uvm_analysis_port定义了广播RSP的TLM端口,类似于driver上定义的。

  • mon_trans()做的是监测数据的传输。

  • ap.write(t):write是一个内建函数,将transaction写入ap。 

(5)MCDF访问寄存器接口的UVC代码:uvm_driver

  • get_sequence_id:根据rsp的sequence_id来找到这个rsp是哪个sequence发送的(每个req item在经sequence发送的时候够会带有unique id值);

  • get_transation_id:在sequence中调用get_response时,不指定transaction_id的话,默认是pop_front response_queue队列中的元素,同时get_response也可以指定要get确定transsaction_id的item,只需要输入相应的参数即可。比如id=req.get_transaction_id(); get_response(rsp,id);

(6)MCDF访问寄存器接口的UVC代码:mcdf_bus_agent

(7)示例解析



http://www.hkcw.cn/article/nauMMypafg.shtml

相关文章

Python训练营打卡Day39

DAY 39 图像数据与显存 知识点回顾 1.图像数据的格式:灰度和彩色数据 2.模型的定义 3.显存占用的4种地方 a.模型参数梯度参数 b.优化器参数 c.数据批量所占显存 d.神经元输出中间状态 4.batchisize和训练的关系 作业:今日代码较少,理解内容…

AI预测3D新模型百十个定位预测+胆码预测+去和尾2025年5月29日第92弹

从今天开始,咱们还是暂时基于旧的模型进行预测,好了,废话不多说,按照老办法,重点8-9码定位,配合三胆下1或下2,杀1-2个和尾,再杀6-8个和值,可以做到100-300注左右。 (1)定…

【AI智能体】Coze 插件从使用到实战详解

目录 一、前言 二、Coze 插件介绍 2.1 什么是插件 2.1.1 插件主要功能 2.1.2 coze 插件常用类型 2.1.3 coze 插件优势 2.2 插件与工具 2.3 插件费用说明 2.4 使用限制 2.5 权限说明 2.6 coze添加插件入口 三、Coze插件创建与使用 3.1 前置准备 3.1.1 查看api列表 …

python实现一个示波器仿真,可以改参数同步效果

代码 import sys import numpy as np import matplotlib.pyplot as plt from matplotlib.backends.backend_qt5agg import FigureCanvasQTAgg as FigureCanvas from matplotlib.backends.backend_qt5agg import NavigationToolbar2QT as NavigationToolbar from matplotlib.an…

【前端】使用grid布局封装断点式进度条

业务需求要求展示一个动态进度条,不同于第三方插件的进度条,这个ui设计的是断点式进度条,效果当然是美观大方,但是因为没有现成的第三方插件可以实现,这当然难不倒一个成熟的前端开发工程师。 根据ui设计可以看到进度条…

[ctfshow web入门] web78

信息收集 表面上没有任何过滤,自由发挥 if(isset($_GET[file])){$file $_GET[file];include($file); }else{highlight_file(__FILE__); }解题 这些解法都在web32解释过,不再详细解释,有需要点击超链接:[ctfshow web入门] web3…

小白的进阶之路系列之六----人工智能从初步到精通pytorch数据集与数据加载器

本文将介绍以下内容: 数据集与数据加载器 数据迁移 如何建立神经网络 数据集与数据加载器 处理数据样本的代码可能会变得混乱且难以维护;理想情况下,我们希望我们的数据集代码与模型训练代码解耦,以获得更好的可读性和模块化。PyTorch提供了两个数据原语:torch.utils…

Memory Repair (二)

Implementing BIRA and BISR Logic 本节介绍如何在 circuit 中插入 repair logic。重点是插入 BISR 逻辑。只要内存库文件中存在 RepairAnalysis 包装器,并且该实例的 repair_analysis_present 属性未设置为 “Off”,就会在内存 BIST 逻辑(控…

Vue 3 的路由管理

提示:记录工作中遇到的需求及解决办法 文章目录 前言一、简易路由器二、Vue Router创建路由器使用路由器创建页面前言 路由指的是通过不同 URL 访问不同页面的方式。 根据路由管辖权的归属不同,可以分为前端路由(Client-Side Routing)和后端路由(Server-Side Routing)。…

油猴脚本开发基础

1. 油猴脚本深度解析 1.1 什么是油猴脚本? 本质:基于JavaScript的浏览器扩展脚本工作原理:在网页加载时注入自定义JS代码核心能力: 修改DOM结构拦截网络请求操作浏览器API存储本地数据 应用场景: 广告屏蔽网页功能增…

练习:对象数组 1

定义数组存储 3 个商品对象。商品的属性:商品的 id,名字,价格,库存。创建三个商品对象,并把商品对象存入到数组当中。 //对象数组 1 package demo01; public class Goods {private int goodsid;private String goodsN…

Baklib知识中台驱动业务创新

知识中台构建四库体系 Baklib通过打造知识资源库、案例库、规则库及专家库四大核心模块,构建起企业级知识中台的底层架构。其中,知识资源库采用多维度标签体系对文档、报告等结构化与非结构化数据进行分类存储;案例库通过智能抽取技术沉淀业…

“文化人”董宇辉也学会了表演 为消费者争取福利

“文化人”董宇辉也学会了表演 为消费者争取福利。董宇辉在直播间开始“表演”与品牌商谈判的戏码。最近,他在销售某品牌电视时,商家表示要收取最高200元的安装费。董宇辉当场拒绝,表示不合理,并坚持不接受收费。最终,商家负责人现场沟通后决定为所有购买电视的朋友免费安…

H5通用模态框可滚动弹框

弹框要求&#xff1a; 1、弹框图片宽高不限制&#xff0c;自适应 2、关闭按钮固定在图片下方 3、长图时弹框图片可滚动&#xff0c;遮罩层固定 4、点击遮罩层可关闭按钮&#xff0c;不冒泡 图例&#xff1a; 代码 <div class"image-modal" v-if"curSideI…

代码随想录打卡|Day51 图论(dijkstra(堆优化版)精讲、Bellman_ford 算法精讲)

图论part09 dijkstra&#xff08;堆优化版&#xff09;精讲(不熟悉) 代码随想录链接 题目链接 import java.util.*;class Edge {int to; // 邻接顶点int val; // 边的权重Edge(int to, int val) {this.to to;this.val val;} }class MyComparison implements Comparator<…

RS232/485转Profinet网关通讯气体检漏仪案例分享

RS232/485转Profinet网关通讯气体检漏仪案例分享 RS232转Profinet网关作为一种重要的工业通讯设备&#xff0c;其作用是将传统的RS232接口设备转换为现代的Profinet接口&#xff0c;从而实现与现代自动化控制系统的无缝对接&#xff0c;提高系统的集成度和性能。 气体检漏仪作…

电感专题归纳

文章目录 6.2.1 概念6.2.1x 电感电流6.2.2 储能6.2.3 伏秒原则6.2.4 电感元件6.2.5 电感充放电 6.3 换路定则6.4 储能总结6.5 串并联6.5.1 电容串联6.5.2 电容并联6.5.4 电感串联6.5.5电感并联6.5.3 电容与电导 6.6 电容与电感的滤波 电感在电路中的坐拥只有两个字&#xff0c;…

2023-ICLR-ReAct 首次结合Thought和Action提升大模型解决问题的能力

关于普林斯顿大学和Google Research, Brain Team合作的一篇文章, 在语言模型中协同Reasoning推理和Action行动。 论文地址&#xff1a;https://arxiv.org/abs/2210.03629 代码&#xff1a;https://github.com/ysymyth/ReAct.git 其他复现 langchain &#xff1a;https://pytho…

吴艳妮落泪道歉 带伤参赛憾失金牌

5月29日,在亚洲田径锦标赛女子100米栏决赛中,吴艳妮以13秒07的成绩获得铜牌。赛后她走路有些一瘸一拐。在接受采访时,吴艳妮哽咽着向大家道歉:“很感谢你们来现场为我加油,没为中国队拿到这个冠军,很对不起大家。我的伤还没养好,不想为自己过多的解释,我还是觉得我在亚…

群辉(synology)NAS老机器连接出现网页端可以进入,但是本地访问输入一样的账号密码是出现错误时解决方案

群辉&#xff08;synology&#xff09;NAS老机器连接出现网页端可以进入&#xff0c;但是本地访问输入一样的账号密码是出现错误时解决方案 老机器 装的win7 系统 登入后端网页端的时候正常&#xff0c;但是本地访问登入时输入登入网页端一样的密码时候出现问题解决方案 1.登…