设为首页
收藏本站
开启辅助访问
切换到窄版
登录
立即注册
首页
Portal
行业资讯
人才培育
求职招聘
智慧教育
人才之家
BBS
淘帖
Collection
分享
Share
搜索
搜索
行业资讯
集成电路
化合物IC
AI芯片
分立器件
新IC材料
行业政策
人才培育
政策法规
高等教育
职业教育
行业观察
行业指导
人才政策
热门领域
物联网IOT
人工智能
AI芯片
汽车电子
可穿戴电子
区块链
芯片制造
芯片杂谈
前端设计
MEMS
封装测试
版图设计
IC新材料
本版
文章
帖子
用户
芯片人才网
»
人才之家
›
芯片设计与制造
›
版图设计
›
版图ECO的那点事(中)
返回列表
发新帖
版图ECO的那点事(中)
[复制链接]
1389
|
0
|
2020-11-20 16:16:19
|
显示全部楼层
|
阅读模式
本帖最后由 Gaohanqing 于 2020-11-20 16:18 编辑
令人又爱又恨的ECO,它又回来了。
ECO版图实现的技巧和经验
在实际的ECO中,版图的实现是非常重要的步骤。是否能完成STA的脚本期望,是数据库能否走向收敛的关键点。一般的STA对应的ECO和相应的修复方法如下:
类别
问题描述
修复手段
实现方法
max_transition
max_capacitance
驱动不够
负载过大
input cap过大
绕线过长
增加驱动
打短绕线
负载分割
size_cell
add_buffer_on_route
split_fanout
setup violation
数据侧延迟过大
捕捉侧时钟过早
发射级时钟过晚
做快数据
做慢捕捉侧时钟
做快发射级时钟
size_cell
insert_buffer
add_buffer_on_route
hold violation
数据侧延迟过小
捕捉侧时钟过晚
发射级时钟过早
做慢数据
做快捕捉侧时钟
做慢发射级时钟
size_cell
insert_buffer
add_buffer_on_route
可以看到,ECO的物理实现就是两种情形
size_cell
add buffer
这里边最会产生的影响其实是面积和器件的位置变动(dis-placement)
通常的版图和ECO流程如下图,在sign-off阶段,理想的是以类似silicon-freeze的方式进行操作
ECO的简明流程如下:
这里的关键节点是在,placement/legalization,任何器件的位置变动带来的意外的影响都有可能导致ECO无法按照期望方向进行,这是因为,原有数据库的cell的放置被调整,之前的绕线需要做相应的调整,同时带来更多的timing/驱动能力的问题,这样就会给数据库带来不期望的抖动。
为了尽可能保证原有数据库的状态,这里需要引入一个新名词:
Minimal Physical Impact Flow(MPI)
为了实现MPI的效果,ICC给出了它的一套解决方案。
【敲黑板划重点】
较小的dis-placement带来更为稳定的版图数据,绕线的挑战也比较小,这个是MPI的核心思想
下边一起来看一下,如何使用合理的命令和流程来弱化legalization带来的影响:
传统的legalize命令在跑流程的时候,可以很好的进行增量性的legalization,但是到了ECO这里,legalize的动作相对于版图的稳定性而言,就是有点太大了,需要使用place_eco_cells来实现MPI:
从上边这个截图可以看出来,传统的legalize模式,带来的明显的average/max dis-placement,但是place_eco_cell可以非常好的避免这种情况的发生。place_eco_cell可以实现MPI的目标,而且run-time速度也很快,这到底是为什么呢?天底下还有这么既省时又省力的两全其美的好事情?
通常使用的legalize_placement -increment命令,它是一个全局命令,它会在需要legalize的cell就近找寻位置,如果找不到,那么就会push周围的cell,从而在ECO cell就近产生足够的空间,这样会产生明显的涟漪效应,尤其在高利用率的区域。但是place_eco_cell的行为完全不一样,它的操作范围完全是有用户决定的,它的目的就是一个:
在规定的范围内,完成目标cell的legalization,如果在规定的区域内(dis-placement threshold)找不到,它就直接放弃,较小的作用范围,带来的就是高速的执行速度。
这里有一个test-case,一个全局的的时序修复(size_cell),基于同样的改变,看看两个命令的表现:
CMD: legalize_placement -increment
可以看到,这里有30871个cell的位置被改变,ECO的cell其实只有7081个cell。可见大约有23K个cell的移动,是为了来给ECO cell腾挪空间的。
CMD: place_eco_cell -eco_changed -displacement_threshold 10 -max_displacement_threshold 10
仔细看图片描述,place_eco_cell的作用范围只有10um,目标cell也只有eco_changed的7081个cell,所以runtime极快。
在使用place_eco_cell之后,如何原始数据库的cell并没有被动到,只有ECO_changed cell 被动到,所以有一些没法完成legalize的cell,需要使用legalize_placement -increment 再次调整,保证整个数据库的legalization。
这里可以看到,使用legalize_placement -increment ,moved cell较之前会有所好转。
这样通过两步走的手段,可以有效地保证eco_changed的cell的legalization,也能最大限度地完成其他cell的原地不动。这里附带完整脚本流程图如下:
本帖子中包含更多资源
您需要
登录
才可以下载或查看,没有帐号?
立即注册
x
回复
使用道具
举报
返回列表
发新帖
高级模式
B
Color
Image
Link
Quote
Code
Smilies
您需要登录后才可以回帖
登录
|
立即注册
本版积分规则
发表回复
回帖后跳转到最后一页
Gaohanqing
356
主题
356
帖子
1318
积分
超级版主
积分
1318
加好友
发消息
回复楼主
返回列表
芯片杂谈
FPGA|ASIC|IC前端设计论坛
集成电路生产/封装/工艺
MEMS(微机电系统)
封装设计
半导体新材料
EDA设计
版图设计
其他