在该宏中,SEQUENCER必须为“类型”,当程序中使用该宏时,SEQUENCER为用户自定义的sequencer,即示例中的my_sequencer,而因为宏中p_sequencer指定的类型为SEQUENCER,即也就是调用该宏时传入的参数my_sequencer,所以可以知道p_sequencer的类型为用户自定义的sequencer,即示例中的my_sequencer,而用户自定义的sequencer派生自uv...
m_sequencer是uvm_sequencer_base类型的句柄,默认情况下在每个sequence中都可用。连接到driver 的真正的sequencer 是从uvm_sequencer_base类派生出来的,其 被参数化为用于与driver 通信的sequence item类型。 因此要访问正在运行sequence 的真实sequencer ,我们需要将m_sequencer类型转化为真实sequencer ,通常称为p_sequencer。
其实,当在sequence中使用uvm_do宏时,其默认的sequencer就是此sequence启动时为其指定的sequencer(my_sequence.start(my_sequencer), 括号里的my_sequencer),sequence会将这个sequencer的指针my_sequencer放在其成员变量m_sequencer中,换句话说就是m_sequencer此时指向的就是my_sequencer。这里要注意,虽然m_sequencer句柄具...
p_sequencer是由`uvm_decalre_p_sequencer宏,定义在用户指定的sequence(例如类库中的your_sequence)中的,用户指定的类型的句柄(例如类库中的your_sequencer),也就是说 p_sequencer是由uvm_decalre_p_sequencer宏产生的 p_sequencer是用户指定的sequence的成员变量(这里是your_sequence的成员变量,因为`uvm_decalre_p_...
1)在介绍sequence 时,内部有m_sequencer, 直接使用m_sequencer 得到这两个变量: 编译错误: 因为m_sequencer 是uvm_sequencr_base (uvm_sequencr 的基类)类型,而不是my_sequencer 类型。 所以要cast:把m_sequencer 转换成my_sequencer: 但是好麻烦。所以内建了一个宏:uvm_declare_p_sequencer(SEQUENCER) ...
transaction,那么它的参数需要改成uvm_sequence_item,同时,driver里面也要有相应的处理。p_sequencer的使用 前文有讲到一个m_sequencer,这个指针是在sequence启动后,所在sequencer的指针。它的类型是uvm_sequencer_base(uvm_sequencer的基类) 而不是my_sequencer类型的。 当存在这么一个情况,我在 ...
uvm_sequencer_base m_sequencer;是uvm_sequence中的protected变量。 my_sequencer是从uvm_sequencer中扩展来的,并拥有独特的dmac/smac的变量。 m_sequencer是uvm_sequencer_base类型的句柄,实际指向的对象是my_sequencer。 所以如果想通过基类的句柄m_sequencer来访问扩展类在中独有的damc/smac的变量是不合法的,解决方...
`uvm_declare_p_sequencer可以认为就是定义一个SEQUENCER类型的变量p_sequencer,并且定义一个函数m_set_p_sequencer()(这个函数在uvm_sequence类中肯定以经存在了,否则还需要用户再手动调用,而我们从来没有自己调用过,所以UVM源代码中原本应该已经实现了该函数的调用了,这里要做的就是override覆盖原有函数定义),该函...
What are these ? (In a Different post regarding [get_/set_]config*, I was asked to use m_sequencer) I looked at the Virtual Sequencer documentation there the `ovm_do_on is pointing to sub_sequencer using p_sequencer… …
1.sequence 向sequencer 发送请求,一旦相应这个lock,sequencer 会一直发送此sequence 的transaction,知道unlock 被调用。(fork join) 2.one_lock: 1)sequence1: 2)结果: 3.dual_lock:首先获得所有权的sequence 执行完后才会将所有权交给另外一个sequence。