本文转自:自己的微信公众号《集成电路设计及EDA教程》

《ICC教程 - Flow系列 - 概念系列 - ECO (理论+实践+脚本分享)》

这篇推文讲一下数字IC设计中的post mask ECO和premask ECO,并讲解一下在ICC中Apply ECO的流程。

理论:

ECO分为post mask ECO和premask ECO,也就是只修改metal layer的ECO和任何layer都可以动到的ECO。

Post mask ECO:

Post mask ECO是利用预先留好的备用单元(Spare Cell),做的逻辑修改。如果后期发现Timing存在问题(或者想小动Function),可以利用附近的Spare Cell搭配上层金属连线来修改电路结构。这种ECO受限于Spare Cell的位置,如果附近找不到的话,就比较麻烦了,所以它的修改规模十分有限。

Spare cell:

Foundry提供一种服务,允许客户在wafer加工到poly以及M1层的时候,让大部分wafer暂时停止加工,而少量wafer继续加工直至完成。之后可以对这些完成了的wafer上的die进行测试,如果发现存在功能或者时序上的问题,那么可以通过利用那些预布在die上的spare cell来解决。由于绝大部分的金属层都没有加工,因此在不修改标准单元布局的情况下(也就是不用改动M1以及poly、NW、SP、SN等这些base层的mask,在流片过程中这些层的光刻也是最贵的),只用改动几层金属的mask并利用spare cell去修复这些问题。如此一来,也大大降低了流片的风险,试想,如果直接让所有的wafer都加工完成,测试后发现存在bug,那么几百万刀的流片费用变付之东流,这个还不是最重要的,最重要的是产品上市时间delay了。而Post mask ECO则提供了一种根据silicon测试结果进行Debug的方法。

Premask ECO:

Premask ECO比post mask的要灵活得多。在tapeout之前,如果发现有任何需要修改的地方,都可以用这种方法。它可以改几百个,甚至上千个单元。该操作主要是针对静态时序分析和后仿真中出现的问题,对电路的网表直接进行修改,待网表修改完毕之后反馈到PR工具中对标准单元的布局和连线进行小范围的改动。当然,直接对网表进行修改是存在风险的,所以之后一定要进行形式验证(formal verification)。

ECO修改组合逻辑比较容易,如果动到FF的话,要格外小心,因为它有可能影响clock tree,进而造成大量的时序违反。

流程、实践与脚本分享:

下面以ICC中用ECO的方法修hold违反为例简单讲解ICC中进行premask的ECO方法。

首先在PT中用以下命令修hold:

>fix_eco_timing -hold

之后通过下面的命令来导出PT对网表做出的改动,格式为ICC的tcl脚本格式。

>write_changes -format icctcl -output eco_fix_hold.tcl

接着便可以开始ICC中的ECO流程了,先在ICC中加载PT导出的tcl文件来更改ICC中的网表。

>eco_netlist -by_tcl_file eco_fix_hold.tcl

接着便是在版图中放置那些网表中新加入的Cell,如果设计中之前已经加过Core Filler了,需要执行下面的命令:

>place_eco_cells -eco_changed_cells \

-legalize_only \

-remove_filler_references "$FILLER_CELL_METAL $FILLER_CELL"

如果之前还没有加入Core Filler,那么只需要执行下面的命令即可:

>place_eco_cells -eco_changed_cells -legalize_only

放置完新加入的Cell之后还需要对设计重新插入Core Filler,即先插入带金属的Filler,再插入那些不带金属的Filler。

之后进行电源地的逻辑连接,

# Connect PG nets

> derive_pg_connection \

-power_net {VDD} -power_pin {VDD} \

-ground_net {VSS}  -ground_pin {VSS}

> derive_pg_connection -power_net {VDD} \

-ground_net {VSS} -tie

其中,legalize_placement可以使用check_legality -verbose查看是否有不合法的标准单元布局。由于此时的布线只是少量改动,因此完全可以禁用时序驱动以减少运行时间。

## 然后进行ECO route

>set_route_zrt_global_options -crosstalk_driven false \

-timing_driven false

>set_route_zrt_track_options-crosstalk_driven false \

-timing_driven false

>set_route_zrt -detail_options -timing_driven false

>route_zrt_eco -reroute modified_nets_first_then_others

执行ECO后如果有DRC问题,可以紧接着执行route_zrt_detail,这可以修复绝大部分DRC。

>route_zrt_detail -incremental true \

-max number iterations 20

如果ECO改动比较小,可以用一个包含网表编辑命令组成的Tcl文件以及eco_netlist -by_tcl_file命令来更新整个设计。如果使用的是freeze silicon的ECO flow,则必须在该命令后边加上-freeze_silicon选项。当然也可以直接在命令行中输入这些网表编辑命令,或者直接source该Tcl文件。

无约束ECO flow中的网表编辑命令有:

下篇推文讲解一下在PT中进行ECO的方法并分享一下脚本。

更多资料欢迎移步微信公众号《数字集成电路设计及EDA教程》

网易云课堂视频课程

链接:https://study.163.com/course/introduction/1005909004.htm

Calibredrv教程-提高流程自动化

##  为了方便大家交流讨论  ##

##  建了一个QQ群  ##

## 集成电路设计及EDA教程  ##

## 加群请备注:EDA  ##

##  群二维码如下  ##

# 本公众号有个红包和资料福利微信群  #

#  集成电路设计及EDA教程福利群  #

#  为了避免乱七八糟的人加进来  #

#  可以先加我微信,我拉你进群  #

#  加我微信 请备注下面问题的答案  #

#       ASIC的全称       #

ICC教程 - Flow系列 - 概念系列 - ECO (理论+实践+脚本分享)的更多相关文章

  1. PT教程 - 应用系列 - ECO修复Timing(理论+实践+脚本分享)

    ​本文转自:自己的微信公众号<集成电路设计及EDA教程> <PT教程 - 应用系列 - ECO修复Timing(理论+实践+脚本分享)> 这篇推文讲一下数字IC设计中的post ...

  2. Innovus教程 - Flow系列 - MMMC分析环境的配置概述(理论+实践+命令)

    本文转自:自己的微信公众号<集成电路设计及EDA教程> <Innovus教程 - Flow系列 - MMMC分析环境的配置概述(理论+实践+命令)>   轻轻走过,悄悄看过,无 ...

  3. Innovus Lab和Lab Guide下载地址 | Innovus教程 - Flow系列 - 数据准备

    本文转自:自己的微信公众号<集成电路设计及EDA教程> <Innovus Lab和Lab Guide下载地址 |    Innovus教程 - Flow系列 - 数据准备>   ...

  4. Linux Shell系列教程之(二)第一个Shell脚本

    本文是Linux Shell系列教程的第(二)篇,更多shell教程请看:Linux Shell系列教程 通过上一篇教程的学习,相信大家已经能够对shell建立起一个大体的印象了,接下来,我们通过一个 ...

  5. Fiddler系列教程3:使用Fiddler录制Jmeter性能测试脚本

    今天继续给大家带来Fiddler工具的教程3:使用Fiddler录制Jmter性能测试脚本. 我们知道Jmeter本身可以录制脚本,也可以通过BadBoy,BlazeMeter等工具进行录制,其实Fi ...

  6. 使用U盘的PE系统安装Windows10操作系统 - 初学者系列 - 学习者系列文章

    今天闲来无事,就把windows 10的安装再重写一个文(以前写过一个:安装免费的正版Windows10操作系统 - 初学者系列 - 学习者系列文章  ). 1.  制作一个WinPE的U盘. 相信现 ...

  7. 安装Windows11操作系统(不需要绕过TPM检测脚本等) - 初学者系列 - 学习者系列文章

    Windows11操作系统是去年微软公司的最新力作.对于该操作系统的安装,网上有很多的教程了.这次主要写的是不需要绕过TPM检测操作安装Windows11操作系统. 1.        制作启动U盘: ...

  8. jQuery插件库代码分享 - 进阶者系列 - 学习者系列文章

    这些天将原来在网上找的jQuery插件进行了下整理,特此将代码分享出来给大家. 见下图结构. 对目录结构进行了分类.这里是插件列表. 这里总共收集了20来个插件.还有下面未进行划分的. 下面是DEMO ...

  9. Android自己定义组件系列【7】——进阶实践(4)

    上一篇<Android自己定义组件系列[6]--进阶实践(3)>中补充了关于Android中事件分发的过程知识.这一篇我们接着来分析任老师的<可下拉的PinnedHeaderExpa ...

随机推荐

  1. $bzoj2067\ szn$ 二分+贪心

    正解:二分+贪心 解题报告: 传送门$QwQ$ 题目大意就说有一棵树,然后要用若干条线覆盖所有边且不能重叠.问最少要用几条线,在用线最少的前提下最长的线最短是多长. 昂首先最少用多少条线这个还是蛮$e ...

  2. 洛谷$P5444\ [APIO2019]$奇怪装置 数论

    正解:数论 解题报告: 传送门$QwQ$ 我好像当初考的时候这题爆零了,,,部分分都没想到,,,我真的好菜$kk$ 考虑如果在$t_1,t_2$两个时刻有$x_1=x_2,y_1=y_2$是什么情况$ ...

  3. MicroPython TPYBoard v702实现HTTP应用功能

    [Micropython]TPYBoard v702 HTTP应用功能 转载请注明文章来源,更多教程可自助参考docs.tpyboard.com,QQ技术交流群:157816561,公众号:Micro ...

  4. Intellij Idea插件使用记录之Alibaba Java Coding Guidelines

    目录 Intellij Idea插件Alibaba Java Coding Guidelines 前言 使用 感谢 Intellij Idea插件Alibaba Java Coding Guideli ...

  5. SCU 4438 Censor|KMP变形题

    传送门 Censor frog is now a editor to censor so-called sensitive words (敏感词). She has a long text P. He ...

  6. 到底如何配置 maven 编译插件的 JDK 版本

    千言万语不及官方文档,详情请阅读 compiler:compile 文档 配置 maven 编译插件的 JDK 版本 maven 编译插件(maven-compiler-plugin)有默认编译 JD ...

  7. 从源码角度来看BeanFactory和ApplicationContext的关系

    大家好,我是小黑,这是年前的最后一篇推文,提前祝大家新年快乐~~ 这次我们从源码角度来聊聊BeanFactory和ApplicationContext的关系,讲一些网上文章不曾提到的点. 官方描述 先 ...

  8. infer 代码静态分析

    infer 代码静态分析 静态代码分析工具,主要是为了提高我们的代码质量. 通常,我们提高代码质量的方式是通过CodeReview,但是这个过程耗费的人工和时间往往较大.并且随着代码量的增加人肉检测起 ...

  9. <s:select>自动加标签

    在使用<s:select>标签时,发现页面位置不对,查看页面源码发现 <tr> <td class="tdLabel"></td> ...

  10. C# 二分法的解读

    注:一定是有序的数组,才可以使用这种算法,如果数组没有排序则先进行排序后再调用此方法. 1.二分法是做什么的呢? 当然是查找数组中的数据了,开个玩笑,哈哈哈. 2.为啥要用这种方式呢? 二分顾名思义, ...