SystemVerilog 引入了面向对象的思想。对象句柄为语言提供了一种安全的、类似于指针的机制。
类提供了继承和抽象建模的能力,这就将不带有任何类型安全性问题的 C 函数指针的优点引入到了 SystemVerilog 中,因此它为 Verilog 带来了真正的多态性。
它包含了数据以及对数据进行操作的成员函数(函数和任务)。类的数据被称为类属性,它的子程序被称为方法,无论是类属性还是方法都是类的成员。类属性和方法结合在一起,定义了某种类型的对象的内容和能力。
由于其继承了面向对象的思想,因此在 SV 中可以定义类,然后例化,例如下面的代码。
class X_mac_env extends uvm_env;
X_mac_agent input_agt;//用于向 DUT 发送数据在实例化中,配置为 ACTIVE 模式
X_mac_agent output_agt;//用于向 DUT 接收数据,配置为 PASSIVE 模式
X_mac_reference_model X_mac_model;//实例化 model 和 scoreboard
X_mac_scoreboard X_mac_scb;
//定义了三个 fifo,用于连接 scoreboard 的两个接口和 reference model 的一个接口
uvm_tlm_analysis_fifo #(X_mac_reg_transaction ) reg_agt_mdl_fifo ;//i_agt<==>ref model
uvm_tlm_analysis_fifo #(eth_frame_transaction ) eth_agt_mdl_fifo ;//i_agt<==>ref model
uvm_tlm_analysis_fifo #(fec_frame_transaction ) X_mac_agt_mdl_fifo;//i_agt<==>ref model
uvm_tlm_analysis_fifo #(X_mac_reg_transaction ) reg_agt_scb_fifo ;//o_agt<==>scb
uvm_tlm_analysis_fifo #(eth_frame_transaction ) eth_agt_scb_fifo ;//o_agt<==>scb
uvm_tlm_analysis_fifo #(fec_frame_transaction ) X_mac_agt_scb_fifo;//o_agt<==>scb
uvm_tlm_analysis_fifo #(X_mac_reg_transaction ) reg_mdl_scb_fifo ;//ref<==>scb
uvm_tlm_analysis_fifo #(eth_frame_transaction ) eth_mdl_scb_fifo ;//ref<==>scb
uvm_tlm_analysis_fifo #(fec_frame_transaction ) X_mac_mdl_scb_fifo;//ref <==>scb
extern function new(string name,uvm_component parent);
extern virtual function void build_phase(uvm_phase phase);
extern virtual function void connect_phase(uvm_phase phase);
`uvm_component_utils(X_mac_env)
endclass
像在 env 这个类中,就例化了两个X_mac_agent、 refernence model 和 scoreboard,另外例化了 9 个 fifo,使用十分方便。
END
作者:验证哥布林
原文链接:https://mp.weixin.qq.com/s/rbo0\_rgRQ\_Bmzj3nzdn55g
微信公众号:
推荐阅读
更多IC设计技术干货请关注IC设计技术专栏