[UVM] reg map

ral model 中涉及到不同的map,这边给一些例子~~

class my_regmodel extends uvm_reg_block;
  ...
  uvm_reg_mapcpu_map;
  uvm_reg_mapgpu_map;
  ...
  cpu_map= create_map("cpu_map", 'h0, 2, UVM_LITTLE_ENDIAN);
  cpu_map.add_reg(R0, 'h0, "RW"); // real address: 'h0
  cpu_map.add_reg(R1, 'h2, "RW"); // real address: 'h2
  cpu_map.add_reg(R2, 'h4, "RW"); // real address: 'h4

  gpu_map= create_map("gpu_map", 'h1000, 2, UVM_LITTLE_ENDIAN);
  gpu_map.add_reg(R0, 'h0, "RW"); // real address: 'h1000
  gpu_map.add_reg(R1, 'h2, "RO"); // real address: 'h1002
  gpu_map.add_reg(R2, 'h4, "RW"); // real address: 'h1004

  set_default_map(cpu_map); // map to use if none specified
endclass: my_regmodel

//-----------------------------------------------------------------------
//sequence
//-----------------------------------------------------------------------

regblock.R0.write(status,8'ha5,.map(cpu_map),.parent(this));
regblock.R1.read(status,data,.map(gpu_map),.parent(this));
. . .
//----------------------------------------------
//env
//----------------------------------------------

function void my_env::build_phase(uvm_phasephase);
  uvm_reg_pridictor#(cpu_trans) cpu_predictor;
  uvm_reg_pridictor#(gpu_trans) gpu_predictor;
  ...
  regmodel= my_regmodel::type_id::create("regmodel");
  reg2apb = reg2apb_adapter::type_id::create("reg2apb");
  reg2ahb = reg2ahb_adapter::type_id::create("reg2ahb");
  cpu_predictor = uvm_reg_pridictor#(cpu_trans)::type_id::create("cpu_predictor");
  gpu_predictor = uvm_reg_pridictor#(gpu_trans)::type_id::create("gpu_predictor");
  regmodel.build();
  
  //1.use auto predict
  //regmodel.cpu_map.set_auto_predict();
  //regmodel.gpu_map.set_auto_predict();
endfunction: build_phase


function void my_env::connect_phase(uvm_phasephase);
  ...
  regmodel.cpu_map.set_sequencer(apb_agent.sequencer, reg2apb);
  regmodel.gpu_map.set_sequencer(ahb_agent.sequencer, reg2ahb);
 
  //2. use predictor 
  cpu_predictor.map= regmodel.cpu_map;
  cpu_predictor.adapter= reg2apb;
  apb_agent.monitor.ap(cpu_predictor.bus_in);


  gpu_predictor.map= regmodel.gpu_map;
  gpu_predictor.adapter= reg2ahb;
  ahb_agent.monitor.ap(gpu_predictor.bus_in);
endfunction: connect_phase

  UVM提供了两种用来跟踪寄存器值的方式,分别为自动预测(auto predicition)和显式预测。(上例已示范)

  •   auto prediction 对于sequence 直接在总线层面上对寄存器操作(不用ral model 的write/read task)无法自动得到register的的mirror value 和期望值。
  • 显式预测则可以,因为predictor实时监测bus上的动作。

 

版权声明:本文为lbt_dvshare原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/lbt_dvshare/article/details/82701147

智能推荐

reg免杀抓hash

1、下载下面3个文件 2、获取密码hash 方法1:使用mimikatz(本地机器系统与位数最好与目标主机保持一致) mimikatz.exe “lsadump::sam /system:sys.hiv /sam:sam.hiv” exit 方法2:python脚本 python /root/impacket/examples/secretsdump.py -sam sam...

lmplot fit_reg参数

lmplot fit_reg参数` API文档里的解释 fit_regbool, optional If True, estimate and plot a regression model relating the x and y variables. 如果为真,估计并绘制与x和y变量相关的回归模型。 默认为真,即绘制回归模型 lm=sns.lmplot(x=‘Age’,...

UVM——同步通信元件(uvm_event、uvm_barrier)

文章目录 一、uvm_event用法 二、uvm_barrier用法   SV中用来做线程间同步的几种方法,它们分别是semaphore、event和mailbox。   UVM中,同步不再只局限于同一个对象中的各个线程,而是还有各个组件之间的同步问题。一旦发生同步的要求发生在各个组件之间,这就要求组件之间通过某种可以同步的方法来实现。而考虑到UVM各个组件...

linux上安装Qt4.8.6+QtCreator4.0.3

一、Qt简介 Qt是1991年奇趣科技开发的一个跨平台的C++图形用户界面应用程序框架。它提供给应用程序开发者建立艺术级的图形用户界面所需的所有功能。Qt很容易扩展,并且允许真正地组件编程。 准备工作 操作系统:centos6.5 位数:64位 二、安装 1、获取源码Qt4.8.6 2、获取源码QtCreator4.0.3 2、安装QtCreator4.0.3 进入QtCreator安装界面,指定...

react-native metro 分析

文章目录 前言 概念 Resolution Transformation Serialization 打包方式 Moudles Plain bundle Indexed RAM bundle File RAM bundle 流程 前置流程 resolve流程 Transformer流程 序列化流程 缓存 为什么要缓存 缓存的请求与缓存 Metro配置 结构 前言 metro是一种支持ReactNa...

猜你喜欢

嵌入式Linux——应用调试:用户态打印段错误信息

简介:     很多时候我们会遇到段错误:segmentation fault,而段错误有时是由内核引起的,有时是由应用程序引起的。在内核态时,发生段错误时会打印oops信息,但是在用户态时,发生段错误却只会打印segmentation fault而并不会打印其他的信息。所以本文主要介绍在用户态时,通过修改内核设置和添加启动参数来打印引发segmentati...

springboot1.4.1整合logback 遇到的问题

springboot1.4.1整合logback 遇到的问题 项目使用了springboot1.4.1整合logback,然而设置的过期时间15 并没有生效, 2GB达到2G自动删除也没有生效,仅仅实现了按大小分割。 经过查看pom 父工程内的源码发现是默认的logback版本是1.1.7,而过期时间配置是在logback 1.1.8以后才支持的。 不得不说这是springboot1.4.1 的b...

记一次C/S架构的渗透测试

概述 目标站点是http://www.example.com,官网提供了api使用文档,但是对其测试后没有发现漏洞,目录、端口扫描等都未发现可利用的点。后发现官网提供了客户端下载,遂对其进行一番测试。 信息收集 先抓了下客户端的包,使用Fiddler和BurpSuite都抓不到,怀疑走的不是HTTP协议,用WireShark查看其确实用的是HTTP协议,但是数据包不好重放,这里最后使用了WSExp...

Linux:结合Securecrt进行文件上传(lrzsz)P2

1、安装rzsz软件   2、点击Scurecrt的option——X/Y/Z配置上传和下载目录   3、首先在Linux里切换到一个目录,然后用rz命令,文件就会上传到钙Linux的目录下   只要敲rz即可,然后在弹出的对话框里选择需要上传的文件即可 4、下载文件用sz   下载单个文件:在当前目录下有该文件     sz filename   下载...

SQL 提示作为 布局 生存工具指南

下面是一些展示AdventureWorks中表现最好的销售人员并列出他们的经理的结构化查询语言代码。 它产生以下结果。 所以,代码是有效的,但它是丑陋的。 如果我需要理解和改进代码,我首先需要把它变成可读的形式。 我有结构化查询语言提示,所以我可以按下计算机的ctrl按键键 踢你自己),它会应用默认的内置代码样式,并对此进行修复。 不,不是,因为我相信你仍然不喜欢它的格式。 没有两个开发人员能够就...