如何迭代多维Systemverilog uvm_queue中的项目
我正在尝试创建一个由 uvm_queue 数组构造的对象。这个想法是数组中的每个项目本身就是一个 uvm_queue (即项目列表)。队列类型是一个类。
问题是我无法迭代单个“内存 ID”列表的项目。
当我编译时,出现以下错误:
if (ml_mem_array[mem_id][ii].m_addr == a_addr)
xmelab: *E,CUVNAA (./utils.sv,47|45): 索引已应用于不适当的位置类型。
代码如下所示:
// ====================
class mem_entry extends uvm_object;
int m_addr;
int m_data;
endclass
// ====================
class memory extends uvm_object;
uvm_queue#(mem_entry) ml_mem_array[2];
function mem_entry get_mem_entry(int a_addr, int mem_id);
int v_size;
int ii;
v_size = ml_mem_array[mem_id].size();
if ((mem_id >= 2) || (v_size == 0))
return null;
for (ii=0 ; ii<=(v_size-1) ; ii=ii+1)
begin
if (ml_mem_array[mem_id][ii].m_addr == a_addr)
return ml_mem_array[mem_id][ii];
end
return null;
endfunction
endclass
I’m trying to create an object which is constructed from array of uvm_queue. The idea is that each item in the array is for itself a uvm_queue ( i.e. a list of items). The Queue type is a class.
The problem is I can’t manage to iterate the items of a single ‘memory ID’ list.
When I compile I get the following Error:
if (ml_mem_array[mem_id][ii].m_addr == a_addr)
xmelab: *E,CUVNAA (./utils.sv,47|45): An index has been applied to an inappropriate type.
The code looks like this:
// ====================
class mem_entry extends uvm_object;
int m_addr;
int m_data;
endclass
// ====================
class memory extends uvm_object;
uvm_queue#(mem_entry) ml_mem_array[2];
function mem_entry get_mem_entry(int a_addr, int mem_id);
int v_size;
int ii;
v_size = ml_mem_array[mem_id].size();
if ((mem_id >= 2) || (v_size == 0))
return null;
for (ii=0 ; ii<=(v_size-1) ; ii=ii+1)
begin
if (ml_mem_array[mem_id][ii].m_addr == a_addr)
return ml_mem_array[mem_id][ii];
end
return null;
endfunction
endclass
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
您需要使用
uvm_queue
的get()
方法来访问内部队列元素You need to use the
get()
method ofuvm_queue
to access the internal queue elements