DC学习(综合与优化)

本文详细介绍了DC(Design Compiler)工具在综合过程中采用的综合策略,包括top-down和bottom-up方法,以及结构级、逻辑级和门级的优化阶段。在优化阶段,重点讨论了结构级优化如何选择合适的加法器,逻辑级优化如何选择最佳逻辑表达式,以及门级优化如何进行路径优化。此外,还提到了时序违规的处理方法,如compile_ultra命令、逻辑复制和寄存器优化等策略,以满足设计时间和面积的要求。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、综合策略
(1)top-down:层次化结构,只对顶层设计进行全面约束,针对个别模块有特殊约束;比如管理模块(clock模块,reset模块等)的综合不会与工作模块(顶层模块)放在一起综合的
(2)bottom-up:对底层的各个模块定为current_design,进行综合,加上dont touch属性;若各层之间有group logic(如与门),还需要对group logic约束;这种风格的综合约束复杂且多

2、三个阶段的优化
在这里插入图片描述
第一阶段的结构级的优化(Architectural-Level Optimization)
第二阶段的逻辑级优化(Logic-Level Optimization)
最后阶段的门级优化(Gate-Level Optimization)

(1)结构级优化(architectural-level)
在这里插入图片描述包括:设计结构的优化,数据通路的优化,共享共同的子表达式,资源共享,重新排序运算符号
例如:加法器有普通加法器,超前进位加法器,DC会根据应用场合挑选出合适的加法器

(2)逻辑级优化(logic-level)
一个逻辑表达式可以是与非格式,也可以是或非格式,DC会选择合适的逻辑表达式来描述逻辑功能
在这里插入图片描述
(3)门级优化(Gate-level)
得到网表后的优化,局部优化。网表文件生成后,静态时序分析时,DC工具对路径进行分析,对关键路径进行优化,逻辑级优化与门级优化可以迭代使用(若路径延时过大,不满足设计规则,DC会resynthesis,一直到路径延迟满足要求)。

常见的算术优化方法:
在这里插入图片描述
逻辑复制(logic duplication):
在这里插入图片描述
对关键路径部分的负载放在其他路径上,减少关键路径延时,以面积换速度

DC综合之后,我们查看详细的报告,如果没有违规,设计既能满足时间和面积的要求又不违犯设计规则,那么综合完成。可以把门级网表和设计约束等交给后端(backend)工具做布局(placement )、时钟树综合(clock tree synthesis)和布线(route)等工作,产生GDSII文件。如果设计不能满足时间和面积的要求或违犯设计规则等,就要分析问题所在,判断问题的大小,然后采取适当的措施解决问题。问题往往是时序的问题,发生时序违规时可以采取相应的措施,如下图所示:
在这里插入图片描述
(1)当违规得比较严重时,也就是时序的违规(timing violation)在时钟周期的25%以上时,就需要重新修改RTL代码了
(2)时序违规在25%以下,有下面的时序优化方法:

  • 使用compile_ultra命令(在拓扑模式下运行)
    compile_ultra跟compile一样,是进行编译的命令。com
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值