



# **Computer-Aided VLSI System Design (EE5022)**

台大電機系/電子所

楊家驥教授

2023.02.21



# IC Design and Implementation

Idea



Design





# Digital IC Design Flow

1. Concept/Application
2. Function/Spec. definition
3. Algorithm exploration
4. Architecture design
  1. Divide-and-conquer
  2. Sub-module design
  3. Design verification
5. System prototyping
  1. RTL design
  2. Verilog Coding/Schematic Design
  3. Cell-based IC design flow / FPGA design flow



```
module Add_Sub_Unit( result, operand_a, operand_b, mode, detect );
  input [3:0] operand_a, operand_b;
  input mode;
  output [3:0] result;
  output detect; // for question 3
  wire [3:0] xor_b;
  xor g0 ( xor_b[0], operand_b[0], mode );
  assign result = {result3, result2, result1, result0};
endmodule
```



# Algorithm Mapping





# System Specifications



Partition

| 腳位名稱  |    | 描述                          | Drive Strength/Output Load |
|-------|----|-----------------------------|----------------------------|
| clk   | 輸入 | 系統時脈                        | assume infinite            |
| reset | 輸入 | 系統重置訊號，high active          | 1 ns/pf                    |
| din   | 輸入 | 每個clock cycle輸入一個16-bit 正整數 | 1 ns/pf                    |
| ready | 輸出 |                             |                            |
| dout  | 輸出 |                             |                            |

IO Spec.



IO Timing Spec.



# Cell-based Design Flow





# Digital IC Design Flow





# Introduction

## ❖ Objective

❖ Students will learn how to design VLSI circuits and systems following a **standard VLSI system design flow**, where various **electronic design automation (EDA) tools** will be used extensively in the semester

## ❖ Course content

1. Verilog-HDL
2. Synthesis
3. Static Timing Analysis
4. Placement and Routing
5. Verification
6. High-level synthesis
7. Design Rule Check, Layout versus Schematic, Layout Parasitic Extraction



# Course Schedule (1)

| Week | Date | Lecture                                 | Speaker | Place  | Lab  | HW assign | HW due |
|------|------|-----------------------------------------|---------|--------|------|-----------|--------|
| 01   | 2/21 | Introduction                            | 楊家驥教授   | BL113  | Lab0 |           |        |
| 02   | 2/28 | Verilog-HDL (1)                         | 張惇宥     | Online |      |           |        |
| 03   | 3/7  | Verilog-HDL (2)                         | 張惇宥     | Online | Lab1 | HW1       |        |
| 04   | 3/14 | Verilog-HDL (3)                         | 李晴妍     | Online |      |           |        |
| 05   | 3/21 | Verilog-HDL (4)                         | 李晴妍     | Online | Lab2 | HW2       | HW1    |
| 06   | 3/28 | Synthesis (1)                           | 陳世豪     | Online | Lab3 | HW3       |        |
| 07   | 4/4  | Synthesis (2)                           | 陳世豪     | Online |      |           | HW2    |
| 08   | 4/11 | Static Timing Analysis                  | 張峻璋     | Online | Lab4 |           |        |
| 09   | 4/18 | Midterm                                 |         | BL113  |      |           |        |
| 10   | 4/25 | Midterm Review/<br>Project Announcement | TA      | BL113  |      | HW4       | HW3    |



## Course Schedule (2)

| Week | Date | Lecture                     | Speaker  | Place  | Lab   | HW assign | HW due |
|------|------|-----------------------------|----------|--------|-------|-----------|--------|
| 11   | 5/2  | APR (1)                     | TSRI     | Online | Lab5  |           |        |
| 12   | 5/9  | APR (2)                     | TSRI     | Online | Lab6  | HW5       | HW4    |
| 13   | 5/16 | APR (3)                     | TSRI     | Online | Lab7  |           |        |
| 14   | 5/23 | Cadence Formal Verification | Cadence  | Online | Lab8  |           | HW5    |
| 15   | 5/30 | High-Level Synthesis        | Cadence  | Online | Lab9  |           |        |
| 16   | 6/6  | PVS/DRC/LVS                 | Cadence  | Online | Lab10 |           |        |
| 17   | 6/13 | Project Presentation        | MediaTek | Online |       |           |        |

### Acknowledgment:

- Final project: 聯發科技，無線通訊技術本部，晶片開發一處
- Formal verification, HLS, PVS: 益華科技
- APR: 台灣半導體研究中心 (TSRI)

MEDIATEK

cadence®



NARLabs 國家實驗研究院  
台灣半導體研究中心  
Taiwan Semiconductor Research Institute



## 線上課程連結

- ❖ Webex: <https://ntucc.webex.com/meet/yicwu>
- ❖ 登入請用”學號-姓名”供助教確認身份
- ❖ 預設為關閉麥克風，有問題可使用聊天室提出



# Contact (1)

- ❖ 大助教: 蔡宇軒 [f07943171@ntu.edu.tw](mailto:f07943171@ntu.edu.tw)
- ❖ 小助教: 羅宇呈 [f08943129@ntu.edu.tw](mailto:f08943129@ntu.edu.tw) 、朱怡蓁 [r10943012@ntu.edu.tw](mailto:r10943012@ntu.edu.tw) 、  
吳秉陞 [r10943007@ntu.edu.tw](mailto:r10943007@ntu.edu.tw)
- ❖ 授課助教:
  - ❖ Verilog-HDL (1) (2): 張惇宥 [r11943017@ntu.edu.tw](mailto:r11943017@ntu.edu.tw)
  - ❖ Verilog-HDL (3) (4): 李晴妍 [r10k41001@ntu.edu.tw](mailto:r10k41001@ntu.edu.tw)
  - ❖ Synthesis (1) (2): 陳世豪 [r09943176@ntu.edu.tw](mailto:r09943176@ntu.edu.tw)
  - ❖ Static Timing Analysis: 張峻瑋 [r09943187@ntu.edu.tw](mailto:r09943187@ntu.edu.tw)
- ❖ Lab助教:
  - ❖ Lab0: 蔡宇軒 [f07943171@ntu.edu.tw](mailto:f07943171@ntu.edu.tw)
  - ❖ Lab1-Lab5: 羅宇呈 [f08943129@ntu.edu.tw](mailto:f08943129@ntu.edu.tw)
  - ❖ Lab6-Lab10: 朱怡蓁 [r10943012@ntu.edu.tw](mailto:r10943012@ntu.edu.tw)



# Contact (2)

❖ HW助教：

- ❖ HW1: 李其祐 [r11943123@ntu.edu.tw](mailto:r11943123@ntu.edu.tw)
- ❖ HW2: 周子皓 [r11943133@ntu.edu.tw](mailto:r11943133@ntu.edu.tw)
- ❖ HW3: 張力元 [r11943006@ntu.edu.tw](mailto:r11943006@ntu.edu.tw)
- ❖ HW4: 陳泰融 [r11943024@ntu.edu.tw](mailto:r11943024@ntu.edu.tw)
- ❖ HW5: 吳秉陞 [r10943007@ntu.edu.tw](mailto:r10943007@ntu.edu.tw)



# Grading Policy

- ❖ Participation (Lab): 5%
- ❖ Homework: 30%
  - ❖ Submission to NTU Cool
  - ❖ Deadline: **Tuesday afternoon** (13:59 pm)
- ❖ Midterm Exam: 30%
  - ❖ Closed-book written test
- ❖ Final Project: 35%
  - ❖ A team of 2 students
  - ❖ VLSI design



# Other Information

- ❖ Textbooks
  - ❖ Cadence Verilog Manual and Lecture Notes
- ❖ Course website
  - ❖ <https://cool.ntu.edu.tw/courses/22079>
- ❖ Enrollment priority
  - ❖ Enrolled > ICS/EDA/ICDA students > ICS/EDA/ICDA advisees > Other graduate students > EE students > Others



# 製程申請

NARLabs 國家實驗研究院  
台灣半導體研究中心

## 【使用者名單】

申請日期：111 年 08 月 27 日

申請人楊家麟同意僅授權以下人員，使用經由TSRI取得之製程資料，並負有監督被授權使用者保密之責任。經申請人授權使用TSRI提供之製程資料，保證被授權人因故離開學校(如：畢業、休學或課程結束或授權使用需求終止時，立即停止其製程資料使用權)，被授權人並須自行銷毀所有取得之資料。如因違反前述承諾而造成TSRI或製程提供廠商的損失，同意負擔所有賠償責任及相關之法律責任。

- 請申請者使用下列製程資料之製程代號：

- 被授權者須遵守以下規定：

- 被授權者僅可予以下列使用：

  1. 被授權使用者應安於保謄相關製程資訊(包含紙本資料及電子檔資料)，並不得以任何方式複製、散佈，亦不得授予給其他任何人使用。
  2. 被授權人因故離開學校(如：畢業、休學)或課程結束或授權使用需求終止時，被授權人必須立即停止使用並自行銷毀所有取得之資料。
  3. 未別於被授權使用老舊之人員，除無權使用製程資料外，亦無法申請晶片製作。

- 附加文件資料(請確認效期):

1. 被授權使用者請附當學期註冊章之學生證影本或在學證明影本，或其他足以證明學籍與身份之文件；被授權使用者若為外籍身份，需再附加有效居留證影本。  
2. 被授權使用者若為研究人員身份，請附(1)校方有效聘書影本、(2)與申請人(教授)間雇佣關係之有效證明文件；被授權使用者若為外籍身份，需再附加有效居留證影本。

申請人服務單位(學校系所)：國立臺灣大學-電機工程系(所)

申請人(教授)簽章:

【授權人數較多時，請自行複製此使用者名單；申請人須於每頁最後欄位(即申請人簽章欄位)簽名或蓋章】



❖ <https://www.tsri.org.tw>

# TSRI會員申請

! 會員註冊

基本資料

(欄位前有 \* 號，為必須輸入欄位)

\* 會員帳號 : (請勿使用身分證及email)

檢查是否已註冊?

\* 密碼(長度介於8-16位數、必須同時包含英文、數字) :

\* 密碼確認 :

\* 中文姓名(同護照) :

\* 英文姓名(同護照或格式：姓名王大中，名DA-CHUNG，姓WANG) :

First Name(名字)       Last Name(姓氏)

国籍 :

Taiwan(台灣)

\* 聯絡電話 :

區碼       電話號碼       分機       非必填

\* 手機 :



# EE2-231 Server Account

❖ <https://reurl.cc/RXqX0x>



## IC設計實驗室伺服器帳號申請表

### 實驗室規則：

1. 請勿任意 reboot 主機，破壞系統或做出對系統有害之行為，或將帳號借予他人使用，否則  
若經查獲，立即刪除帳號，並交由教授處理。
2. 硬碟使用空間以大學部 1G、碩士班 5G、博士班 10G 為限。
3. 個人資料請隨時自行備份，並於隔年9/1前將個人目錄下的檔案清理乾淨，不保證檔案完整性。
4. 帳號預設期限為一學年，每年9/1將停止上學年申請之帳號，新的學年度請重新申請。
5. 其它注意事項請參閱本實驗室內的實驗室公布欄與實驗室網頁 <http://cad.ee.ntu.edu.tw>。
6. 本伺服器帳號需使用"校內IP"登入，如果是校外IP，請參考 <https://ccnet.ntu.edu.tw/vpn>。



# 個資同意書



## 經濟部工業局 蒐集個人資料告知事項暨個人資料提供同意書

版本：P-V5x-RISD

經濟部工業局（以下簡稱本局）為遵守個人資料保護法令及本局個人資料保護政策、規章，  
於向您蒐集個人資料前，依法向您告知下列事項，敬請詳閱。

### 一、 蒯集目的及類別

本局因辦理或執行公私(產學)共育國內外高階人才計畫業務、活動、計畫、提供服務及  
供本局用於內部行政管理、陳報主管機關或其他合於本局所定業務、寄送本局或產業相  
關活動訊息之蒐集目的，而需獲取您下列個人資料類別：○○一辨識個人者：姓名、  
工作地址、職稱、○五二資格或技術：學歷、○六一現行之受僱情形；公司名稱、  
部門

※您日後如不願再收到本局所寄送之行銷訊息，可於收到前述郵件時，直接點選郵件內拒絕接  
收之連結。

### 二、 個人資料利用之期間、地區、對象及方式

除涉及國際業務或活動外，您的個人資料僅供本局於中華民國領域、在前述蒐集目的之必  
要範圍內，以合理方式利用至蒐集目的之消失為止。

### 三、 當事人權利

您可依前述業務、活動所定規則或以電子郵件聯繫(iei@iii.org.tw)向本局行使下列權利：

- (一)查詢或請求閱覽。
- (二)請求製給複製本。
- (三)請求補充或更正。
- (四)請求停止蒐集、處理及利用。
- (五)請求刪除您的個人資料。

### 四、 不提供個人資料之權益影響

若您未提供正確或不提供個人資料，本局將無法為您提供蒐集目的之相關服務。

### 五、 您瞭解此一同意書符合個人資料保護法及相關法規之要求，且同意本局留存此同意書， 供日後取出查驗。

#### 個人資料之同意提供：

- 一、本人已充分獲知且已瞭解上述經濟部工業局告知事項。
- 一、本人同意經濟部工業局於所列蒐集目的之必要範圍內，蒐集、處理及利用本人之個人資料。  
立同意書人：

中　　華　　民　　國　　1　　1　　1　　年　　月　　日



# 簽到表 (實體，線上請登入時用學號-姓名)



111 年經濟部工業局  
公私(產學)共育國內外高階人才計畫  
表格二：數位積體電路設計潛力學程-簽到表(實體活動)

| 日期              |      | 111 年 月 日 |    | 時間 | 00:00~00:00  |
|-----------------|------|-----------|----|----|--------------|
| 主題              |      | 地點        |    |    |              |
| 專家(顧問/講師)<br>簽名 |      |           |    |    |              |
| 項次              | 學校   | 科系        | 年級 | 姓名 | 簽名<br>(中文正楷) |
| 1.              | 台灣大學 |           |    |    |              |
| 2.              | 台灣大學 |           |    |    |              |
| 3.              | 台灣大學 |           |    |    |              |
| 4.              | 台灣大學 |           |    |    |              |
| 5.              | 台灣大學 |           |    |    |              |
| 6.              | 台灣大學 |           |    |    |              |
| 7.              | 台灣大學 |           |    |    |              |
| 8.              | 台灣大學 |           |    |    |              |
| 9.              | 台灣大學 |           |    |    |              |
| 10.             | 台灣大學 |           |    |    |              |
| 11.             | 台灣大學 |           |    |    |              |
| 12.             | 台灣大學 |           |    |    |              |
| 13.             | 台灣大學 |           |    |    |              |
| 14.             | 台灣大學 |           |    |    |              |
| 15.             | 台灣大學 |           |    |    |              |



## 關於選課

### ❖ 加簽方式

- ❖ 電子所 ICS/EDA 以及重點科技學院 ICDA 同學優先加簽
- ❖ 第一次上課請向助教登記取得授權碼，超過可加簽人數將以抽籤決定
- ❖ 原則上第一次上課未出席不予加簽

### ❖ 先修課程與基礎

- ❖ 最好有 Verilog 基礎。不熟悉 Verilog 同學，可先修數位設計相關課程 (e.g., 數位電路實驗、數位系統設計、計算機結構、積體電路設計實驗等)
- ❖ 課程可旁聽，請寫信給大助教宇軒 [f07943171@ntu.edu.tw](mailto:f07943171@ntu.edu.tw) 列入旁聽名單



# **Digital Design Using Integrated Circuits (IC)**

# **& Very Large-Scale IC (VLSI)**

---



# The First Computer



**The Babbage  
Difference Engine  
(1832)**

**25,000 parts**  
**Cost: 17,470 Pounds**  
**in Year 1832**

*Use Relays as switching components*



# ENIAC - The first electronic computer (1946)



*Use Vacuum Tubes as switching components*



# Technologies for Building Processors & Memories

## ❖ Vacuum tube

- ❖ An electronic component, predecessor of the transistor, that consists of a hollow glass tube about 5 to 10 cm long from which as much air has been removed as possible and which uses an electron beam to transfer data

## ❖ Transistor

- ❖ An ON/OFF switch controlled by an electric signal

## ❖ Very large scale integrated (VLSI) circuit

- ❖ A device containing hundreds of thousands to millions of transistors



# Vacuum Tube





# The Transistor Revolution



First transistor  
Bell Labs, 1948



# Discrete Transistors





# The MOS Transistor





# FinFET Device Schematic



ComputerHope.com



# The First Integrated Circuits



*Bipolar logic  
1960's*

ECL 3-input Gate  
Motorola 1966



# Gate and Circuit Level Design





# Mapping of Layout to IC Layers





# Layout of an CMOS Inverter





# Physical Design





# Physical Layout of your design





# The “Timing Closure” Problem



*Iterative Removal of Timing Violations (white lines)*

Courtesy Synopsys



## Example: Intel 4004 Micro-Processor



1971  
1000 transistors  
1 MHz operation



## Example: Intel Pentium (IV) microprocessor





## Example: Apple M1 & M2 Chips



Apple M1



Apple M2



# 8-inch Wafer



An 8-inch (200-mm) diameter wafer containing Intel Pentium 4 processors



# Die Cost



Single die

Wafer



Going up to 12"

From <http://www.amd.com>



# Wafer-Scale Engine



## Cerebras Wafer-Scale Engine

|                     | Gen1 WSE                     | Gen2 WSE                     |
|---------------------|------------------------------|------------------------------|
| Fabrication process | <b>16 nm</b>                 | <b>7 nm</b>                  |
| Silicon area        | <b>46,225 mm<sup>2</sup></b> | <b>46,225 mm<sup>2</sup></b> |
| Transistors         | <b>1.2 Trillion</b>          | <b>2.6 Trillion</b>          |
| AI-optimized cores  | <b>400,000</b>               | <b>850,000</b>               |
| Memory on-chip      | <b>18 GB</b>                 | <b>40 GB</b>                 |
| Memory bandwidth    | <b>9 PB/s</b>                | <b>20 PB/s</b>               |
| Fabric bandwidth    | <b>100 Pb/s</b>              | <b>220 Pb/s</b>              |

From <https://www.cerebras.net>



# The Chip Manufacturing Process





# Technologies for Building Processors & Memories

| Year | Technology used in computers         | Relative performance/unit cost |
|------|--------------------------------------|--------------------------------|
| 1951 | Vacuum tube                          | 1                              |
| 1965 | Transistor                           | 35                             |
| 1975 | Integrated circuit                   | 900                            |
| 1995 | Very large scale integrated circuit  | 2,400,000                      |
| 2005 | Ultra large scale integrated circuit | 6,200,000,000                  |

Relative performance per unit cost of technologies used in computers over time



# Design Abstraction Levels





# Behavioral Model





# Moore's Law vs. HDL

---

*Issue : Design Productivity*



# **Review of Full-custom Analog Design Flow**



# Schematic of 741 Op-amp Circuits



Fig. 1(a) Transistor level circuit diagram for op741



## The classic 741 bipolar op-amp

E-Mail: [help@www.spartakus.org](mailto:help@www.spartakus.org) | Version 1.1 | 2024-01-01

<https://www.ncbi.nlm.nih.gov/pmc/articles/PMC1000000/>

Schematic  
(Transistor level  
circuit diagram)  
for op741

# Editing In EDA tools



# SPICE – Manual Programming or Export from Schematic

- ❖ When you export the SPICE netlist, you get the following file:

\*SPICE BJT Amplifier

C1 5 1 1U

C3 2 4 1U

C2 0 6 100U

Q1 2 1 6 ZTX109 1.0

R1 1 3 82k

R4 2 3 4.7k

R2 0 1 22k

R3 0 6 1.8k

C4 0 3 100u

.MODEL ZTX109 NPN IS=1.8E-14 ISE=5.0E-14 NF=.9955 BF=400 BR=35.5  
+IKF=.14 IKR=.03 ISC=1.72E-13 NC=1.27 NR=1.005 RB=.56 RE=.6 RC=.25  
+VAF=80 VAR=12.5 CJE=13E-12 TF=.64E-9 CJC=4E-12 TR=50.72E-9  
MJC=.33 .END



# Schematic Inputs and Simulations of A two-stage 1.9GHz monolithic low-noise amplifier (LNA)



Source: <http://www.elecfans.com/article/84/148/2008/2008091712654.html>



# Single-Chip Radio Chip





# Summary:

## Full-custom Analog Design Flow



Lower Design Productivity



Figure 4.3 Full-custom (or analog) design flow.



## Moore's Law

In 1965, *Gordon Moore* noted that the number of transistors on a chip doubled every 18 to 24 months.

He made a prediction that semiconductor technology will **double** its effectiveness **every 18~24 months**



# Transistor Counts

500M~1Billion  
Transistors





# Moore's Law: Driving Technology Advances

- ❖ Logic capacity doubles per IC at regular intervals (1965).
- ❖ Logic capacity doubles per IC every 18 months (1975).





# Engineering Productivity Gap



- Engineering productivity has not been keeping up with silicon gate capacity for several years.
  
- Companies have been using larger design teams, making engineers work longer hours, etc., but clearly the limit is being reached.



# Why Must HDL Tools & IP Reuse?



## Design productivity crisis:

Divergence of potential design complexity  
and designer productivity



# HDL and Moore's Law

- ❖ HDL – Hardware Description Language
- ❖ Why use an HDL?
  - ❖ Unify design entries.
  - ❖ Easy for synthesis:
    - Hardware is becoming very difficult (and too big!) to design directly
    - HDL is easier and cheaper to explore different design options
    - Reduce time and cost to verify your digital designs in VLSI implementations



# Verilog HDL

## ❖ Feature

- ❖ HDL has high-level programming language constructs and constructs to describe the connectivity of your circuit.
- ❖ Ability to mix different levels of abstraction freely
- ❖ One language for all aspects of design, test, and verification
- ❖ Functionality as well as timing
- ❖ Concurrency perform target functions
- ❖ Support timing simulation for your design



# Behavioral Model





# Verilog HDL in Different Design Domains





# Digital IC Design Flow for Better Design Productivity





# **FPGA Prototyping as Design Verification**



# Cost & Time-to-Market

- ❖ Leading-edge digital system designs are becoming more expensive and time-consuming
  - ❖ Increasing cost of mask sets and the amount of engineering verification required.
  - ❖ Very difficult for a company to react nimbly to competitive pressures or evolving standards.



Declining Product Sales Due to Late-to-Market Designs The Cost of Chip Development



# Cost & Time-to-Market

- ❖ Leading-edge digital system designs are becoming more expensive and time-consuming
  - ❖ Increasing cost of mask sets and the amount of engineering verification required.
  - ❖ Very difficult for a company to react nimbly to competitive pressures or evolving standards.

## Design Time-to-Market



**Money & Time**

FOUNDRY  
up to 3 months  
for each Rev



***Getting your design “right the first time” is more and more imperative !!!***



# FPGA Prototyping

- ❖ Using an FPGA to prototype an digital system for verification has now become standard practice to:
  - ❖ Both decrease development time and reduce the risk of first silicon failure.
  - ❖ Faster “**emulation**” speed
  - ❖ Realistic system environment
  - ❖ System (HW/SW) development platform

Design process for developing a product with an FPGA  
and converting the FPGA to an ASIC for production.



## Design Time-to-Market





# Verification Platform





# FPGA Design Flow

