sequence中的objection的控制策略
在整颗UVM树中,树的结点很多,理论来说在任何组件中都可以控制objection。一般在sequence和virtual sequence中,也有在scoreboard和test中。
一般来说,在一个实际的验证平台中,通常会有以下两种objection的控制策略:
第一种:
在scoreboard中进行控制,但要注意当收集到指定数量的数据后,利用fork…join_any跳出循环。
第二种:
在sequence中提起sequencer的objection,当sequence完成后,再撤销此objection。
class case0_sequence extends uvm_sequence #(my_transaction);
my_transaction m_trans;
function new(string name= "case0_sequence");
super.new(name);
endfunction
virtual task body();
if(starting_phase != null) //
starting_phase.raise_objection(this); //置起objection
repeat (10) begin
`uvm_do(m_trans)
end
#100;
if(starting_phase != null) //
starting_phase.drop_objection(this); //撤销objection
endtask
`uvm_object_utils(case0_sequence)
endclass
以上两种方式在验证平台中都有应用。其中第二种用的最多,这也是UVM提倡的方式。UVM的设计哲学就是全部由sequence来控制激励的生成,因此一般情况下只在sequence中控制objection。
virtual sequence中objection的控制策略
一般来说,有三个地方可以控制objection。一是普通的sequence,二是中间层的virtual sequence,三是最顶层的virtual sequence。
一般只在最顶层的virtual sequence中控制objection。因为virtual sequence是起统一调度作用的,这种统一调度不只体现在transactio上,也应该体现在objection上。同时在仿真时,经常会出现仿真没有按照预期的结束,这样就不需要层层的查找,从而提高debug的效率。
class case0_sequence extends uvm_sequence #(my_transaction); //virtual sequence
my_transaction m_trans;
function new(string name= "case0_sequence");
super.new(name);
endfunction
virtual task body();
crc_seq cseq;
long_seq lseq;
if(starting_phase != null)
starting_phase.raise_objection(this); //raise objection
repeat (10) begin
`uvm_do(cseq)
`uvm_do(lseq)
end
#100;
if(starting_phase != null)
starting_phase.drop_objection(this); //drop objection
endtask
`uvm_object_utils(case0_sequence)
endclass