UVM RAL 中的显示预测 uvm_reg_predictor

在之前简单介绍了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是如何处理的
这种情况比较特殊,具体看下面的流程。

  • 1
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值