如何迭代多维Systemverilog uvm_queue中的项目

发布于 2025-01-09 12:45:04 字数 928 浏览 0 评论 0原文

我正在尝试创建一个由 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 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

顾铮苏瑾 2025-01-16 12:45:04

您需要使用uvm_queueget()方法来访问内部队列元素

 for (int ii=0 ; ii<=(v_size-1) ; ii=ii+1)
    begin
       mem_entry entry = ml_mem_array[mem_id].get(ii);
       if (entry.m_addr == a_addr)
         return entry;
    end

You need to use the get() method of uvm_queue to access the internal queue elements

 for (int ii=0 ; ii<=(v_size-1) ; ii=ii+1)
    begin
       mem_entry entry = ml_mem_array[mem_id].get(ii);
       if (entry.m_addr == a_addr)
         return entry;
    end
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文