集成电路版图与工艺课程设计之用CMOS实现Y=AB+C电路与版图

1 绪论

1.1 设计背景

集成电路设计(Integrated circuit design, IC design),亦可称之为超大规模集成电路设计(VLSI design),是指以集成电路、超大规模集成电路为目标的设计流程。集成电路设计涉及对电子器件(例如晶体管、电阻器、电容器等)、器件间互连线模型的建立。所有的器件和互连线都需安置在一块半导体衬底材料之上,这些组件通过半导体器件制造工艺(例如光刻等)安置在单一的硅衬底上,从而形成电路。
近些年来,集成电路技术发展迅猛,促使半导体技术不断地发展,半导体技术正在进入将整个系统整合在单一晶片上的时代。故对VLSI的版图设计的要求也越来越高。Tanner软件可提供完整的集成电路设计环境,帮助初学者进入VLSI设计领域。本设计采用Tanner Tools Pro 工具,对逻辑为Y=AB+C进行电路设计与仿真、版图设计与仿真,在报告中给出电路图、版图与仿真结果。

1.2 设计目标

设计目标逻辑:Y=AB+C
用CMOS工艺设计逻辑为Y=AB+C的电路和版图。因为CMOS是天然的反逻辑输出,所以需要先设计出逻辑为/Y=/(AB+C)的电路,再将输出接入一个CMOS反相器实现逻辑功能。
设计电路图(Schematic)时,N网络A与B串联且与C并联,P网络A与B并联且与C串联,在N和P网络的交界节点接入反相器后引出输出Y。
设计版图(Layout)时,在P型衬底(P-Sub)上进行制作,所以N-MOS管可以直接掺杂制作,而P-MOS管需要先制作一个N阱(N-Well),并在N阱里制作P-MOS管。整个设计比较简单,仅仅使用单层金属布线(Meteal)。
导出电路和版图网表(spice)文件,用Tspice软件进行仿真波形,分析电路和版图是否设计正确性以及其性能如何。在LVS验证中匹配电路原理图和版图逻辑和尺寸匹配性,完成整个设计过程。

2 Y=AB+C 的电路原理图设计与仿真

2.1 电路原理图设计

目标逻辑Y=AB+C,设计电路其功能为当C=1时,Y=1;当C=0而B和C不同时为1时,Y=0;当C=0,A和B都为1时,Y=1。
以上电路功能符合设计的目标逻辑Y=AB+C,所以此电路图(Schematic)设计正确,下面给出其真值表,如下表所示:
在这里插入图片描述
使用S-Edit软件进行电路图(Schematic)绘制,在Schematic Model下绘制电路图(Schematic),首先从Symbol Browser中导出N-MOS管和P-MOS管,然后绘制InputPort和OutPort,最后通过Wire线进行连接,如下图所示;
在这里插入图片描述

2.2 电路仿真

通过以上电路原理图(Schematic)和符号图的绘制,导出spice网表,用Tspice软件进行仿真波形,分析电路是否设计正确性以及其性能如何。
仿真需要在spice网表中添加额外的命令来完成仿真,需要添加包含文件(Include file)、外加电压(Constant Voltage source)、外加脉冲激励(Pulse Voltage source)、波形追踪(.tran)和打印波形(.print)命令。以下给出这些命令,如下表所示:
在这里插入图片描述
插入命令 含义
.include D:\Tanner\TSpice70\models\ml2_125.md 包含文件
vvdd Vdd Gnd 5 外加驱动
va A Gnd PULSE (0 5 5n 1n 1n 80n 160n)
vb B Gnd PULSE (0 5 5n 1n 1n 40n 80n)
vc C Gnd PULSE (0 5 5n 1n 1n 20n 40n) 脉冲激励
.tran/op 1n 400n method=bdf
.print tran v(Y) v© v(B) v(A) 波形追踪
下面给出电路原理图的仿真波形结果图,如下图所示:
在这里插入图片描述
输入激励以C的周期为基础,B翻一倍,A翻两倍,这样做可以将所有情况遍历出来,进而可以和真值表进行对比验证其准确性。

3 Y=AB+C的版图设计与仿真

3.1 版图设计

首先需要先制作一个N阱(N-Well),并在N阱里制作P-MOS管,由于在P型衬底(P-Sub)上进行制作,所以N-MOS管可以直接掺杂制作。整个设计比较简单,仅仅使用单层金属布线(Meteal)即可实现。
首先导入设计规则(lights.ext)文件,绘制两个有源区为PN网络,再绘制栅极横跨上下两个有源区,然后依照电路原理图合理分配源漏区,绘制有源区接触孔(Active Contact)并连线,再绘制衬底区,使用P-Select和N-Select、N-Well遮罩有源区,最后绘制端口(Port),每一步进行DRC电气规则检查从而保证当前设计符合设计和生产规则。
下面给出版图设计,如下图所示:
在这里插入图片描述
其中M1-M8管的宽和长(W和L),如下表所示:
在这里插入图片描述

3.2 DRC检查

DRC检查,即设计规则检查,是在进行版图设计中必要的一步,通过带有可选参数的DRC检查,可以保证设计尺寸和布局的准确性。
在进行DRC检查之前需要导入设计规则MOSIS/ORBIT 2.0U SCNA Design Rules,在绘制过程中需要不断进行检查,若有错误可以及时的修改更正。下面给出本设计的DRC检查结果,如下图所示:
在这里插入图片描述
经过检查,本设计版图符合设计规则,能够用于生产。图3.2图中的DRC Error Navigator窗口为DRC检查的内容,每一项都需要符合设计规则。

3.3 版图仿真

在绘制完版图后,可以导出spice网表,用Tspice软件进行仿真波形,来分析版图是否设计正确以及其性能如何。
导出spice网表需要在添加支持文件下进行,Import Mask Data选项下导入lights.ext文件。
仿真需要在spice网表中添加额外的命令来完成仿真,需要添加的命令如电路导出的spice网表一样包括包含文件(Include file)、外加电压(Constant Voltage source)、外加脉冲激励(Pulse Voltage source)、波形追踪(.tran)和打印波形(.print)命令。以下给出这些命令,如表所示:
在这里插入图片描述
插入命令 含义
.include D:\Tanner\TSpice70\models\ml2_125.md 包含文件
vvdd Vcc Gnd 5 外加电压
va A Gnd PULSE (0 5 800n 1n 1n 800n 1600n)
vb B Gnd PULSE (0 5 400n 1n 1n 400n 800n)
vc C Gnd PULSE (0 5 200n 1n 1n 200n 400n) 脉冲激励
.tran/op 1n 5000n method=bdf
.print tran v(A) v(B) v© v(y) 波形追踪
在Tspice软件中打开版图中导出的spc网表文件,加入上述激励命令,再进行波形的仿真,如图所示:
在这里插入图片描述
通过版图仿真出来的波形,再结合之前生成的电路图仿真的波形以及电路原理图和真值表,能够验证版图绘制过程中的正确性。因为输入信号只有三个,所以可以将输入激励以C的周期为基础,B增加一倍,A增加两倍,这样做的好处是能够将所有的输入情况进行遍历,可以完整的检验设计逻辑的正确性。
由给出的激励如va A Gnd PULSE (0 5 800n 1n 1n 800n 1600n)可知A输入信号激励初始为0电平,其峰值为5V,初始电平延时时间为800ns,电平上升和下降时间为1ns,峰值保持时间为800ns,周期为1600ns可知,该输入信号频率较低,从而保证输出的波形十分规整,无明显的毛刺现象。

4 版图与电路图验证

将版图和电路图直接进行对比验证,可以很直接的判断设计的统一性,将原理设计和版图设计统一为一个整体,同时,也可以检查出单一设计中的一些问题,比如MOS的宽长比例是否一致,金属孔类型是否正确等。
启动LVS软件,新建立一个项目(LVS setup)分别将版图的spc网表和电路图的sp网表文件导入进去,添加包含的文件命令:.include “D:\Tanner\TSpice70\models\ml2_125.md”。这里需要注意的是上述仿真添加的激励命令需要注释掉,否则会产生一些不必要的警告,如图所示:在这里插入图片描述

配置LVS对比的的设置,在Output选项卡里勾选Output file和Node and element list并分别添加之前仿真产生的文件,在Device Parameters里勾选R,C and L Elements中唯一的一项Resistance,capacitance and inductance value选项,以上图4.1为LVS配置界面
下面给出LVS对比的结果,如图所示:
在这里插入图片描述
通过对比的结果可以看出,电路图和版图的各种参数保持一致,从而再次验证了本次设计的正确性。

5 总结

通过这段时间的课程设计的学习,综合运用所学的知识完成了设计任务。使我更深的的了解版图工艺的艺术,并深入掌握仿真方法和工具Tanner、同时为以后从事本专业工作打下坚实的基础。进一步熟悉设计中使用的主流工具,版图设计属于集成电路的后端设计,通过绘制电路版图,发现了理论与现实有着很大的差别,特别是绘制版图,需要很大的耐心和毅力。由逻辑表达式到电路原理图绘制再到版图的绘制,突破一个个问题然后是成功从设计到实现。
课程设计是一门很严谨的的课程,给了我很多专业知识,同时在一定程度上提高了我的专业技能,还教给我许多的道理。通过课程设计,我不仅学到了知识,而且从中领悟到了一些解决问题的方法,为以后的学习打下了坚实的基础。

参考文献

[1] 姜岩峰编著.现代集成电路版图设计.北京:化学工业出版社,2010
[2] 尹飞飞编著.CMOS模拟集成电路版图设计与验证:基于Cadence Virtuoso与Mentor Calibre. 北京:电子工业出版社,2016
[3] 曾庆贵、姜玉稀编著.集成电路版图设计教程.上海:上海科学技术出版社,2012

附录一:电路原理图网表

* SPICE netlist written by S-Edit Win32 7.03
* Written on Jun 17, 2019 at 20:44:53
* Waveform probing commands
.probe
.options probefilename="E:\tanner_pro\ABC13\dianlutu\Module2.dat"
+ probesdbfile="E:\tanner_pro\ABC13\dianlutu\demo2.sdb"
+ probetopmodule="Module0"* Main circuit: Module0
M1 N1 B N4 Gnd NMOS L=2u W=22u AD=66p PD=24u AS=66p PS=24u 
M2 N1 C Gnd Gnd NMOS L=2u W=22u AD=66p PD=24u AS=66p PS=24u 
M3 N4 A Gnd Gnd NMOS L=2u W=22u AD=66p PD=24u AS=66p PS=24u 
M4 Y N1 Gnd Gnd NMOS L=2u W=22u AD=66p PD=24u AS=66p PS=24u 
M5 N1 A N8 Vdd PMOS L=2u W=22u AD=66p PD=24u AS=66p PS=24u
M6 N1 B N8 Vdd PMOS L=2u W=22u AD=66p PD=24u AS=66p PS=24u
M7 N8 C Vdd Vdd PMOS L=2u W=22u AD=66p PD=24u AS=66p PS=24u
M8 Y N1 Vdd Vdd PMOS L=2u W=22u AD=66p PD=24u AS=66p PS=24u
* End of main circuit: Module0
vvdd Vdd Gnd 5.tran/op 1n 400n method=bdf
.print tran v(A) v(B) v(C) v(Y)
.include "D:\tanner\TSpice70\models\ml2_125.md"
va A Gnd PULSE (0 5 5n 1n 1n 80n 160n)
vb B Gnd PULSE (0 5 5n 1n 1n 40n 80n)
vc C Gnd PULSE (0 5 5n 1n 1n 20n 40n)

附录二:版图网表

* Circuit Extracted by Tanner Research's L-Edit Version 9.00 / Extract Version 9.00 ;
* TDB File:  E:\tanner_pro\ABC13\bantu\layout2.tdb
* Cell:  Cell0	Version 1.27
* Extract Definition File:D:\Tanner\LEdit90\Samples\SPR\example1\lights.ext
* Extract Date and Time:  06/18/2019 - 13:15
* NODE NAME ALIASES
*       1 = Vcc (642,-1409)
*       3 = Gnd (648.5,-1469.5)
*       5 = y (682,-1441)
*       6 = A (615,-1459.5)
*       7 = C (640.5,-1460)
*       8 = B (628.5,-1460)
M9 y 2 Gnd Gnd NMOS L=2.5u W=10.5u 
M8 2 B 9 Gnd NMOS L=2.5u W=10.5u 
M7 Gnd C 2 Gnd NMOS L=2.5u W=10.5u 
M6 9 A Gnd Gnd NMOS L=2.5u W=10.5u 
M4 y 2 Vcc Vcc PMOS L=2.5u W=10.5u 
M3 4 B 2 Vcc PMOS L=2.5u W=10.5u 
M2 Vcc C 4 Vcc PMOS L=2.5u W=10.5u 
M1 2 A 4 Vcc PMOS L=2.5u W=10.5u * Total Nodes: 9
* Total Elements: 8
* Total Number of Shorted Elements not written to SPICE file: 1
* Extract Elapsed Time: 0 seconds
.END
vvdd Vcc Gnd 5
.tran/op 1n 5000n method=bdf
.print tran v(A) v(B) v(C) v(y)
.include "D:\Tanner\TSpice70\models\ml2_125.md"
va A Gnd PULSE (0 5 800n 1n 1n 800n 1600n)
vb B Gnd PULSE (0 5 400n 1n 1n 400n 800n)
vc C Gnd PULSE (0 5 200n 1n 1n 200n 400n)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/455870.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

硬盘显示容量和实际容量不符合_买移动固态硬盘纠结大半天?花2分钟看完这篇,购买时不再被坑...

如今移动硬盘已成为很多办公用户标配的物品,纵观整个移动硬盘市场,主要有移动机械硬盘和移动固态硬盘两种类型,前者容量大,价格较亲民;而后者具备了轻薄、读写速度快、耐振动不怕摔等优点。不少追求高效率的用户&#…

【Python基础入门系列】第10天:Python 类与对象

首先,我已经假定你是个萌新或已经看了无数遍的垃圾文章,然后依然搞不懂类和对象,但是呢起码知道有类和对象这么两个玩意儿,我觉得有必要找一篇生动形象的示例来讲解。 由于你可能没有编程经验, 所以无法从学过的编程…

数字电子技术课程设计之基于触发器的三位二进制同步减法计数器无效态000/110

基于触发器的三位二进制同步减法计数器无效态000/110 1 课程设计的目的与作用 掌握用multisim 的电路仿真程序 熟悉同步计数器工作原理和逻辑功能 熟悉计数器电路的分析和设计方法 掌握161 芯片集联成任意进制同步加法计数器 2 设计任务 三位二进制减法计数器(无…

【Python的黑魔法】实例方法、静态方法和类方法

class Bird:# classmethod修饰的方法是类方法classmethoddef fly (cls):print(类方法fly: ,cls)# staticmethod修饰的方法是静态方法# staticmethoddef info (p):print(静态方法info: , p)if __name__ __main__:# 调用类方法,Bird类会自动绑定到第一个参数Bird.fl…

基于dreamweaver软件设计和开发一网站_基于 abp vNext 和 .NET Core 开发博客项目 Blazor 实战系列(一)...

系列文章使用 abp cli 搭建项目给项目瘦身,让它跑起来完善与美化,Swagger登场数据访问和代码优先自定义仓储之增删改查统一规范API,包装返回模型再说Swagger,分组、描述、小绿锁接入GitHub,用JWT保护你的API异常处理和…

LINUX 内存使用情况

# free 显示结果如下: Mem:表示物理内存统计 total 内存总数 8057964KBused 已使用的内存 7852484KBfree 空闲的内存数 205480KBshared 当前已经废弃不用,总是0buffers Buffer 缓存内存数: 290432KBcached Page 缓存内存数:5735024KB(存在关…

vagrant系列教程(四):vagrant搭建redis与redis的监控程序redis-stat(转)

阅读目录 下载redis解压redis编译安装redis配置redisredis开机自启动系统参数的调整上一篇php7环境的搭建 真是火爆,仅仅两天时间,就破了我之前swagger系列的一片文章,看来,大家对搭建环境真是情有独钟。 为了访问量,我…

【技术分享】Ubuntu下使用微信教程

做后端开发的同学用的Linux(ubuntu),肯定会因为没有适配微信版本会感觉不太舒服,很多时候因为缺少一些办公通讯软件而感到不便。现在已经有很方便的Wine WeChat方案,但是微信在Wine上配置还有许多bug,今天在github上看…

python join函数_Python join()函数

原博文 2016-08-12 10:16 − 今天写python 100例时,有个题目是大致是这样的:已知输入形式是1321,要求输出形式为1123 一开始思路是将输入的字符串用split()函数划分成数组,在对数组进行排序,再用for循环输出 代码附上&…

CSS中的盒子

盒子 盒子模型解释元素在页面中显示成一个方块,类似一个盒子,CSS盒子模型就是使用现实中盒子来做比喻,帮助我们设置元素对应的样式。盒子模型示意图如下: 把元素叫做盒子,设置对应的样式分别为:盒子的边框…

Djang重新整理migrations,解决:Django Table xxx already exist

在开发过程中,由于需求变更或者自我重构,需要清理migrations,以保持代码整洁和后续的可维护性。 场景一 不考虑数据库数据表,可以完全清空数据库里面的表的数据。 步骤: 删除所有migrations find . -path "/migr…

安全随笔2:对称加密应用场景

MD5或者说HASH值是一种不可逆的算法。如果需要从密文还原成明文,那么就需要对称和非对称这两类可逆算法。 首先,简单介绍下这两类算法。图9-1是对称算法的示意图: 图9-1 对称算法 在对称算法中,首先需要发送方和接收方协定一个密钥…

python安装多久_python安装与使用

1、进入官网下载python软件 python-3.4.4.amd64.msi http://www.python.org/download/ 这个软件包含三个环境,如下图:2、双击安装软件 3、设置环境变量path";C:\Python34"; 4、验证是否安装成功 进入cmd中,输入python,如果出现如下…

CSS中的块元素,内联元素,内联块元素

块元素,内联元素,内联块元素 元素就是标签,布局中常用的有三种标签,块元素、内联元素、内联块元素,了解这三种元素的特性,才能熟练的进行页面布局。 块元素块元素,也可以称为行元素,布局中常用的标签如&…

django 与 vue 的完美结合

最近接到一个任务,就是用django后端,前段用vue,做一个普通的简单系统,我就是一搞后端的,听到vue也是比较震惊,之前压根没接触过vue。看了vue的一些文档,还有一些项目,先说一下django…

东芝确定半导体重组计划:保留闪存其他全卖

会计丑闻给日本东芝公司的业绩带来严重影响,为了提高盈利,东芝正在对旗下的半导体、个人电脑、白色家电等业务进行一次重大重组。据日经新闻1月23日报道,东芝已经正式制定了芯片业务重组的详细计划,除了占据优势的闪存芯片之外&am…

python画两条曲线图_python绘制多个曲线的折线图

这篇文章利用的是matplotlib.pyplot.plot的工具来绘制折线图,这里先给出一个段代码和结果图: # -*- coding: UTF-8 -*- import numpy as np import matplotlib as mpl import matplotlib.pyplot as plt #这里导入你自己的数据 #...... #...... #x_axix&a…

oracle 截取字指定的字符串

过滤指定的字符串,一字符串有重复的数据内容,所以需要去掉重复的内容,subst()截取 起止下标;instr()获取终止下标位置 例如:substr(p.address, 0, instr(p.address, -, 1, 1)-1) ); case when length(substr(p.address, 0, instr(p.address, -, 1, 1)-1) ) 13 then substr(sub…

数据分级分类实施指南_运营商行业数据安全治理实践

建立组织构建大数据安全保障组一、大数据安全保障工作组职责 1、负责制定大数据信息安全策略,明确信息安全目标。 2、组织相关平台负责人定期召开信息安全会议。 3、负责客户数据安全突发事件应急方案实施和大数据信息系统日常安全运行管理的组织协调及决策工作。 4…

servlet中中文正常显示,mysql数据库手动插入中文正常显示,servlet向mysql中插入中文显示乱码...

作者:http://5563447.blog.51cto.com/5553447/1422627 问题是:就是POST请求提交表单数据给servlet,通过JDBC插入Mysql,出现中文乱码。 解决方式:在url后面加这句 ?useUnicodetrue&characterEncodingutf-8 我的项目: 结果&am…