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

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

 

轻轻走过,悄悄看过,无意瞥一眼惊鸿的颜色,随着巷口的老猫湮没在无声中,爱这巷,爱这楼阁,爱这轻缓的脚步,落在石板上的踢踏,喜欢看你的身影随我远去,目光牵着你的笑,飞洒的柳絮勾勒你的轮廓,在茫茫烟波中,你留下残红染了梅花,在渺渺云雾中。

理论

这里需要给工具指定时序/SI分析的多模多角MMMC环境。建议最好按照工具MMMC Objects里面的顺序从上至下进行配置,因为后边的配置会用到前面配置的内容。

工具推荐的配置顺序如下:

- 时序、SI分析用的lib/cdb库文件(library set)

- 寄生参数提取的RC Corners

- 工作条件(Operating conditions)

- Delay corners

- 添加Constraint Mode,读入sdc

- 创建MMMC的analysis views,并指定哪些View是用于Setup分析/优化的,哪些是用于Hold分析/优化的。

它们之间(Analysis View、library set、RC Corner、op condition、Delay Corner、Constraint Mode)的关系如下图所示,详细内容留待下次讲解。这里只简单介绍下推荐的配置顺序及Lab中的配置方法。

实践

在Analysis Configuration下方点击“Create Analysis Configuration”弹出MMMC Browser窗口,如下图所示:

Lab中已经给出了现成的MMMC配置文件(dtmf.view),简单起见可以直接指定这个文件,即可以点击“MMMC View Definition File”后边的按钮来导入。

对于一个新的Design而言,是没有该文件的,需要自己去编写该文件或者在GUI里面进行相应的设置。具体每项内容的含义以及指定方法在后续推文中会介绍。 

命令和脚本

set init_mmmc_file {./dtmf.view}

dtmf.view文件内容及各项内容的注释如下(也可以直接在Innovus中输入各项配置命令):

#创建用于对标准单元以及Macro进行时序分析和SI分析的lib/cdb库(library set),根据时序分析的PVT环境,需要将所有用到的PVT Corner的库都读进来,根据PVT环境的不同将它们分组。65 nm以前最常用的就是BCWC的STA模式,以这种模式为例,需要创建setup分析用的slow lib set,创建hold分析用的fast lib set:

create_library_set -name dtmf_libs_min \

-timing {../lib/pllclk_fast.lib \

../lib/ram_128x16A_fast_syn.lib \

../lib/rom_512x16A_fast_syn.lib \

../lib/ram_256x16A_fast_syn.lib \

../lib/fast.lib \

../lib/tpz973gbc-lite_fast.lib} \

-si {../CDB/fast.cdb}

create_library_set -name dtmf_libs_max \

-timing {../lib/pllclk_slow.lib \

../lib/ram_128x16A_slow_syn.lib \

../lib/ram_256x16A_slow_syn.lib \

../lib/rom_512x16A_slow_syn.lib \

../lib/slow.lib \

../lib/tpz973gwc-lite_slow.lib} \

-si {../CDB/slow.cdb}

#前面创建的lib set指定了对标准单元和Macro进行STA的PVT信息,这里创建RC Corner来为提取Net的寄生电阻电容指定电阻、电容查找表(从而得到Net的Delay信息),根据Stage的不同选用不同的查找表文件(.capTbl和.tch):

create_rc_corner -name dtmf_rc_corner \

-cap_table {../captable/t018s6mlv.capTbl} \

-preRoute_res {1.0} \

-preRoute_cap {1.0} \

-preRoute_clkres {0.0} \

-preRoute_clkcap {0.0} \

-postRoute_res {1.0} \

-postRoute_cap {1.0} \

-postRoute_xcap {1.0} \

-postRoute_clkres {0.0} \

-postRoute_clkcap {0.0} \

-qx_tech_file {../QRC/t018s6mm.tch}

#创建Delay Corner,它是library set和RC Corner等的组合(此Lab中没有设置power domain和op condition的信息,因此就这两项内容的组合):

create_delay_corner -name dtmf_corner_min \

-library_set {dtmf_libs_min} \

-rc_corner {dtmf_rc_corner}

create_delay_corner -name dtmf_corner_max \

-library_set {dtmf_libs_max} \

-rc_corner {dtmf_rc_corner}

#创建Constrain Mode,读入时序约束文件(.sdc)

create_constraint_mode -name common \

-sdc_files {dtmf.sdc}

#创建Setup分析和Hold分析的Analysis View,它是Constrain Mode和Delay Corner的组合:

create_analysis_view -name dtmf_view_hold \

-constraint_mode {common} \

-delay_corner {dtmf_corner_min}

create_analysis_view -name dtmf_view_setup \

-constraint_mode {common} \

-delay_corner {dtmf_corner_max}

#指定进行Setup/Hold分析和优化的Analysis View:

set_analysis_view -setup {dtmf_view_setup} \

-hold {dtmf_view_hold}

相关推文

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

Innovus教程 - Flow系列 - 导入设计(理论+实践+命令)

Innovus教程 - Flow系列 - 导入网表 指定工艺/物理库(理论+实践+命令)

Innovus教程 - Flow系列 - 管脚排列文件的编写与指定(理论+实践+命令)

Innovus教程 - 应用系列 - CPF应用实例

Innovus教程 - Flow系列 - 指定PG Net和CPF文件(理论+实践+命令)

 

网易云课堂视频课程

新课上线

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

Linux操作系统视频教程(中高级)

主要面向集成电路设计

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

##  建了一个QQ群  ##

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

## 加群请备注:EDA  ##

##  群二维码如下  ##

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

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

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

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

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

#       ASIC的全称       #

Innovus教程 - Flow系列 - MMMC分析环境的配置概述(理论+实践+命令)的更多相关文章

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

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

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

    本文转自:自己的微信公众号<集成电路设计及EDA教程> <ICC教程 - Flow系列 - 概念系列 - ECO (理论+实践+脚本分享)> 这篇推文讲一下数字IC设计中的po ...

  3. 《Visual C++ 2010入门教程》系列二:安装、配置和首次使用VS2010

    作者:董波 日期:2010.6.15 写在前面 在我还在上学的时候,我选择了C++,最初我用VC6作为我的IDE,我看过很多本C++的教材,有的适合我,有的不适合我,其中有一本叫<Visual ...

  4. 【Win10+eclipse+MinGW+QT安装教程】已有eclipse环境下配置QT插件出错详解

    (纪念一下装了一整天濒临绝望的自己[/doge]) (以下所有下载项一律使用32位) step1:下载安装eclipse.适配的jdk.MinGW和QT 1.下载32位eclipse for c++以 ...

  5. RabbitMQ使用教程(一)RabbitMQ环境安装配置及Hello World示例

    你是否听说过或者使用过队列? 你是否听说过或者使用过消息队列? 你是否听说过或者使用过RabbitMQ? 提到这几个词,用过的人,也许觉得很简单,没用过的人,也许觉得很复杂,至少在我没使用消息队列之前 ...

  6. [nRF51822 AK II 教程]第一课,开发环境的配置及背景介绍【转】

    低功耗蓝牙4.0是全新的技术,并不向下兼容,也就是说它和蓝牙3.0.2.0什么的都不能通信的.另外,蓝牙4.0目前的规范只能做外设和主机(智能手机,电脑等)通讯,也就是说你想用一个单模的蓝牙4.0开发 ...

  7. linux 中环境变量配置错误导致部分命令不能使用包括vi

    1,使用 /bin/vi  /etc/profile 可以打开环境变量 2,修改正确后,重启

  8. Shell脚本开发环境的配置和优化实践

    1. 配置vim编辑器 1-1. 为什么不使用vi而是vim vi适合编辑普通文本,不适用编写脚本代码,例如:缺少高亮显示代码.自动缩进等重要功能: vim相当于高级编辑器,可以提高开发效率. 1-2 ...

  9. SSO单点登录系列3:cas-server端配置认证方式实践(数据源+自定义java类认证)

    落雨 cas 单点登录 本篇将讲解cas-server端的认证方式 1.最简单的认证,用户名和密码一致就登录成功 2.配置Oracle的jdbc数据源,通过spring动态查询数据库 3.配置orac ...

随机推荐

  1. Servlet的基础知识

    没有什么固定的结构, 就是稍微总结一下学习到的, 基本上想到哪里写到哪里. 关于基本的最HttpServlet 实际上Servlet是J2EE(也就是现在的Java EE)中规范的一个接口, 用于根据 ...

  2. Delphi 接口使用中,对象生命周期管理,如何释放需要注意的问题

    网上有篇文章<Delphi接口编程的两大陷阱>,里面提到接口的生存期管理的问题.但该文章里面提到的两个问题,其实都是对 Delphi 不理解导致的.   先说该篇文章中提到的第一个问题为什 ...

  3. GIS基础软件及操作(二)

    原文 GIS基础软件及操作(二) 练习二.管理地理空间数据库 1.利用ArcCatalog 管理地理空间数据库 2.在ArcMap中编辑属性数据 第1步 启动 ArcCatalog 打开一个地理数据库 ...

  4. WPF修改窗体标题栏的颜色

    WPF程序通常情况下没办法修改窗体标题栏的样式,包括标题栏的背景颜色. 不过借助一个叫Fluent.Ribbon的第三方控件,貌似可以修改标题栏的背景颜色. 可以通过NuGet来安装这个控件:Inst ...

  5. 『SHELL』--SHELL脚本执行方式(转)

    Shell脚本的执行方式: 注明:wd代表“脚本保存的目录” 1.fork 语法:/wd/shell.sh fork是最普通的, 就是直接在脚本里面用/wd/shell.sh来调用shell.sh这个 ...

  6. delphi 获取当前进程的cpu占用率

    type  TProcessCpuUsage = record  private    FLastUsed, FLastTime: Int64;    FCpuCount:Integer;  publ ...

  7. SYN012型B码时统

       SYN012型B码时统 产品概述 SYN012型B码时统是由西安同步电子科技有限公司精心设计.自行研发生产的一款通用性时统终端,内置高精度恒温晶振,接收GPS北斗双模卫星信号,10MHz外部参考 ...

  8. JAVA8之lambda表达式详解

    原文:http://blog.csdn.net/jinzhencs/article/details/50748202 lambda表达式详解 一.问题 1.什么是lambda表达式? 2.lambda ...

  9. Zookeeper详解-概述(一)

    ZooKeeper是一种分布式协调服务,用于管理大型主机.在分布式环境中协调和管理服务是一个复杂的过程.ZooKeeper通过其简单的架构和API解决了这个问题.ZooKeeper允许开发人员专注于核 ...

  10. web页面的时间传入servlet如何转换为可以存入MySQL的Date类型

    在web页面中当使用如下语句: <input type="date" name="startTime"/> 提交到servlet中 在servlet ...