UVM RAL 中的显示预测 uvm_reg_predictor

本文详细探讨了UVM RAL中的uvm_reg_predictor如何实现显示预测,重点解析了write()方法的功能,并介绍了当register位宽大于bus_width时的处理策略。强调挂载的map必须是root_map,adapter可以是local_adapter或root_adapter,byte_en默认全开,且predict工作在采样到完整寄存器数据后执行。可以根据需求重载write方法。
摘要由CSDN通过智能技术生成

在之前简单介绍了uvm_reg_predic是怎么实现显示预测的,连上map,连上adapter,连上bus_in即可,下面我们要详细的解释原因
先解释uvm_reg_predict中重要变量的作用

uvm_reg_map map :  从bus总线上上采样到addr信息之后,有map根据addr寻找到RAL中相关寄存器句柄
uvm_reg_adapter adapter:从bus总线上上采样到addr信息之后,调用adapter.bust2reg实现transaction 转换
uvm_analysis_imp#(BUSTYPE,uvm_reg_predict#(BUSTYPE))  bus_in  :TLM 端口

核心方法write(),下面总结了这个方法具体做的事情

(1)    判断adapter是否为null
(2)    应该增加判断map是否为null(虽然UVM源码中没有实现,严谨的角度应该判断)//注意这里挂载的map的必须是root_map。
(3)    adapter.bus2reg//    transaction转换
(4)    map.get_reg_by_offset //获取RAL中reg句柄
(5)    获取reg所在local_map的map_info//获取reg的直连map的map_info信息
(6)    根据map_info信息调用uvm_reg::do_predict//实现预测,包的括多地址的处理情况

上面即为实现显示预测的全步骤
下面介绍一下当register 位宽大于bus_width的时候,uvm_reg_predict是如何处理的
这种情况比较特殊,具体看下面的流程。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值