【uvm】uvm_event同步

原文

篇10-uvm通信之uvm_event & uvm_event_pool & uvm_event_callback
参考资料
(1) UVM通信篇之六:同步通信元件(上) - 路科验证的日志 - EETOP 创芯网论坛 (原名:电子*开发网) -

1.同步的方法

(1) 在sv中,用于同步的方法有event, semaphore和mailbox;

(2) 在UVM中,用于同步的方法为uvm_event;

(3) uvm_event不仅能实现不同组间进程间同步的功能,还能像TLM通信一样传递数据,并且作用范围更广(TLM通信只能局限于uvm_component之间,而uvm_event不限于此);

补充: 什么情况下会使用uvm_event呢?

组件之间的常规的数据流向是通过TLM通信方法实现的,比如sequencer与driver之间,或者monitor与scoreboard之间。然而有些时候,数据的传输的偶然触发的,并且需要立即响应,这个时候uvm_event就是得力的助手了。同时,uvm_event也解决了一个重要问题,那就是在一些uvm_object和uvm_component对象之间如果要发生同步,那么无法通过TLM传输,因为TLM传输必须是在组件(component)和组件之间进行的。譬如,在sequence与sequence之间要进行同步,或者sequence与driver

上一篇:【UVM基础】uvm_info 宏介绍


下一篇:UVM-sequence,sequencer,driver