callback源码分析——callbacks

uvm的callback必须是提供者有预见性的留一些方法在function先后,这样在使用的时候,进行遍历调度便可    函数

  设计者,须要从uvm_callback定义一个基类,只定义function原型定义一个uvm_callbacks,即pool类型;设计

      在对象类中使用register_cb宏来注册callbacks;  3d

  使用者,须要从指定的uvm_callback扩展出一个实现类,并将该类的一个对象add到对应的pool中;对象

 

callbacks中有两个参数,一个表示object,一个表示具体的callback,由于一个object可能有多个callback;blog

typed_callback,中只有一个参数,表示object;继承

callbacks_base,则通用的定义了一个uvm_pool,m_pool,以object为索引,返回uvm_queue类型的队列;递归

 

callbacks_base,从uvm_object继承而来,单实例化设计,其中定义了两个static变量,因为并非一个参数化的类;索引

    因此m_b_inst和m_pool在系统中,只有一份;队列

    

 

uvm_typed_callbacks从uvm_callbacks_base继承而来,参数化的类,以callback对应的object为参数;get

    其中定义了两个参数化的变量;变量m_t_inst,队列m_tw_cb_q;

    因此两个static变量根据paramter的不一样会有不少份;

    

uvm_callbacks从uvm_typed_callbacks,继承而来,有两个参数,object和callback,

    其中定义了两个主要的static变量,m_inst,m_base_inst,m_base_inst只与object类型有关;

    因此不一样的object和callback,m_inst都还有多份;

    

 

uvm_register_cb(T,CB)的define;

    

调用了一个uvm_callbacks的function, m_register_pair,而且新定义了一个变量来接收返回值;

 

1)首先必须在uvm_callback扩展的时候,定义一个uvm_callbacks的class;

  m_register_pair一个static的函数,调用get函数,以后递归调用initial function,实现全部static变量的定义;

      

      

      

2)uvm_typeid获得static的实例化typeid_base的class;

      

3)注册m_typeid和m_cb_typeid的值到uvm_typeid_base的static变量中;一个object的参数化类,一个callback的参数化类;

      m_base_inst中push back全部的m_inst,即callbacks的种类;

      

 

add function,static类型,将object和相应的callback加到对应的callbacks中;

      首先调用get函数,此时各个inst都不是null,不会执行代码;若是callback为null,报错;

      

      从m_pool中拿到指定object的callback queue;若是为null,新建一个;

      

 

        若是对应的callback已经加到对应的object的queue中,报warning;不然根据order的类型,进行push操做;

        不一样的order顺序,决定了定义同一object的callback的执行顺序;

      

 

若是add的时候,object的值为null,则将callback加到本身类型的queue中;

      

add_by_name,static function只是在uvm_root中进行find函数调用,查找指定name的comp,在调用add函数;

    找到的comp队列都加入callback;

      

 

delete函数,static类型,拿到m_pool中的队列,删除相应的callback,找不到相应的callback,报warning;

      

若是delete的时候,传入的object的值为null,则删除该类型中的queue中的callback;

 

delete_by_name相似。

 

提供给其余class的static函数 实现;

get_first;先拿到该comp类型的对象(null),或者某个对象的callback队列;

      若是没有add进m_pool中,则也进行add操做;

      

      

get_last,get_prev,get_next,相似,可是须要显示指定itr的值;

 

使用时也能够调用宏ucm_do_obj_callbacks进行遍历调用;

      

相关文章
相关标签/搜索