数字集成电路物理设计[陈春章]——知识总结与精炼02

2024-05-15 20:12

本文主要是介绍数字集成电路物理设计[陈春章]——知识总结与精炼02,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

第二章 物理设计建库与验证

2.1 集成电路工艺与版图

自行了解,关于闩锁效应可查阅小编之前的文章。

2.2 设计规则检查(DRC)

定义:晶圆代工厂对各自不同工艺参数制定出满足芯片制造良率的同一工艺层及不同工艺层之间几何尺寸的最小值(图2-17),这些最小值规划的集合就是版图设计规则。

目的:DRC的主要目的是检查版图中所有因违反设计规则而引起潜在断路、短路或不良效应的物理验证过程。

2.3 电路规则检查

目的:验让版图与电路原理图的电路结构是否一致

检查内容:①所有信号的电气连接关系是否一致;②器件类型、尺寸是否一致

过程:抽取+比较

常用解决办法:(1)检查器件数目 (2)检查器件类型 (3)  检查电源线和地线的连接 (4)检查节点数量  (5)从关键的找起

2.4 版图寄生参数提取与设计仿真

1.寄生参数

(1)寄生电容

解决方法:导线尽可能短;采用电容最低的电容层;绕过电路走线

(2)寄生电阻

电流密度可以选择导线宽度,电流大小影响单元间的布线方案,翻开工艺手册,我们经常能看到每层金属线能够承载的电流。通过这个参数我们可以计算所需要的金属层宽度。例如,有一根信号线需要承载1毫安的电流,而工艺手册注明每微米可以走 0.5毫安的电流,那么这根金属层的宽度至少要2微米。

(3)寄生电感

当电路是在一个真正的高频的情况下工作时,导线也开始存在了电感效应。 解决寄生电感的方法就是试着去模拟它,把它当成电路中的一部分。
首先需要尽早的完成布局,好让电路设计者较早的看到导线究竟能有多长,然后估计出可能引起的电感。版图设计过程中尤其注意不要因为电感耦合而影响其它部分。

2.器件的寄生参数

3.闩锁效应 

2.5 逻辑单元库的建立

2.5.1逻辑单元类别

标准单元、模块宏单元 输入输出单元

2.5.2逻辑单元电路

1.标准单元

组合电路:反向器、与非门、或非门、缓冲器、与门、或门等

时序电路:锁存器和寄存器

2.模块单元

(1)存储单元ROM
(2)RAM,存储单元可以通过独立设计制造并自成芯片产品,通常根据芯片设计的逻辑功能需求,利用内存编译器(memory compiler)设计不同的位数和不同的存储量。

(3)专用模块,通常指客户自行设计的专用标准产品模块;
(4)IP模块;
(5)模拟电路模块;

3.输入输出单元
输入输出单元(I/0 Pad cell)包括输入信号、输出信号、三态、双向、电源和接地单元。
对于输入信号单元,最重要的要考虑静电放电(ESD,electrostaticdischarge)的防护。静电放电的基本模型有四种,即人体模型(HBM)、机器模型(MM)、带电器件模型(CDM)和电场感应模型(FIM)。

2.5.3 物理单元建库与数据文件

1.标准单元

2.模块单元

3.I/O单元

4.特殊单元

5.物理单元建库与数据文件
物理库交换格式(LEF)文件
目前普遍使用的物理库是由Cadence公司开发的LEF(library exchange format)文件格式,已成为业界标准,一般LEF文件分为工艺LEF文件单元LEF文件两部分。工艺LEF文件定义的是布局布线的设计规则和晶圆厂的工艺信息,包括互连线的最小间距、最小宽度、厚度、典型电阻、电容、电流密度大小,布线宽度,通孔等信息;单元LEF文件主要用于定义标准单元、模块单元、I/0单元和各种特殊单元的物理信息,定义单元的面积大小、几何形状,布线层,端口信息,以及一些物理参数。

2.5.4 时序单元建库与数据文件

1.器件延时+互连线延时

2.器件延时数据:是根据物理库数据中实际版图的RC参数,结合品体管级的理论参数模型,经过集成电路仿真程序(SPICE,simulation program withintegrated circuit emphasis)仿真,并考虑到不同输入信号的转换(transition)时间和输出端的负载变量而建立的数据表。

3.时序库文件

4.时序库的PVT条件

 在建库时,人们同时会更加关心时序库(芯片)的应用条件,即PTV(process,工艺;temperature,温度;voltage,电压。有时也称作PVT)条件,它们均由晶圆厂提供。最常见的为三种PTV条件下的时序库,并且用来做逻辑综合和静态时序分析(见第6章),它们是考虑CMOS中的NMOS和PMOS晶体管都工作在同一工艺角条件下。最常用的工艺角为最佳或最快(BC/best case,fast)、最差或最慢(WC/worst,slow)、典型或正常(TC/typical,normal)三种。

这篇关于数字集成电路物理设计[陈春章]——知识总结与精炼02的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/992807

相关文章

Android数据库Room的实际使用过程总结

《Android数据库Room的实际使用过程总结》这篇文章主要给大家介绍了关于Android数据库Room的实际使用过程,详细介绍了如何创建实体类、数据访问对象(DAO)和数据库抽象类,需要的朋友可以... 目录前言一、Room的基本使用1.项目配置2.创建实体类(Entity)3.创建数据访问对象(DAO

Java向kettle8.0传递参数的方式总结

《Java向kettle8.0传递参数的方式总结》介绍了如何在Kettle中传递参数到转换和作业中,包括设置全局properties、使用TransMeta和JobMeta的parameterValu... 目录1.传递参数到转换中2.传递参数到作业中总结1.传递参数到转换中1.1. 通过设置Trans的

C# Task Cancellation使用总结

《C#TaskCancellation使用总结》本文主要介绍了在使用CancellationTokenSource取消任务时的行为,以及如何使用Task的ContinueWith方法来处理任务的延... 目录C# Task Cancellation总结1、调用cancellationTokenSource.

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

不懂推荐算法也能设计推荐系统

本文以商业化应用推荐为例,告诉我们不懂推荐算法的产品,也能从产品侧出发, 设计出一款不错的推荐系统。 相信很多新手产品,看到算法二字,多是懵圈的。 什么排序算法、最短路径等都是相对传统的算法(注:传统是指科班出身的产品都会接触过)。但对于推荐算法,多数产品对着网上搜到的资源,都会无从下手。特别当某些推荐算法 和 “AI”扯上关系后,更是加大了理解的难度。 但,不了解推荐算法,就无法做推荐系

从去中心化到智能化:Web3如何与AI共同塑造数字生态

在数字时代的演进中,Web3和人工智能(AI)正成为塑造未来互联网的两大核心力量。Web3的去中心化理念与AI的智能化技术,正相互交织,共同推动数字生态的变革。本文将探讨Web3与AI的融合如何改变数字世界,并展望这一新兴组合如何重塑我们的在线体验。 Web3的去中心化愿景 Web3代表了互联网的第三代发展,它基于去中心化的区块链技术,旨在创建一个开放、透明且用户主导的数字生态。不同于传统

学习hash总结

2014/1/29/   最近刚开始学hash,名字很陌生,但是hash的思想却很熟悉,以前早就做过此类的题,但是不知道这就是hash思想而已,说白了hash就是一个映射,往往灵活利用数组的下标来实现算法,hash的作用:1、判重;2、统计次数;

sqlite3 相关知识

WAL 模式 VS 回滚模式 特性WAL 模式回滚模式(Rollback Journal)定义使用写前日志来记录变更。使用回滚日志来记录事务的所有修改。特点更高的并发性和性能;支持多读者和单写者。支持安全的事务回滚,但并发性较低。性能写入性能更好,尤其是读多写少的场景。写操作会造成较大的性能开销,尤其是在事务开始时。写入流程数据首先写入 WAL 文件,然后才从 WAL 刷新到主数据库。数据在开始

usaco 1.2 Name That Number(数字字母转化)

巧妙的利用code[b[0]-'A'] 将字符ABC...Z转换为数字 需要注意的是重新开一个数组 c [ ] 存储字符串 应人为的在末尾附上 ‘ \ 0 ’ 详见代码: /*ID: who jayLANG: C++TASK: namenum*/#include<stdio.h>#include<string.h>int main(){FILE *fin = fopen (