UVM中每個phase都有一個內(nèi)置的objection,為components和objects提供了同步方法,指示何時可以安全地結(jié)束這個phase,最終結(jié)束整個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
上面的三種方式只需要實現(xiàn)其中一種即可。
當所有objections都被dropped,當前運行的phase就結(jié)束了。在仿真過程中,可能需要一些額外的cycle來向scoreboard傳輸最后一筆transaction。
為了適配這種情況,可以使用phase_ready_to_end()方法在必要時刻重新提出phase objection。
另外,也可以設置一個drain time,在組件所有objections都被dropped之后注入一個延遲。一般是在env或者test級設置drain time。
審核編輯:劉清
-
仿真器
+關注
關注
14文章
1048瀏覽量
86730 -
UVM
+關注
關注
0文章
183瀏覽量
19933
原文標題:管理test case結(jié)束機制
文章出處:【微信號:芯片驗證工程師,微信公眾號:芯片驗證工程師】歡迎添加關注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄
基于base test如何來構(gòu)造測試用例
條件(Case)結(jié)構(gòu)的運用細節(jié)
Linux Shell系列教程之(十三)Shell分支語句case … esac教程
如何解決vhdl代碼中的case語句問題?
工作流管理系統(tǒng)柔性機制
linux內(nèi)存管理機制淺析
淺析物理內(nèi)存與虛擬內(nèi)存的關系及其管理機制
JavaScript定時器與執(zhí)行機制介紹
聊一聊所謂的Objection機制
CASE:創(chuàng)建多路分支

管理test case結(jié)束機制介紹
評論