在 UVM方法学中,UVM sequences 是寿命有限的对象 。
UVM sequences从uvm_sequence_item基类扩展得到,uvm_sequence_item进一步从uvm_object基类扩展得到。
UVM sequences不是在仿真的开始,而是在仿真的过程中生成并分配内存的,也没有类似uvm_component的层次结构。
随着仿真的进行,将创建一个或多个UVM sequences ,并在sequencer上启动这些序列。sequencer-driver之间的接口 将一个或多个sequences 作为激励发送给DUT。一旦sequences 发送完成,对应的内存将得到释放。
往往我们在书写测试用例或者sequences的时候会有查询验证平台组件uvm_component的需求,比如env/driver/monitor。
由于sequences不是测试平台层次结构的一部分,实现这种需求就比较困难 。sequences唯一可以访问的句柄是它当前运行的sequencer 。因此,sequences需要通过sequencer 访问测试平台中层次结构。
这就是m_sequencer/p_sequencer概念的用处。
m_sequencer是uvm_sequencer_base类型的句柄,默认情况下在每个sequence中都可用。连接到driver 的真正的s