集成電路版圖與工藝課程設計之用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.pswp.cn/news/455870.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/455870.shtml
英文地址,請注明出處:http://en.pswp.cn/news/455870.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

關于H264通過RTP傳輸的打包方式

Q:現在小弟初次嘗試H264的編碼通過RTP方式傳輸,具體實驗環境的問題如下:環境:服務器端,H264的幀數據(可能超過64k),分成N個1460字節的包,然后加上RTP頭發送。客戶端,VLC播…

AngualrJS之服務器端通信

譯自《AngularJS》 與服務器通信 目前,我們已經接觸過下面要談的主題的主要內容,這些內容包括你的Angular應用如何規劃設計、不同的angularjs部件如何裝配在一起并正常工作以及AngularJS中的模板代碼運行機制的一小部分內容。把它們結合在一起&#xff0…

硬盤顯示容量和實際容量不符合_買移動固態硬盤糾結大半天?花2分鐘看完這篇,購買時不再被坑...

如今移動硬盤已成為很多辦公用戶標配的物品,縱觀整個移動硬盤市場,主要有移動機械硬盤和移動固態硬盤兩種類型,前者容量大,價格較親民;而后者具備了輕薄、讀寫速度快、耐振動不怕摔等優點。不少追求高效率的用戶&#…

【Python基礎入門系列】第10天:Python 類與對象

首先,我已經假定你是個萌新或已經看了無數遍的垃圾文章,然后依然搞不懂類和對象,但是呢起碼知道有類和對象這么兩個玩意兒,我覺得有必要找一篇生動形象的示例來講解。 由于你可能沒有編程經驗, 所以無法從學過的編程…

數字電子技術課程設計之基于觸發器的三位二進制同步減法計數器無效態000/110

基于觸發器的三位二進制同步減法計數器無效態000/110 1 課程設計的目的與作用 掌握用multisim 的電路仿真程序 熟悉同步計數器工作原理和邏輯功能 熟悉計數器電路的分析和設計方法 掌握161 芯片集聯成任意進制同步加法計數器 2 設計任務 三位二進制減法計數器(無…

SUSE11 搭建iscsi target 配置

https://www.suse.com/documentation/sles11/stor_admin/data/sec_inst_system_iscsi_target.html#sec_inst_system_iscsi_target_manual https://www.novell.com/support/kb/doc.php?id7001308 http://scst.sourceforge.net/comparison.html轉載于:https://www.cnblogs.com/b…

圖像、幀、片、NALU(firstime)

圖像、幀、片、NALU 是學習 H.264 的人常常感到困惑的一些概念,我在這里對自己的理解做一些闡述,歡迎大家討論:H.264 是一次概念的革新,它打破常規,完全沒有 I 幀、P幀、B 幀的概念,也沒有 IDR 幀的概念。對…

【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異常處理和…

CSS邊框,背景,邊距,溢出

CSS邊框,背景,邊距,溢出 css邊框屬性 border:寬度 樣式 顏色; border-color; border-style; 邊框樣式:solid實現,dotted點狀線,dashed虛線CSS3的樣式 border-radius:圓角處理 box-shadow: x軸偏移 y軸偏移 模糊度 擴散成都 顏色…

LINUX 內存使用情況

# free 顯示結果如下: Mem:表示物理內存統計 total 內存總數 8057964KBused 已使用的內存 7852484KBfree 空閑的內存數 205480KBshared 當前已經廢棄不用,總是0buffers Buffer 緩存內存數: 290432KBcached Page 緩存內存數:5735024KB(存在關…

vagrant系列教程(四):vagrant搭建redis與redis的監控程序redis-stat(轉)

閱讀目錄 下載redis解壓redis編譯安裝redis配置redisredis開機自啟動系統參數的調整上一篇php7環境的搭建 真是火爆,僅僅兩天時間,就破了我之前swagger系列的一片文章,看來,大家對搭建環境真是情有獨鐘。 為了訪問量,我…

sps及pps在解碼器內傳遞過程

首先解碼器中有一個全局變量seq_parameter_set_rbsp_t SeqParSet[MAXSPS];// MAXSPS32,它是一個指向序列參數集的數組。還有一個全局變量seq_parameter_set_rbsp_t *active_sps;主要為后續解碼所用。解碼器先將碼流中的數據讀入臨時指針sps,之后存入全局…

【技術分享】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盒子模型就是使用現實中盒子來做比喻,幫助我們設置元素對應的樣式。盒子模型示意圖如下: 把元素叫做盒子,設置對應的樣式分別為:盒子的邊框…

分享Kali Linux 2017年第17周鏡像文件

分享Kali Linux 2017年第17周鏡像文件 Kali Linux官方于4月23日發布2017年的第17周鏡像。這次維持了11個鏡像文件的規模。默認的Gnome桌面的4個鏡像,E17、KDE、LXDE、MATE、XFCE桌面的各一個,手機版的包括ARMEL和ARMHF。有最近要安裝Kali Linux系統的&am…

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,如果出現如下…