OVM的run.test的执行顺序

top module里总会写一句run.test

但是找到testcase类,里面有诸多函数,到底是按什么顺序执行的呢?

1 build()

   获取配置信息
  创建 components.
  配置 components

2 connect()

3 end of elaboration

4 start of simulation

显示 banners, 打印tb的策略 和配置信息

5 run()

 sequencer生成随机的data给driver 这一步是由ovm类库自动执行的。

driver 会从sequencer获得data并按照协议驱动dut端口

6 extract()

  数错误数量
  查看覆盖率信息
  查看DUT内部信号和寄存器值
  查看不同component的内部变量
  从component查看其它信息

7 check()

8 report()


build()  connect() 都是top-down,check()和report是bottom-up。为了不重复在父类或子类中执行这些函数,格式上将super._写在函数的第一行。


加用户自定义步骤

1 在某类里写一个函数A

2 用ovm_func_decl宏 注册A到ovm_phase类里的call_task将call_task覆盖。

3 在环境component的构件器里或top module的initial里写入ovm_top.insert_phase即可。




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值