typedef struct {
Vector#(4, INDEX) index;
Vector#(2, TAG1) comp_tag1_table;
Vector#(2, TAG2) comp_tag2_table;
} Prediction_Packet deriving(Bits, Eq, FShow);Prediction_Packet pred_pkt <- mkReg(unpack(0)); 在上面的BSV代码中,我需要给comp_tag1_table (有2个TAG1数据类型的条目)和comp_tag2_table (有2个TAG2数据类型的条目)赋值。
我试过using...something,就像...pred_pkt.comp_tag1_table[ti] <= 8'b101,其中ti可以是0或1,但这似乎不能解决问题。我猜它不可能是一个数组。
发布于 2020-07-30 20:25:58
如果pred_pkt.comp_tag1_table[ti] = 8'b0101;是一个变量,则可以使用它。当然,它是一个变量。
<=用于为寄存器赋值的情况。
发布于 2021-04-02 03:51:34
BSV不支持更新寄存器的字段或元素。如果pred_pkt是一个寄存器,那么您可以这样做:
let new_pred_pkt = pred_pkt;
new_pred_pkt.comp_tag1_table[ti] = 8'b101;
pred_pkg <= new_pred_pkt;https://stackoverflow.com/questions/60360024
复制相似问题