# **CS3120 Introduction of Integrated Circuit Design**

# **Homework 2: Layout Design**

Due Date: 2024/11/17(Sun) 23:59:59

## **Background**

In VLSI circuit design, there are many fundamental building blocks, including memories, controllers, registers, and more. These modules are used to implement a wide range of complex functions. Layout methods and Electronic Design Automation (EDA) tools play crucial roles in helping designers transform circuit designs into manufactuable layouts. The physical arrangement directly impacts a circuit's performance, functionality, and reliability. As VLSI technology continues to advance, the demand for more sophisticated and power-efficient circuits grows. This places greater emphasis on optimizing not only the individual building blocks but also the overall system design. Additionally, the relentless pursuit of smaller chip sizes and lower manufacturing costs poses both challenges and opportunities for VLSI designers. A thoughtfully planned layout minimizes signal interference, reduces delays, and ensures efficient thermal management.

# **Description**

In practical scenarios, IC designs need to have the ability to drive specific load, and make sure the operation of the load will work successfully. However, it is difficult to drive a load for a single combinational circuit. In this layout assignment, you are asked to generate a 50% duty cycle by an XOR gate.

## • 3-input XOR gate

The XOR gate is widely used in digital circuits for addition, logical operations, and other functions. A 3-input XOR gate consists of 3 input channels, which are A, B, and C, and a output channel, S. When S = ABC + AB'C' + A'BC' + A'B'C, the output is 1. A XOR gate can be composed of inverters and transistors, or it can be designed with different layout strategies to optimize for specific parameters. In this assignment, we hope to use the form below to complete the multiplexer (Fig.1). The input should include the combinations of (A, B, C) = (0, 0, 0), (0, 0, 1), (0, 1, 0, 0), (0, 1, 1), (1, 0, 0), (1, 0, 1), (1, 1, 0) and (1, 1, 1) in sequence.



Fig. 1 3-input XOR gate

In the 3-input XOR gate, add a capacitance of 0.005 pF to the output S. Please make the power consumption as low as you can. We will make a comparison of the power consumption of all designs. The design with lower power consumption will get a higher grade.

## Limitations

Below are the guidelines that must be adhered to for this assignment. Any violation of these guidelines will result in 0 points for this HW.

#### **Environment setup and parameters**

- The naming and pinouts of each input and output must match the figures provided in this document.
- The operating voltage (VDD) is set to 1.8V. and the operating temperature is 30°C.
- In 3-input XOR gate, the capacitive of S is 0.005pF.
- For transistors, please set the L = 0.18um, while the minimum value of W is 0.25um and the value of W can be adjusted as needed.
- Only Metal 1 \ Metal 2 and Via can be used when routing.
- You must use the same approach as 'cic018.1' and 'cic18.tf' in HW2 to do this assignment; otherwise, you will get 0 points.

## **Inputs and outputs**

#### 3-input XOR gate:

- In the design of the 3-input XOR gate, the signals A, B, and C has a 50% duty cycle. A operates at 200 MHz, B at 100 MHz, and C at 50 MHz.
- The order of input combinations (A, B, C) should match the sequence mentioned

in this document.

- Set the rise/fall time of the input signals to 10ps.
- The highest logic level for all outputs must be greater than 0.9VDD, while the lowest logic level must be less than 0.1VDD.
- Delay1\_XOR represents the delay when the signal A and S are falling, while Delay2\_XOR represents the delay when the signal A and S are rising.

#### **Input files**

• spice\_layout.tar

## **Output files**

#### 3-input XOR gate

- hw2\_XOR.pex.netlist
- hw2\_XOR.pex.netlist.HW2\_XOR.pxi
- hw2\_XOR.pex.netlist.pex

#### **Coding style**

• Pre-simulation

## 3-input XOR gate

```
**StudentID HW2 XOR**
**Environment setting**
**Your code**
**Your design**
.subckt hw2 XOR A B C S VDD GND
**Your code**
.ends
**Main circuit**
Xhw2 XOR A B C S VDD GND hw2 XOR
C1 S GND 0.005p
**Input signal**
**Your code**
**Simulation setting**
.tran 0.01n 50n
.measure tran power AVG POWER
.meas tran Delay1 XOR
                                trig v(A) val=0.9 fall=4
                                 targ v(S) val=0.9 fall=3
trig v(A) val=0.9 rise=1
targ v(S) val=0.9 rise=1
.meas
       tran Delay2 XOR
.end
```

#### • Post-simulation

#### 3-input XOR gate

```
**StudentID HW2 XOR**
**Environment setting**
**Your code**
**Main circuit**
Xhw2_XOR A B C S VDD GND hw2_XOR
C1 S GND 0.005p
**Input signal**
**Your code**
**Simulation setting**
.tran 0.01n 50n
.measure tran power AVG POWER
                                     v(A) val=0.9 fall=4
                             trig
.meas tran Delay1_XOR
                              targ
                                     v(S)
                                             val=0.9 fall=3
                                     v (A)
                                             val=0.9 rise=1
.meas tran Delay2 XOR
                             trig
                              targ
                                     v(S)
                                             val=0.9 rise=1
end
```

## **Bonus**

Design 3-input XOR gate using pass transistors. Three inputs are A, B, and C; the output is S.

## Limitations

Below are the guidelines that must be adhered to for this assignment. Any violation of these guidelines will result in 0 points for this HW.

#### **Environment setup and parameters**

- The naming and pinouts of each input and output must match the figures provided in this document.
- In 3-input XOR gate, the capacitive of S is 0.005pF.
- For transistors, please set the L = 0.18um, while the minimum value of W is 0.25um and the value of W can be adjusted as needed.
- You must use the same approach as 'cic018.1' and 'cic18.tf' in HW2 to do this assignment; otherwise, you will get 0 points.

#### **Inputs and outputs**

- The signals A, B, and C exhibit a 50% duty cycle. A operates at 200 MHz, B at 100 MHz, and C at 50 MHz.
- Set the rise/fall time of the input signals to 10ps.
- The highest logic level for all outputs must be greater than 0.9VDD, while the lowest logic level must be less than 0.1VDD.
- Delay1\_XOR represents the delay when signals A and S are falling, while Delay2\_XOR represents the delay when signals A and S are rising.
- The power of the bonus circuit layout must be smaller than that of the 3-input XOR gate which is composed of whole transistors and inverters.

#### **Input files**

• spice\_layout.tar

#### **Output files**

- hw2\_bonus.pex.netlist
- hw2\_bonus.pex.netlist.HW2\_bonus.pxi
- hw2\_bonus.pex.netlist.pex

## **Coding style**

• Pre-simulation

```
*StudentID HW2 bonus**
**Environment setting**
**Your code**
**Your design**
.subckt hw2 bonus A B C S VDD GND
**Your code**
.ends
**Main circuit**
Xhw2 bonus A B C S VDD GND hw2 bonus
C1 S GND 0.005p
**Input signal**
**Your code**
**Simulation setting**
.tran 0.01n 50n
.measure tran power AVG POWER
                              trig v(A) val=0.9 fall=4
targ v(S) val=0.9 fall=3
.meas tran Delay1_XOR
.meas tran Delay2_XOR trig v(A) val=0.9 rise=1
                                              val=0.9 rise=1
                               targ v(S)
end
```

#### • Post-simulation

```
**StudentID_HW2_bonus**

**Environment setting**

**Your code**

**Main circuit**
Xhw2_bonus A B C S VDD GND hw2_bonus
C1 S GND 0.005p

**Input signal**

**Your code**

**Simulation setting**
.tran 0.01n 50n
.measure tran power AVG POWER
.meas tran Delay1_XOR trig v(A) val=0.9 fall=4
+ targ v(S) val=0.9 fall=3
.meas tran Delay2_XOR trig v(A) val=0.9 rise=1
+ targ v(S) val=0.9 rise=1
.end
```

# **Submission Requirement**

You have to submit a tar file named StudID\_HW2.tar (ex: 9862534\_HW2.tar). There are two folds in the tar file, HW2\_XOR and HW2\_bonus, and a report named StudID Name HW2 report.pdf (ex: 9862534 陳聿廣 HW2 report.pdf).

- 1. HW2\_XOR contains following files:
  - A pre-simulation file named pre XOR.sp
  - A post-simulation file named post XOR.sp
  - The DRC summary file named hw2 XOR.drc.summary
  - The LVS report file named hw2\_XOR.lvs.report
  - Three output files of PEX
    - hw2\_XOR.pex.netlist
    - > hw2\_XOR.pex.netlist.HW2 XOR.pxi
    - > hw2\_XOR.pex.netlist.pex
- 2. HW2 bonus contains following files:
  - A pre-simulation file named pre\_bonus.sp
  - A post-simulation file named post bonus.sp
  - The DRC summary file named hw2\_bonus.drc.summary
  - The LVS report file named hw2 bonus.lvs.report
  - Three output files of PEX
    - > hw2\_bonus.pex.netlist
    - hw2\_bonus.pex.netlist.HW2 bonus.pxi
    - > hw2\_bonus.pex.netlist.pex

Please upload it to ee-class with the original version. Note that the only acceptable report file format is .pdf, no .doc/.docx or other files are acceptable.

BE SURE to follow the naming rule mentioned above. Otherwise, your program will not be graded.

We don't restrict the report format and length. In your report, you must at least describe:

- 1. The circuit diagram of your design and explaining your design (You can use screenshots to explain)
- **2.** Pre-sim waveform
- 3. Screenshot of your layout
- **4.** Screenshot of DRC summary report

For example:



**5.** Screenshot of LVS report includes the message of passing LVS For example:



- **6.** Post-sim waveform
- 7. Screenshot of the post-simulation result

For example: 3-input XOR gate

**8.** Write down your delay and the difference in delay between rising and falling delay in the 3-input XOR gate.

- **9.** The hardness of this assignment and how you overcome it.
- **10.** Any suggestions about this programming assignment You can also put anything related to the PA in your report.

# **Grading**

The grading is as follows:

(1) Correctness: 40%

• Pre-sim: 10%

• DRC: 10%

• LVS: 10%

• Post-sim: 10%

(2) Performance: power, area 10%

(3) Readability of your spice code: 10%

(4) The report: 10%

(5) Demo session: 30%

(6) Bonus:10%

Please submit your assignment on time. Otherwise, the penalty rule will apply:

- Within 72hrs delay: 20% off
- More than 3 days: 0 point

Be sure to attend a demo session (the time will be announced later). If you have questions, please E-mail to both me (andyygchen@ee.ncu.edu.tw) and TA 張孫婕 (ting200011@gmail.com)