1.实际工作中,除了描述仿真测试激励时使用for循环语句外,极少在RTL级编码中使用for循环
这是因为for循环会被综合器展开为所有变量情况的执行语句,每个变量独立占用寄存器资源,不能有效的复用硬件逻辑资源,造成巨大的浪费。一般常用case语句代替。
2. if…else…和case在嵌套描述时是有很大区别的
if…else…是有优先级的,一般来说,第一个if的优先级最高,最后一个else的优先级最低。而case语句是平行语句,它是没有优先级的,而建立优先级结构需要耗费大量的逻辑资源,所以能用case的地方就不要用if…else…语句。
补充:1.也可以用if…; if…; if…;描述不带优先级的“平行”语句。
本文探讨了RTL级设计中for循环的资源浪费问题,推荐使用case语句替代;并解析了if...else...与case语句在嵌套描述时的区别,强调了case语句在优先级结构构建上的优势。
171万+

被折叠的 条评论
为什么被折叠?



