callback源码分析——callbacks
uvm的callback必须是提供者有预见性的留一些方法在function前后,这样在使用的时候,进行遍历调度即可
设计者,需要从uvm_callback定义一个基类,只定义function原型,定义一个uvm_callbacks,即pool类型;
在对象类中使用register_cb宏来注册callbacks;
使用者,需要从指定的uvm_callback扩展出一个实现类,并将该类的一个对象add到对应的pool中;
callbacks中有两个参数,一个表示object,一个表示具体的callback,因为一个object可能有多个callback;
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为参数;
其中定义了两个参数化的变量;变量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进行遍历调用;