多级选择与按位或综合时的区别

在进行电路设计的过程中,遇到了高达1024位宽的数据处理,此时需要着重注意时序。大佬指出,上面红框的处理(按位或),时序不会有大问题。下面红框的选择器级数不要超过16级(时钟频率312.5MHz)。遂产生疑问:既然FPGA会综合成查找表,那么LUT相当于只是一个存储单元,两种操作输入数量都一样,为什么逻辑功能不一样会造成综合结果不一样,且多级选择器的限制如此严格。

思考了一上午,陷入一个误区:只要输入数量一致,那么无论逻辑功能如何,反正是IDE计算出结果存在LUT中,综合结果没区别。

最后把两种实现综合了一下观察区别:

下面的多级选择电路中,每级只能有1个查找表,因为判断存在先后关系,后面的判断需要用到前面的判断结果。如果像上面红框那样设计,会有如下问题:第一级中,第二个LUT无法预知第一个LUT的结果,IDE无法计算第二个LUT的结果,只能将其放在后一级,等第一级算完才知道结果。

所以对于无先后依赖关系的操作,查找表级数只要 din_num关于6开次方即可。

而对于有先后依赖关系的操作,查找表级数为(din_num-6)/5+1.

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值