在线咨询
eetop公众号 创芯大讲堂 创芯人才网
切换到宽版

EETOP 创芯网论坛 (原名:电子顶级开发网)

手机号码,快捷登录

手机号码,快捷登录

找回密码

  登录   注册  

快捷导航
搜帖子
查看: 2676|回复: 0

[原创] verilog hdl 向量使用变量进行索引

[复制链接]
发表于 2015-9-28 10:46:37 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?注册

x
module    id(
    ......
);

    reg[`InstWidth]                cur_inst;                        //48字节的指令存放空间,后面的分析根据
    reg[`InstBus]                    cur_pos;                        //cur_inst[cur_pos: 0]
     
    ........
     
     
    always    @ (*)    begin     
                        
            //----------------------------------------------------
            区域1:
            
            //将本次获得的指令赋给 cur_inst
            cur_inst[cur_pos  : ((cur_pos + 1) - `Num32)]    = inst_i[`InstBus];
            
            ** Error: C:/id.v(89): Range must be bounded by constant expressions.
            
            注:
            `define    InstWidth                            383:0
            `define    Num32                                    32
            `define    InstBus                                31:0
            
            问题1:
            
            按照错误提示,应该是 cur_inst[a:b]内的表达式 a、b 都应该为常量表达式,是这样吗?
            如果是的话,那假设我需要使用变量,该如何修改?
            详细一点的说,我的意图是,cur_inst[]是48字节大小的,每次对它增加的内容是不定长的,
            因此每次的起始位置也是不定的,例如:
            1)第一次,    cur_pos: 383,即cur_inst[]的最高位。如果这次需要填充的内容为4字节,
                                    即inst_i[31:0],则 cur_pos 会变更为 383 + 1 -32 = 352
            2)第二次,    cur_pos: 352, 如果这次需要填充的内容为2字节,即inst_i[15:0],
                                    则 cur_pos 会变更为 352 + 1 -16 = 336
            ......
            
            可见,cur_inst[]所填充内容的位置由 cur_pos 决定。这是动态的,不可能是常量表达式。
            那如何解决?
            
            注:
            本例中的inst_i[`InstBus]虽然是固定4字节的填充内容,但实际在程序中还是有2字节
            的填充,且编译时也已报错(错误提示的内容跟这里的一样),只是篇幅所限没有列出
            
            //----------------------------------------------------
            
    end
     
     
    ......

endmodule
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

站长推荐 上一条 /1 下一条

X

小黑屋| 手机版| 关于我们| 联系我们| 隐私声明| EETOP 创芯网
( 京ICP备:10050787号 京公网安备:11010502037710 )

GMT+8, 2025-6-29 04:58 , Processed in 0.017001 second(s), 11 queries , Gzip On, MemCached On.

eetop公众号 创芯大讲堂 创芯人才网
快速回复 返回顶部 返回列表