

MCC092  
Postlab lab 3 &  
prelab lab 4  
and a few other things

2017-09-28  
Lena Peterson

# Lab 3

- Do your design on paper first.
- Euler analysis is good - but there may be multiple solutions.
- Stick diagrams help.
  - If you must revise your solution do that on paper first!

# Improvements

- Add the info that is on the web in the memo, since many missed it.
- Even more clearly point out that you have to use ESC to deselect a tool.

# Euler path



Same topology in n-net and p-net.

Odd order nodes:  
Start/end in x/y  
and V<sub>DD</sub>/V<sub>SS</sub>

Which one to choose?

A & B poly lines must be connected

x/y diffusion areas must be connected with metal-1 wire since their node order is > 2

# Three Euler paths



# Best Euler path



Best solution(s):  
Keep x/y diffusion areas close  
to minimize wire lengths

Thus best solution(s):  
A B C B A  
A B C A B

# Prelab 4



# Prelab 4, calculations

## part I

- Each wire segment = one pi link
- First,  $R_{SH}=0$ , that is whole tree is one big capacitance
- Design a tapered buffer to drive this huge capacitance

# Prelab 4, calculations

## part 2

- Assume  $R_{SH} \neq 0$
- Calculate delay to leaves using Elmore model
- Collapsed tree helps!

# H-tree branching



# H-tree collapsing



# H-tree collapsing

Fold over once



And wire  
capacitances  
are added

# H-tree collapsing

Fold over twice



And wire  
capacitances  
are added again

# H-tree collapsing

Fold over thrice



And wire  
capacitances  
are added again

# Prelab 4, calculations

## part 3



# Prelab 4

- We will use Spectre with command-line input.
- Write the Spectre input file properly!
- Otherwise you have to spend valuable lab time doing that!
- Consultation time after class and tomorrow: Sept 29: 9-10 (Note! I may be a little late).

# Lab make-up session

- Monday Oct. 9 8.00-11.45.

# Adder lecture/exercises

- Tuesday October 3 13.15-15.00 in E-studion.
- Tuesday October 10 13.15-15.00 in E-studion.



Entry is from  
Hörsalsvägen

# Adder lecture/exercise preparation

- If you do not have access to the book download chapter 11 of W&H from [cmosvlsi.com](http://cmosvlsi.com). Use “Look inside” to the left.
- Read sections 11.2.1, 11.2.2 (for Oct. 3 up to 11.2.2.8 for Oct. 10 the rest of 11.2.2) Skip any optional parts.
- Find excel (either on Chalmers PC:s or download it on your own computer - see later slides).
- Download example file: `Excel_examples 2017.xlsx` and open in Excel. Three examples:
  1. 8-bit zero-detect circuit as ILA
  2. 8-bit comparator circuit as ILA
  3. 8 bit ripple-carry adder with negation

# Ripple-carry adder

Result from numbers

| 8-bit ripple-carry adder design with control signal for subtraction |                                |      |       |              |       |                                   |      |      |    |     |    |    |    |    |    |    |    |    |    |    |   |
|---------------------------------------------------------------------|--------------------------------|------|-------|--------------|-------|-----------------------------------|------|------|----|-----|----|----|----|----|----|----|----|----|----|----|---|
| 1                                                                   | A                              | B    | C     | D            | E     | F                                 | G    | H    | I  | J   | K  | L  | M  | N  | O  | P  | Q  | R  | S  | T  | U |
| 2                                                                   | 3                              | 4    | 5     | ADD/SUBTRACT | ADD=0 | CIN=?                             | A=   | 30   | 30 | 30  | 30 | 30 | 30 | 30 | 30 | 30 | 30 | 30 | 30 | 30 |   |
| 6                                                                   | CONTROL SIGNAL:                | 0    | SUB=1 | CIN=?        | B=    | 12                                | 12   | 12   | 12 | 12  | 12 | 12 | 12 | 12 | 12 | 12 | 12 | 12 | 12 | 12 |   |
| 7                                                                   | 0                              |      |       |              |       |                                   | SUM= | 42   | 42 | 42  | 42 | 42 | 42 | 42 | 42 | 42 | 42 | 42 | 42 |    |   |
| 8                                                                   | a7                             | b7   | a6    | b6           | a5    | b5                                | a4   | b4   | a3 | b3  | a2 | b2 | a1 | b1 | a0 | b0 |    |    |    |    |   |
| 9                                                                   | 0                              | 0    | 0     | 0            | 0     | 0                                 | 1    | 0    | 1  | 1   | 1  | 1  | 1  | 0  | 0  | 0  | 0  | 0  | 0  |    |   |
| 10                                                                  | 0                              | 0    | 0     | 0            | 0     | 0                                 | 1    | 0    | 1  | 1   | 1  | 1  | 1  | 0  | 0  | 0  | 0  | 0  | 0  |    |   |
| 11                                                                  | COUT<<<                        | 0    | 0     | 0            | 0     | 0                                 | 1    | 1    | 1  | 1   | 1  | 1  | 1  | 0  | 0  | 0  | 0  | 0  | 0  |    |   |
| 12                                                                  | 0                              | 0    | 1     | 0            | 1     | 0                                 | 0    | 1    | 0  | 1   | 0  | 1  | 1  | 0  | 0  | 0  | 0  | 0  | 0  |    |   |
| 13                                                                  | SUM7                           | SUM6 | SUM5  | SUM4         | SUM3  | SUM2                              | SUM1 | SUM0 |    |     |    |    |    |    |    |    |    |    |    |    |   |
| 14                                                                  | SUM converted back to decimal: |      |       |              | 42    | Both sums are equal?<br>OVERFLOW? |      |      |    | YES | NO |    |    |    |    |    |    |    |    |    |   |
| 15                                                                  |                                |      |       |              |       |                                   |      |      |    |     |    |    |    |    |    |    |    |    |    |    |   |
| 16                                                                  |                                |      |       |              |       |                                   |      |      |    |     |    |    |    |    |    |    |    |    |    |    |   |
| 17                                                                  |                                |      |       |              |       |                                   |      |      |    |     |    |    |    |    |    |    |    |    |    |    |   |

Result from adder

Equal results?

# Addition

# Expression for $C_{out0}$

# Subtraction

# Control signal

# Overflow

## Expression for $SUM_0$

Q12     $=\text{OR}(\text{AND}(Q10;R10;S11);\text{AND}(\text{NOT}(Q11);\text{OR}(Q10;R10;S11))) * 1$

8-bit ripple-carry adder design with control signal for subtraction

| ADD/SUBTRACT                   |      | CONTROL SIGNAL: |      | ADD=0                |      | CIN=0 |      | A= 30    |    | <<<<      |    | ENTER TWO NUMBERS |    |     |     |
|--------------------------------|------|-----------------|------|----------------------|------|-------|------|----------|----|-----------|----|-------------------|----|-----|-----|
|                                |      |                 |      | SUB=1                |      | CIN=1 |      | B= -127  |    | <<<<      |    | -128<NUMBER<128   |    |     |     |
|                                |      |                 |      | 0                    |      |       |      | SUM= 157 |    |           |    |                   |    |     |     |
| a7                             | b7   | a6              | b6   | a5                   | b5   | a4    | b4   | a3       | b3 | a2        | b2 | a1                | b1 | a0  | b0  |
| 0                              | 1    | 0               | 0    | 0                    | 0    | 1     | 0    | 1        | 0  | 1         | 0  | 1                 | 0  | 0   | 1   |
| 0                              | 0    | 0               | 1    | 0                    | 1    | 1     | 1    | 1        | 1  | 1         | 1  | 1                 | 1  | 0   | 0   |
| COUT<<<                        | 0    | 1               | 1    | 1                    | 1    | 1     | 1    | 1        | 1  | 1         | 1  | 0                 | 0  | 1   | CIN |
|                                | 1    | 0               | 0    | 1                    | 1    | 1     | 1    | 1        | 1  | 1         | 1  | 0                 | 1  |     | ↑   |
| SUM7                           | SUM6 | SUM5            | SUM4 | SUM3                 | SUM2 | SUM1  | SUM0 |          |    |           |    |                   |    |     |     |
| SUM converted back to decimal: | -99  |                 |      | Both sums are equal? |      |       |      | NO       |    | OVERFLOW? |    |                   |    | YES |     |

# How to download Office 365 on your own PC (I)

1. Go to: [https://outlook.com/  
net.chalmers.se](https://outlook.com/net.chalmers.se)

2. Click on the cogwheel, select  
“Office 365 settings”

3. Under “Software” click on  
“Install and manage software”



# How to download Office 365 on your own PC (2)

4. Download the installation program:

5. When you are asked to activate the license log in with [CID@net.chalmers.se](mailto:CID@net.chalmers.se)



Note! Only one installation per CID is allowed

# Question related to quiz: g and p for sequence of gates

- Our linear model for normalized delay:
  - $d = g \times h + p$
- p is constant part
- g part depends linearly on load capacitance:
  - $g \times h = g \times C_L/C_{in}$

# Exercise 8.2

## solutions from last week

a)



b)

$g_{NAND4} = 2$   
from layout:  
 $p_{NAND4} = 8/3$

# Problem 8.2 c)

Transistor sizes from layout:



$$g_{NAND4} = 2$$

$$g_{INV} = 1$$

$$p_{NAND4} = 8/3$$

$$p_{INV} = 1$$

$$C_{NAND4} = C + 2C$$

$$C_{INV} = 2C + C$$

$$\Rightarrow C_{INV} = C_{NAND4}$$

$$h_{NAND4} = 1$$

$$h_{INV} = C_L/C_{INV} = C_L/C_{NAND4}$$

$$d = 2 \times 1 + 8/3 + 1 \times C_L/C_{INV} + 1$$

$$d = 5 \frac{2}{3} + C_L/C_{INV}$$
 thus,  $p_{AND4} = 5 \frac{2}{3}$

$$d = 5 \frac{2}{3} + C_L/C_{NAND}$$
  $g_{AND4} = 1$

# What if we size inverter up by 2?



$$\begin{aligned} g_{\text{NAND4}} &= 2 & g_{\text{INV}} &= 1 \\ p_{\text{NAND4}} &= 8/3 & p_{\text{INV}} &= 1 \end{aligned}$$

New gate sizes:

$$\begin{aligned} C_{\text{NAND4}} &= 3C \\ C_{\text{inv}} &= 6C \\ \Rightarrow C_{\text{inv}} &= 2C_{\text{NAND4}} \\ h_{\text{NAND4}} &= 2 \\ h_{\text{inv}} &= C_L/C_{\text{inv}} = C_L/2C_{\text{NAND4}} \end{aligned}$$

Note (afterwards): the ratio  $C_{\text{inv}}/C_{\text{NAND4}}$  can also be expressed with X ratio: X4/X2 = 2 etc.

$$d = 2 \times 2 + 8/3 + 1 \times C_L/C_{\text{inv}} + 1$$

$$d = 7 \frac{2}{3} + C_L/C_{\text{inv}}$$

$$d = 7 \frac{2}{3} + C_L/2C_{\text{NAND}}$$

$$\text{thus, } p_{\text{AND4}} = 7 \frac{2}{3}$$

$$g_{\text{AND4}} = 1/2$$