使用sv语言,clk_data是一个33位的变量, for(int i = 0; i < 16; i++) begin clk_data[2i+1 : 2i] = {tx_link_code_word[i], clock[i]}; end 报错Error-[IRIPS] Illegal range in part select /home/Common/User/kirby/hs5411/trunk/verif/common/flp_if_uvc/tb/flp_if_item.sv, 193 The range of the part select is illegal: Unknown range in part select.this.clk_data
时间: 2024-02-12 21:06:28 浏览: 170
根据你提供的代码,你在对一个33位的变量clk_data进行部分位赋值。具体来说,你想把tx_link_code_word数组和clock数组中的元素交替地赋值给clk_data的奇数位和偶数位。但是,在你的代码中,你使用了未知的范围来进行部分位赋值,导致编译器报错。
为了解决这个问题,你需要明确指定每个部分位的范围。具体来说,你可以使用类似于下面的语句:
```
clk_data[2*i+1 : 2*i] = {tx_link_code_word[i], clock[i]};
```
在这个语句中,你使用变量i来计算每个部分位的范围,并且使用大括号{}来将tx_link_code_word[i]和clock[i]组合成一个2位的值,然后将这个值赋值给clk_data的相应部分位。
阅读全文