UVM中每个phase都有一个内置的objection ,为components和objects提供了同步方法,指示何时可以安全地结束这个phase,最终结束整个test case。
一般来说,由一个components或sequence在激励开始时raise phase objection,激励处理完毕之后drop objection。一旦所有提起的objections被dropped,该phase就终止了。
在仿真中,一个master agent可能需要在runphase停止之前完成所有的读写操作,一个reactive slave agent不会drop objection,因为它只是一直被动地处理事务。对于sequence来说,有三种可能的方式可以处理phase objection。
a)
class test extends ovm_test;
task run_phase(uvm_phase phase);
phase.raise_objection(this);
seq.start(seqr);
phase.drop_objection(this);
endtask
endclass
b)
class test extends ovm_test;
task run_phase (uvm_phase phase);
seq.set_starting_phase(phase);
seq.start(seqr);
endtask
endclass
class seq extends uvm_sequence #(data_item);
task body();
uvm_phase p = get_starting_phase();
if(p) p.raise_objection(this);
//some critical logic
if(p) p.drop_objection(this);
endtask
endclass
c)
class test extends ovm_test;
task run_phase (uvm_phase phase);
seq.set_starting_phase(phase);
seq.start(seqr);
endtask
endclass
class seq extends uvm_sequence #(data_item);
function new(string name = "seq");
super.new(name);
set_automatic_phase_objection(1);
endfunction
task body();
// Sequence logic with no objection
// as it is already handled in the base class
endtask
endclass
上面的三种方式只需要实现其中一种即可。
当所有objections都被dropped,当前运行的phase就结束了。在仿真过程中,可能需要一些额外的cycle来向scoreboard传输最后一笔transaction。
为了适配这种情况,可以使用phase_ready_to_end()方法在必要时刻重新提出phase objection。
另外,也可以设置一个drain time ,在组件所有objections都被dropped之后注入一个延迟。一般是在env或者test级设置drain time。
审核编辑:刘清
全部0条评论
快来发表一下你的评论吧 !