一、driver与sequence的改建
移除原有在各个driver
中的mailbox
句柄,以及在do_driver()
任务中使用mailbox
句柄通信的方式,转而用uvm_driver::seq_item_port
进行通信,同时定义对应的uvm_sequencer
。
在do_drive()中将原来用mailbox通信的方式改为PORT通信。通过driver的seq_item_port端口调用get_next_item(req)获取req,由sequence的函数set_sequence_id设置id,所用id为req这个item调用get_sequence_id得到的;最后返回rsp。
二、底层sequence的提取
将原来在各个generator中
发送transaction
的任务,提取为各个对应的底层sequence
。在各个agent
中声明、创建对应的sequencer
,并且将其与driver
通过TLM port连接起来。
三、移除generator的踪迹
在mcdf_base_test
中移除generator
的声明、创建以及和driver
之间的连接。
四、移除uvm_base_test的transaction发送方法
将已经被从uvm_base_test移植到reg_pkg中的方法idle_reg()、write_reg()和read_reg()从uvm_base_test中移除。由此uvm_base_test只变为了容器的性质,在它内部主要由mcdf_env、mcdf_config配置对象以及被用来挂载的顶层sequence构成。
五、添加顶层的virtual sequencer
virtual sequencer包含所有底层sequencer的句柄
由于MCDF验证环境中存在多个底层的sequencer和sequence,因此这就需要有顶层的virtual sequencer与virtual sequence统一调度。在定义了mcdf_virtual_sequencer之后,在mcdf_env中声明、例化,并且完成其与底层sequencer的句柄连接。
六、重构mcdf_base_test
原有的mcdf_base_test除了承担其容器的功能,还在其run_phase阶段中实现了sequence的分阶段发送功能。在添加了顶层的virtual sequencer之后,需要将所有发送序列的顺序和组织等内容均移植到mcdf_base_virtual_sequence,因此需要将mcdf_base_test::run_phase()发送序列的功能移植到定义的mcdf_base_virtual_sequence一侧,而在移植后,mcdf_base_test::run_phase()只需要挂载对应的顶层virtual sequence即可。