在线咨询
eetop公众号 创芯大讲堂 创芯人才网
切换到宽版

EETOP 创芯网论坛 (原名:电子顶级开发网)

手机号码,快捷登录

手机号码,快捷登录

找回密码

  登录   注册  

快捷导航
搜帖子
查看: 6913|回复: 5

[求助] 求助:怎么写uvm_reg的sequence与test?

[复制链接]
发表于 2012-8-3 11:07:28 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?注册

x
各位:
    我回来折腾UVM了。现在我的DUT是一个带apb接口的ram,该ram宽32bit,深1024。我想使用uvm_reg对DUT进行仿真。首先是写ralf文件,然后再用vcs提供的工具来生成uvm_reg_block的相关代码。
    ralf文件内容如下:



  1. memory MY_RAM {
  2.   size 1k;
  3.   bits 32;
  4.   access rw;
  5. }

  6. block apb_basic_block {
  7.   bytes 4;
  8.   memory MY_RAM @32'h0000_0000;
  9. }

  10. system apb_basic_slave {
  11.   bytes 4;
  12.   block apb_basic_block=slave_block;
  13. }


复制代码
而vcs生成的uvm_reg_block的相关代码如下:



  1. `ifndef RAL_APB_BASIC_SLAVE
  2. `define RAL_APB_BASIC_SLAVE

  3. import uvm_pkg::*;

  4. class ral_mem_MY_RAM extends uvm_mem;
  5.     function new(string name ="MY_RAM");
  6.         super.new(name,`UVM_REG_ADDR_WIDTH'h400,32,"RW",build_coverage(UVM_NO_COVERAGE));
  7.     endfunction
  8.     virtual function void build();
  9.     end function :build

  10.     `uvm_component_utils(ral_mem_MY_RAM)
  11. endclass

  12. class ral_block_apb_basic_block extends uvm_reg_block;
  13.     rand ral_mem_MY_RAM MY_RAM;
  14.     function new (string name ="apb_basic_block");
  15.         super.new(name,build_coverage(UVM_NO_COVERAGE));
  16.     endfunction
  17.     virtual function void build();
  18.         this.default_map=create_map("",0,4,UVM_LITTLE_ENDIAN);
  19.         this.MY_RAM=ral_mem_MY_RAM::type_id::create("MY_RAM");
  20.         this.MY_RAM.build();
  21.         this.MY_RAM.configure(this,"");
  22.         this.default_map.add_mem(this.MY_RAM,`UVM_REG_ADDR_WIDTH'h0,"RW",0);
  23.     endfunction : build

  24.     `uvm_object_utils(ral_block_apb_basic_block)
  25. endclass : ral_block_apb_basic_block

  26. class ral_sys_apb_basic_slave extends uvm_reg_block;
  27.     rand ral_block_apb_basic_block slave_block;
  28.     function new(string name="apb_basic_slave");
  29.         super.new(name);
  30.     endfunction
  31.     function build();
  32.         this.default_map=create_map("",0,4,UVM_LITTLE_ENDIAN);
  33.         this.slave_block=ral_block_apb_basic_block::type_id::create("slave_block");
  34.         this.slave_block.configure(this,"");
  35.         this.slave_block.build();
  36.         this.default_map.add_submap(this.slave_block.default_map,`uvm_REG_ADDR_WIDTH'h0);
  37.     endfunction : build

  38.     `uvm_component_utils(ral_sys_apb_basic_slave)
  39. endclass : ral_sys_apb_basic_slave
  40. `endif



复制代码
然后,建立一个environment来与apb_env放一块,这块是自己写的,代码如下:



  1. `ifndef REG_TB
  2. `define REG_TB

  3. `include "demo_cfg.sv"
  4. `include "reg_seq.sv"
  5. `include "ral_sys_apb_basic_slave.sv"

  6. class reg_tb extends uvm_env;
  7.   `uvm_component_utils(reg_tb)
  8.   apb_env                   apb0;
  9.   demo_config               demo_cfg;
  10.   ral_sys_apb_basic_slave   regmodel;
  11.   reg_to_apb_adapter        reg_sqr_adapter;
  12.   reg_to_apb_adapter        mon_reg_adapter;
  13.   uvm_reg_prediector#(apb_transfer) reg_predictor;

  14.   function new(string name,uvm_component parent);
  15.     super.new(name,parent);
  16.   endfunction
  17.   virtual function build_phase(uvm_phase phase);
  18.     super.build_phase(phase);
  19.     demo_cfg=demo_config::type_id::create("demo_cfg");
  20.     uvm_config_object::set(this,"apb0*","cfg",demo_cfg);
  21.     uvm_config_object::set(this,"apb0.slave[0]*","cfg",demo_cfg.slave_configs[0]);
  22.     apb0=apb_env::type_id::create("apb0");
  23.     //for reg model
  24.     regmodel=ral_sys_apb_basic_slave::type_id::create("regmodel");
  25.     regmodel.configure(null,"top.u_dut");
  26.     regmodel.build();
  27.     regmodel.lock();
  28.     regmodel.reset();
  29.     reg_sqr_adapter=reg_to_apb_adapter::type_id::create("reg_sqr_adapter",,get_full_name());
  30.     mon_reg_adapter=reg_to_apb_adapter::type_id::create("mon_reg_adapter",,get_full_name());
  31.     reg_predictor=new("reg_predictor",this);

  32.   endfunction : build_phase

  33.   function void connect_phase(uvm_phase phase);
  34.     regmodel.define_map.set_sequencer(apb0.master.sequencer,reg_sqr_adapter);
  35.     regmodel.define_map.set_auto_predict(1);
  36.     reg_predictor.map=regmodel.define_map;
  37.     reg_predictor.adapter=mon_reg_adapter;
  38.     apb0.slave.monitor.item_collected_port.connect(reg_predictor.bus_in);
  39.   endfunction:connect_phase
  40. endclass :reg_tb
  41. `endif



复制代码
然后到写sequence和test的时候,我就不知道该怎么写了,有谁能指点一下,或者提供一个例子,或者指出上哪儿去找例子呀?
发表于 2012-8-3 23:33:11 | 显示全部楼层
建议别折腾什么RGM的东西,直接用driver和monitor那一套搞就好了,不大一点的RAM,用RGM有点浪费。呵呵。就照着APB的时序写组件就好了。
 楼主| 发表于 2012-8-4 09:33:58 | 显示全部楼层
回复 2# gaurson


    我目前是用一个最简单的来练手,实际上我们要验的IP是对高清图像处理的,需要存储器的地方又多又大又杂,全从总线上的话太费时间了,想能不能通过RGM的后面直接往存储器里面灌图像数据。
 楼主| 发表于 2012-8-4 14:02:42 | 显示全部楼层
另外,问一下,除了sequence和test,还需要改写一下apb_master_sequencer么?
发表于 2012-8-7 09:41:18 | 显示全部楼层
I have never used UVM_REG. But I think you still need something like REG2APB/APB2REG to mapping your register sequence item to the APB sequence time and verse.
 楼主| 发表于 2012-8-7 10:10:40 | 显示全部楼层
回复 5# enchanter

apb_adapter已经写好。准确的说是用了从cadence网站下的ref_flow中的apb环境,里面带有apb_adapter。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

站长推荐 上一条 /1 下一条

×

小黑屋| 手机版| 关于我们| 联系我们| 在线咨询| 隐私声明| EETOP 创芯网
( 京ICP备:10050787号 京公网安备:11010502037710 )

GMT+8, 2024-11-11 08:31 , Processed in 0.023864 second(s), 9 queries , Gzip On, Redis On.

eetop公众号 创芯大讲堂 创芯人才网
快速回复 返回顶部 返回列表