[英]Creating an array of structs with macro in Systemverilog
我创建了一个带有(两个)输入和两个输出的模块(示例)。 每个输入和输出的定义都通过一个宏传递。
是否可以将其创建得更加优雅(可用性更高)? 有点像输入和输出数组(NAME(i),in(i),out(i))?
这将是有帮助的,因为稍后我会使用更多的out和输入,并且有可能使用稍后的循环来更优雅地访问in /输出。
最佳:
`include "macro.sv"
module top (in_0, in_1, out_0, out_1);
`STRUCT_i(in_0_temp, 10);
`STRUCT_i(in_1_temp, 22);
`STRUCT_i(out_0_temp, 55);
`STRUCT_i(out_1_temp, 99);
input `STRUCT(in_0_temp) in_0;
input `STRUCT(in_1_temp) in_1;
output `STRUCT(out_0_temp) out_0;
output `STRUCT(out_1_temp) out_1;
...
endmodule
Macro.sv:
`define STRUCT(NAME) \
struct_i_``NAME``
`define STRUCT_i(NAME, DATA) \
typedef struct packed { \
logic [DATA:0] info; \
logic test1; \
logic test2; \
} `STRUCT(NAME)
无法对数组执行此操作,因为根据定义,数组是统一类型变量的集合。 具有动态索引值的访问要求每个元素具有相同的布局。 即使使用不同长度的简单位向量也无法使用。 您唯一可综合的选项是声明info
的最大大小,并希望将未使用的位进行优化。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.