Q:激勵最初產生在driver中,后來產生在sequence中。為什么會有這個過程呢?
Q:當一個激勵在driver中產生,當要對DUT施加不同的激勵時,那應該怎么辦呢?
Q:如何在定義后啟動一個sequence
//當完成一個sequence的定義后,可以使用start任務將其啟動
my_sequence my_seq;
my_seq = my_sequence::create("my_seq");
my_seq.start(sequencer);
//除了直接啟動之外,還可以使用default_sequence啟動
uvm_config_db#(uvm_object_wrapper)::set(this,"env.i_agt.sqr.main_phase","default_sequence",case0_sequence::get());
A:使用sequence機制之后,在不同的測試用例中,將不同的sequence設置成sequencer的main_phase的default_sequence。當sequencer執行到main_phase時,發現有default_sequence,那么它就啟動sequence。
A:當一個sequence啟動后會自動執行sequence的body任務。其實,除了body外,還會自動調用sequence的pre_body與post_body
文件:src/my_case0.sv3
class case0_sequence extends uvm_sequence #(my_transaction);
…
virtual task pre_body();
`uvm_info("sequence0", "pre_body is called!!!", UVM_LOW)
endtask
virtual task post_body();
`uvm_info("sequence0", "post_body is called!!!", UVM_LOW)
endtask
virtual task body();
…
#100;
`uvm_info("sequence0", "body is called!!!", UVM_LOW)
…
endtask
`uvm_object_utils(case0_sequence)
endclass
Q:UVM支持同一時刻在同一sequencer上啟動多個sequence,那同時啟動多個sequence時,哪個先執行呢?
Q:sequencer根據什么選擇使用哪個sequence的transaction呢?這是UVM的sequence機制中的仲裁問題
//例如如下啟動了seq0和seq1
文件:src/no_pri/my_case0.sv
task my_case0::main_phase(uvm_phase phase);
sequence0 seq0;
sequence1 seq1;
seq0 = new("seq0");
seq0.starting_phase = phase;
seq1 = new("seq1");
seq1.starting_phase = phase;
fork
seq0.start(env.i_agt.sqr);
seq1.start(env.i_agt.sqr);
join
endtask
A:對于transaction來說,存在優先級的概念,通常來說,優先級越高越容易被選中。當使用uvm_do或者uvm_do_with宏時,產生的transaction的優先級是默認的優先級,即-1。可以通過uvm_do_pri及uvm_do_pri_with改變所產生的transaction的優先級
文件:src/item_pri/my_case0.sv3
class sequence0 extends uvm_sequence #(my_transaction);
…
virtual task body();
…
repeat (5) begin
`uvm_do_pri(m_trans, 100)
`uvm_info("sequence0", "send one transaction", UVM_MEDIUM)
end
#100;
…
endtask
…
endclass
class sequence1 extends uvm_sequence #(my_transaction);
…
virtual task body();
…
repeat (5) begin
`uvm_do_pri_with(m_trans, 200, {m_trans.pload.size < 500;})
`uvm_info("sequence1", "send one transaction", UVM_MEDIUM)
end
…
endtask
…
endclass
uvm_do_pri與uvm_do_pri_with的第二個參數是優先級,這個數值必須是一個大于等于-1的整數。數字越大,優先級越高。
A:除transaction有優先級外,sequence也有優先級的概念
文件:src/sequence_pri/my_case0.sv
task my_case0::main_phase(uvm_phase phase);
…
env.i_agt.sqr.set_arbitration(SEQ_ARB_STRICT_FIFO);
fork
seq0.start(env.i_agt.sqr, null, 100);
seq1.start(env.i_agt.sqr, null, 200);
join
endtask
-
driver
+關注
關注
0文章
526瀏覽量
66722 -
UVM
+關注
關注
0文章
182瀏覽量
19228 -
sequence
+關注
關注
0文章
23瀏覽量
2862
原文標題:UVM之sequence機制
文章出處:【微信號:FPGA學姐,微信公眾號:FPGA學姐】歡迎添加關注!文章轉載請注明出處。
發布評論請先 登錄
相關推薦
UVM sequence分層有哪幾種方式呢
UVM sequence分層的幾種體現
如何在SpinalHDL里啟動一個仿真
如何配置sequence的仲裁算法和優先級及中斷sequence的執行
sequence item實際應用中應該包含哪些東西
如何在啟動文件中調用定義為uint32_t getValue(void)的C函數呢?
UVM中seq.start()和default_sequence執行順序
淺談UVM之sequence/item見解(上)
![淺談UVM之<b class='flag-5'>sequence</b>/item見解(上)](https://file.elecfans.com/web1/M00/45/D5/o4YBAFp5YuCAUvLmAAAy0q6PnwM341.png)
如何配置sequence的仲裁算法和優先級?
![如何配置<b class='flag-5'>sequence</b>的仲裁算法和優先級?](https://file1.elecfans.com/web2/M00/82/58/wKgZomRKIrqATw8xAAAfRtkuDbc705.png)
UVM設計中的sequence啟動方式有哪幾種呢?
![UVM設計中的<b class='flag-5'>sequence</b><b class='flag-5'>啟動</b>方式有哪幾種呢?](https://file1.elecfans.com/web2/M00/90/DF/wKgaomTdgZCAGq9kAAAnwfSCLs4862.jpg)
如何將sequences類型添加或注冊到sequence library里呢?
![如何將sequences類型添加或注冊到<b class='flag-5'>sequence</b> library里呢?](https://file1.elecfans.com/web2/M00/A3/96/wKgaomT6x-qAWMk4AAF7iIp9Kgg610.jpg)
評論