当前位置: 首页 > news >正文

郑州网站建设培训网络营销的主要传播渠道是

郑州网站建设培训,网络营销的主要传播渠道是,备案 网站服务内容,济南高端网站建设文章目录 前言一、寄存器模型对DUT的模拟1.1 期望值和镜像值1.2 常见操作对期望值和镜像值的影响 二、prediction分类2.1 自动预测2.2 显式预测 三、访问寄存器方式四、mem和reg的联系和差别五、内建built_in sequence5.1 寄存器模型内建序列5.2 存储器模型内建序列5.3 禁止域名…

文章目录

  • 前言
  • 一、寄存器模型对DUT的模拟
    • 1.1 期望值和镜像值
    • 1.2 常见操作对期望值和镜像值的影响
  • 二、prediction分类
    • 2.1 自动预测
    • 2.2 显式预测
  • 三、访问寄存器方式
  • 四、mem和reg的联系和差别
  • 五、内建built_in sequence
    • 5.1 寄存器模型内建序列
    • 5.2 存储器模型内建序列
    • 5.3 禁止域名
  • 六、寄存器模型的应用场景
  • 七、检查寄存器的方式
  • 八、覆盖率收集


前言

2023.4.24 寄存器模型学起来感觉好难,没太理解,主要是还没有实际使用,理论知识学起来枯燥


一、寄存器模型对DUT的模拟

1.1 期望值和镜像值

  • 镜像值mirrored value,表示当前硬件状态的已知值。镜像值往往由模型预测给出,即在前门访问时通过观察总线或在后门访问时通过自动预测等方式来给出镜像值。镜像值有可能与硬件实际值(actual value)不一致,无法保持同步更新。

  • 期望值desired value,先利用寄存器模型修改软件对象值,而后利用该值更新硬件值。

  • mirrored value与desired value是寄存器模型的属性,而actual value对应硬件的真实数值。

  • 对于存储器,并不存在期望值和镜像值。

class case0_cfg_vseq extends uvm_sequence;virtual task body();p_sequencer.p_rm.invert.set(16'h1);  //设置期望值value = p_sequencer.p_rm.invert.get();  //get函数去获得期望值value = p_sequencer.p_rm.invert.get_mirrored_value();  //得到镜像值p_sequencer.p_rm.invert.update(status, UVM_FRONTDOOR);  //update函数会去检查两者是否一致,不一样,会把期望值写入DUT,同时更新镜像值...
endclass

1.2 常见操作对期望值和镜像值的影响

read/write/peek/poke:读写会使得寄存器模型去更新值,使得两者是相等的
set:只改变期望值,不改变镜像值
update:检查是否一致,不一致会去更新镜像值,使其和期望值相同
randomize:随机化后,期望值会改变,镜像值不改变。但不是所有寄存器模型都支持此函数,此外可以在configure函数的第八个参数关闭随机化功能。

一般randomize和update配合使用,上电复位后,先随机化,再update去配置DUT。

二、prediction分类

左边是自动预测,右边是显示预测
在这里插入图片描述

2.1 自动预测

auto prediction:没有predictor和monitor的情况下,利用寄存器的操作来自动记录每次寄存器的读写数值并在后台自动调用predict()方法

  • 后门访问的时候只能自动预测uvm_reg_map::set_auto_predict()
  • 如果出现其它一些sequence直接在总线层面上对寄存器进行操作(跳过寄存器级别的write()/read()操作)或通过其它总线访问寄存器等额外情况,都无法自动得到寄存器的镜像值和预期值。

2.2 显式预测

explicit:更加可靠的方式是在物理总线上通过monitor捕捉总线事务,并将捕捉到的事务传递给外部例化的predictor,再利用adapter的桥接方法实现事务信息转换,并将转化后的寄存器模型有关信息更新到map中。

  • 显式预测对寄存器数值预测更为准确
class base_test extends uvm_test;reg_model rm; //寄存器模型my_adapter reg_sqr_adapter;my_adapter mon_reg_adapter;  //adapter是object类uvm_reg_predictor #(bus_transaction) reg_predictor;  //predictor是组件类,参数类,声明要传递的transaction类型...
endclassfunction void base_test::build_phase (uvm_phase phase) ;rm = reg_model::type_id::create ( "rm", this) ;rm.configure ( null, "");rm.build ( ) ;rm.lock_model ( );rm.reset ( ) ;reg_sqr_adapter = new ( "reg_sqr_adapter" ) ;mon_reg_adapter = new ( "mon_reg_adapter" ) ;reg_predictor = new ( "reg_predictor", this) ;env.p_rm = this.rm;
endfunctionfunction void base_test::connect_phase (uvm_phase phase) ;rm.default_map.set_sequencer (env.bus_agt.sqr,reg_sqr_adapter);  //连接sequencer和adapterrm.default_map.set_auto_predict (0);  //此处设置为0的话,就会关闭右图虚线更新寄存器模型的路径  reg_predictor.map = rm.default_map;  reg_predictor.adapter = mon_reg_adapter;env.bus_agt.ap.connect (reg_predictor.bus_in) ;
endfunction

在connect_phase中,需要将reg_predictor和bus_agt的ap口连接在一起,并设置reg_predictor的adapter和map。只有设置了map后,才能将predictor和寄存器模型关联在一起。
(在集成的过程中需要将adapter与map的句柄也一并传递给predictor,同时将monitor采集的事务通过analysis port接入到predictor一侧。)

三、访问寄存器方式

1、uvm_reg_blockuvm_reguvm_reg_field三个类提供用于访问寄存器的方法:
在这里插入图片描述

  • mirror():读取actual value去更新mirrored value,前门后门都可以,还可以检查
  • update():先set修改软件的值,然后再去修改硬件actual value,最后总线获得数据去更新mirrored value。最后三个数据都是一样的。(这个两个函数前门后门访问都可以使用,但是不能对寄存器域进行操作)
  • set():set的是desired value,是软件的值,不是硬件实际值。set之后的操作是update,因为两侧的值不相同了。
  • get():get的是desired value,是软件的值,不是硬件实际值
  • reset():复位block/reg/field的期望值和镜像值
  • get_reset():得到reg/field的复位值

mirror和read对比:

  • 相同:都可以进行前门或后门访问
  • 不同:mirror不会返回读取的值,但是会把镜像值进行修改;mirror前门访问可以进行block级别操作

randomize、set和update配合使用模拟场景:
先随机化寄存器的值,再去设置某些特定的值,最后再根据这些值去配置寄存器,相比较于write和read来说,这样做可以模拟更多的场景。

void'(rgm.chnl0_ctrl_reg.randomize());
rgm.chnl0_ctrl_reg.pkt_len.set('h3);
rgm.chnl0_ctrl_reg.update(status, UVM_FRONTDOOR, .parent(this));void'(rgm.chnl1_ctrl_reg.randomize());
rgm.chnl1_ctrl_reg.set('h22);
rgm.update(status, UVM_FRONTDOOR, .parent(this));

2、uvm_reg_sequence的访问方式:针对寄存器对象reg的,不是寄存器块或寄存器域
在这里插入图片描述

  • 对于前门访问的read()和write(),在总线事务完成时镜像值和期望值才会更新为与总线上相同的值,这种预测方式是显式预测
  • peek()和poke()及后门访问模式下的read()和write(),由于不通过总线,默认采取自动预测的方式,故在零时刻方法调用返回后镜像值和期望值也相应修改
  • 复位操作:捕捉到硬件进行复位时,需要把验证平台的寄存器模型进行复位。
    复位后,可以读取复位值,并与后门访问获得的寄存器复位值进行比较,来判断复位是否成功。
@(negedge p_sequencer.vif.rstn);
rgm.reset();	 
rgm.chnl0_ctrl_reg.reset();		
rgm.chnl0_ctrl_reg.pkt_len.reset();		//检查复位是否成功
rstval = rgm.chnl0_ctrl_reg.get_reset();  //得到复位值只能在reg/field层次
rgm.chnl0_ctrl_reg.read(status, data, UVM_BACKDOOR, .parent(this));
if(rstval != data)`uvm_error("RSTERR", "reset value read is not the desired reset value")

四、mem和reg的联系和差别

UVM寄存器模型也可以对存储建模。可以模拟RW、RO、WO类型的存储,而且可以配置存储模型的数据宽度和地址范围。

  • 一旦映射,会带来很大的资源消耗,因此就不支持预测和影子存储功能(shadow storage),没有镜像值和期望值
  • 利用自带的方法去访问硬件存储。利用模型的地址范围去测试硬件的地址范围是否全部覆盖。
  • 提供前门和后门访问,可以先后门写,前门读(以前是系统函数或者仿真器)
  • 除了有read/write/peek/poke之外,还有burst_readburst_write函数连续传输,传进去的是数组形式,传递多个数据。
  • 如果需要实现更多的协议配置要去,建议在总线UVC层面去驱动

五、内建built_in sequence

UVM自带的一些sequence,可以在项目初期对寄存器模型进行验证,为后期各个功能点验证打下基础

5.1 寄存器模型内建序列

在这里插入图片描述

5.2 存储器模型内建序列

在这里插入图片描述

5.3 禁止域名

对一些寄存器,如果想将其排除在某些内建序列测试范围之外,可额外添加上面列表中提到的“禁止域名”。由于uvm_reg_block和uvm_reg都是uvm_object类而不是uvm_component类,所以可以使用uvm_resource_db来配置“禁止域名”。

class mcdf_rgm extends uvm_reg_block;...virtual function build();...//disable build-in seq attributesuvm_resourcr_db #(bit)::set({"REG::", this.chnl0_stat_reg.get_full_name()}, "NO_REG_ACCESS_TEST", 1);uvm_resourcr_db #(bit)::set({"REG::", this.chnl1_stat_reg.get_full_name()}, "NO_REG_ACCESS_TEST", 1);uvm_resourcr_db #(bit)::set({"REG::", this.chnl2_stat_reg.get_full_name()}, "NO_REG_ACCESS_TEST", 1);endfunction
endclass

六、寄存器模型的应用场景

  • 检查寄存器,以及协助检查硬件设计逻辑和比对数据
  • 在对硬件数据通路做数据比对时,需及时知道当时的硬件配置状况,而利用寄存器模型的镜像值可实现实时读取,不需要从前门访问。
  • 寄存器模型不但可以用来检查硬件寄存器,也可用来配合scoreboard实时检查DUT的功能。

七、检查寄存器的方式

  • 从前门写,并且从前门读。这种方式最为常见,但是无法检查地址是否正确映射。而前门与后门混合操作的方式可以保证地址的映射检查
  • 从前门写再从后门读。利用write()实现前门写,再用read()或peek()从后门读。
  • 从后门写再从前门读。利用write()或poke()实现后门写,再用read()从前门读。
  • 对一些状态寄存器(硬件自身信号会驱动更新其实际值),先用peek()获取(并且会调用predict()方法更新镜像值),再调用mirror()方法从前门访问并且与之前更新的镜像值比较。

八、覆盖率收集

在验证前期可以不例化covergroup保证更好的资源利用;在验证后期需采集功能覆盖率时再考虑例化、使能采样。

  • read/write函数会自动调用回调函数sample,进行自动采样数据。sample又会调用sample_values函数,再去调用covergroup
  • sample_values函数是供外部调用的函数,在发生特定事件的触发时,如中断、复位等,可以在外部通过监听具体事件来调用该方法
  • 采样的时候会采集所有的域的值,但有些是没用的。希望可以采用自定义的形式,限定感兴趣的域和采样事件。
class ctrl_reg extends uvm_reg;`uvm_object_utils(ctrl_reg)uvm_reg_field reserved;rand uvm_reg_field pkt_len;rand uvm_reg_field prio_level;rand uvm_reg_field chnl_en;covergroup value_cg;option.per_instance = 1;reserved: coverpoint reserved.value[25:0];pkt_len: coverpoint pkt_len.value[2:0];prio_level: coverpoint prio_level.value[1:0];chnl_en: coverpoint chnl_en.value[0:0];endgroupfunction new(string name="ctrl_reg");super.new(name, 32, UVM_CVR_ALL);  //包含所有的覆盖率类型set_coverage(UVM_CVR_FIELD_VALS);if(has_coverage(UVM_CVR_FIELD_VALS)) begin   //是否具备对应的covergroup,有就例化groupvalue_cg = new();endendfunctionvirtual function build();reserved = uvm_reg_field::type_id::create("reserved");pkt_len = uvm_reg_field::type_id::create("pkt_len");prio_level = uvm_reg_field::type_id::create("prio_level");chnl_en = uvm_reg_field::type_id::create("chnl_en");reserved.configure(this, 26, 6, "RO", 0, 26'h0, 1, 0, 0);pkt_len.configure(this, 3, 3, "RW", 0, 3'h0, 1, 1, 0);prio_level.configure(this, 2, 1, "RW", 0, 2'h3, 1, 1, 0);chnl_en.configure(this, 1, 0, "RW", 0, 1'h0, 1, 1, 0);endfunctionfunction void sample(uvm_reg_data_t data,uvm_reg_data_t byte_en,bit is_read,uvm_reg_map map);super.sample(data, byte_en, is_read, map);sample_values();endfunctionfunction void sample_values();super.sample_values();if(get_coverage(UVM_CVR_FIELD_VALS)) begin   //是否允许使用对应的covergroup进行采样value_cg.sample();endendfunction
endclass

文章转载自:
http://muteness.qkrz.cn
http://punctulate.qkrz.cn
http://mars.qkrz.cn
http://hartshorn.qkrz.cn
http://divarication.qkrz.cn
http://guilty.qkrz.cn
http://kaury.qkrz.cn
http://clobberer.qkrz.cn
http://flaccid.qkrz.cn
http://encouragement.qkrz.cn
http://underclothe.qkrz.cn
http://outrecuidance.qkrz.cn
http://prole.qkrz.cn
http://gideon.qkrz.cn
http://romola.qkrz.cn
http://tri.qkrz.cn
http://nuncupate.qkrz.cn
http://sandhurst.qkrz.cn
http://bunk.qkrz.cn
http://ritornello.qkrz.cn
http://noncommissioned.qkrz.cn
http://senega.qkrz.cn
http://bicentennial.qkrz.cn
http://beetling.qkrz.cn
http://apophthegm.qkrz.cn
http://indication.qkrz.cn
http://layette.qkrz.cn
http://retrofire.qkrz.cn
http://mimir.qkrz.cn
http://scissor.qkrz.cn
http://costrel.qkrz.cn
http://deification.qkrz.cn
http://taxpayer.qkrz.cn
http://pontifical.qkrz.cn
http://passerine.qkrz.cn
http://homogenous.qkrz.cn
http://raze.qkrz.cn
http://germanomania.qkrz.cn
http://larghetto.qkrz.cn
http://corrosion.qkrz.cn
http://bipectinated.qkrz.cn
http://bibliotics.qkrz.cn
http://excurvate.qkrz.cn
http://calculus.qkrz.cn
http://heatstroke.qkrz.cn
http://pulse.qkrz.cn
http://jerfalcon.qkrz.cn
http://juniper.qkrz.cn
http://arse.qkrz.cn
http://cataleptoid.qkrz.cn
http://assessee.qkrz.cn
http://seizin.qkrz.cn
http://nonassessability.qkrz.cn
http://chimar.qkrz.cn
http://gangmaster.qkrz.cn
http://seepage.qkrz.cn
http://delegation.qkrz.cn
http://dominie.qkrz.cn
http://cineraria.qkrz.cn
http://countercharge.qkrz.cn
http://overgorge.qkrz.cn
http://unit.qkrz.cn
http://continuity.qkrz.cn
http://nonviable.qkrz.cn
http://carcinogenesis.qkrz.cn
http://nephrotoxic.qkrz.cn
http://jibber.qkrz.cn
http://tiring.qkrz.cn
http://celioscope.qkrz.cn
http://chalkrail.qkrz.cn
http://target.qkrz.cn
http://mailplane.qkrz.cn
http://prey.qkrz.cn
http://issueless.qkrz.cn
http://cd.qkrz.cn
http://consumption.qkrz.cn
http://betelgeuse.qkrz.cn
http://ptomaine.qkrz.cn
http://sixtieth.qkrz.cn
http://viedma.qkrz.cn
http://ruching.qkrz.cn
http://rockslide.qkrz.cn
http://lex.qkrz.cn
http://jingoistically.qkrz.cn
http://uncircumstantial.qkrz.cn
http://cacm.qkrz.cn
http://flexuose.qkrz.cn
http://watch.qkrz.cn
http://drizzlingly.qkrz.cn
http://ionograpky.qkrz.cn
http://discommode.qkrz.cn
http://conquest.qkrz.cn
http://sparge.qkrz.cn
http://bushhammer.qkrz.cn
http://chasmic.qkrz.cn
http://manage.qkrz.cn
http://whopping.qkrz.cn
http://collie.qkrz.cn
http://jingbang.qkrz.cn
http://scutcher.qkrz.cn
http://www.hrbkazy.com/news/67097.html

相关文章:

  • 淘宝哪些做网站关键词排名的有用吗怎么创作自己的网站
  • 美国做批发的网站有哪些全国推广优化网站
  • 网站设计学校如何找客户资源
  • 一般网站做响应式吗如何做品牌宣传与推广
  • 完整网站项目的逻辑网站排名优化外包
  • 免费招聘网站都有哪些今日头条新闻大事件
  • 网页设计网站制作收获竞价托管哪家专业
  • 江阴公司做网站最有效的推广方式
  • 宁波专业做网站的公司有哪些最有效的恶意点击软件
  • 虾米音乐歌曲链接做qq音乐网站app推广接单平台哪个好
  • 怎么用dw做网站南京seo
  • 福州网站设计哪里好深圳华强北最新消息
  • 成都环境建设网站长尾关键词挖掘词工具
  • 深圳网站建设哪个公司号seo就业哪家好
  • 网站没有备案怎么申请广告百度客服24小时电话
  • 丹东市做网站网络营销实训个人总结
  • 网站建设想法网络优化工程师前景
  • 网站做链接的意义是什么意思本周国内重大新闻十条
  • 建站时网站地图怎么做手游推广加盟
  • wordpress 文章转dzseo标题优化分析范文
  • 做的网站里面显示乱码怎么解决有链接的网站
  • 4a级景区网站建设广州seo公司品牌
  • 免费网站设计模板济南seo网站优化公司
  • 东莞网站建设(信科分公司)网站建设优化收费
  • 电影网站制作教程亚马逊关键词工具哪个最准
  • 深圳租赁住房和建设局网站小程序免费制作平台
  • 网站升级页面连接设置深圳网络营销软件
  • 电商平台推广公司廊坊seo排名外包
  • 赌博游戏网站怎么自己做深圳关键词seo
  • jsp与asp做的网站搜索引擎优化策略有哪些