config_db机制分为set和get两个操作,set和get一般都成对出现。 set函数范式 uvm_config_db #(传输数据类型)::set(发送源地址, “相对于发送源的接收方地址”, “传输数据名称”, 传输数据内容); set:自顶向下set,如从top_tb向下driver设置参数,即在top_tb中进行set。 举个例子,我们要用uvm_config_db传输...
例程中,uvm_config_string的原型是uvm_config_db#(string),uvm_config_int的原型是uvm_config_db#(uvm_bitstream_t),这是UVM中为了简写通过typedef定义的类型。 仿真结果如下: 04 扩展:Config_db资源优先级 当不得已需要在环境中的多个地方,对相同数据对象,通过config_db进行配置的时候,就需要关心到这些资源的...
(1) UVM中用于在不同component之间共享资源的一种机制,即实现了资源共享(也可描述为在UVM验证平台间传递参数),又避免了全局变量的弊端. (2) umv_config_db是从uvm_resource_db派生而来,对uvm_resource_db的一些功能进行了扩展,主要体现在对资源的写入和读取上. 注1:具体应用如将virtual interface传递到环境中(...
1.3.uvm_resource_db 1.3.1.uvm_resource_db::set 1staticfunctionvoid set(inputstringscope,inputstringname,2T val,inputuvm_object accessor =null);34rsrc_t rsrc =new(name, scope);//uvm_resource#(T).new();5rsrc.write(val, accessor);//uvm_resource#(T).write();6rsrc.set();//uvm_resour...
对于uvm_config_db来说,在调用get()函数检索数据库的时候,get()函数传递的{cntxt,”.”, inst_name}会作为uvm_re_match()的str的实参,set()函数设置的{cntxt,”.”, inst_name}在经过uvm_glob_to_re()处理后作为uvm_re_match()的实参,这也就是为什么set()参数的inst_name支持正则格式,而get()参数...
uvm_config_db#(virtual my_if)::set(null, "uvm_test_top", "vif", input_if); 2. 收信(Get): 在`my_driver`或其他UVM组件中,他们在开始工作之前会通过`uvm_config_db#(...)::get(...)`来“收信” - 即查找并获取接口实例的地址。 // 在my_driver中 - 收信 virtual my_if vif; if ...
UVM:3.5.7 config_db 机制对通配符的支持,config_db::set时,第二个参数都是完整的路径。还可以用通配符*:之前:可以把前两个set合并为一个set:可以进一步简化为:不推荐使用通配符,容易产生交互问题。
API Explorer SDK中心 软件开发生产线 AI开发生产线 数据治理生产线 数字内容生产线 开发者Programs Huawe...
config机制是用来传递数据的 config机制在UVM验证平遥中都是成对出现的。如在某个case(派生自uvm_test)的build_phase中可以做如下设置: uvm_config_db#(int)::set(this,”env.agent.driver”,”pre_num_max”,100); 那么在driver的build_phase中要这样做: ...
config_db机制分为set和get两个操作,set和get一般都成对出现。 set函数范式 uvm_config_db #(传输数据类型)::set(发送源地址, “相对于发送源的接收方地址”, “传输数据名称”, 传输数据内容); set:自顶向下set,如从top_tb向下driver设置参数,即在top_tb中进行set。