

# Lecture 2: CMOS Logic

*Based on material prepared by prof. Visvesh S. Sathe*

# Acknowledgements

All class materials (lectures, assignments, etc.) based on material prepared by Prof. Visvesh S. Sathe, and reproduced with his permission



Visvesh S. Sathe  
Associate Professor  
Georgia Institute of Technology

<https://psylab.ece.uw.edu>



UW (2013-2022)  
GaTech (2022-present)

# Course Announcements

- By now, you should have
  - Make sure you can access the linux labs and have a directory for this class
  - Set up VNC connection
- Reservations for ECE 357:
  - Monday to Thursday: 2:00 pm to 5:00 pm
  - Friday: 11:30 am to 1:30 pm (*Kevin's office hours*)
  - Saturday and Sunday: 9:00 am to 1:00 pm
  - **You're welcome to work there during any other time as well,** but there is no priority reservation.

## Transistors as switches: CMOS inverter



$$V_A \geq V_{thm}$$

$$V_A = V_{dd} = 1V \quad \text{on}$$

$$V_A > 0 \quad \text{off}$$



$$V_B \leq V_{dd} - V_{thp} \quad \text{on}$$

$$V_B = 1V \quad \text{off}$$

$$V_B \leq 0V \quad \text{on}$$

## Quick aside: NMOS logic





$$V_Z(t=0) = 0.5V$$



# CMOS logic

$$F = (\bar{A} + \bar{B})\bar{C}$$

$$F = \overline{AB} + C$$

$$F = \overline{AB} + \overline{C}$$



- Implement logic by connecting output to 1 ( $V_{dd}$ ) or 0 ( $V_{ss}$ )
  - Connect output Z to  $V_{dd}$  if function evaluates to '1'
  - Relay network connecting  $V_{dd}$  to Z referred to as the pull-up network (PUN)
  - Connect Z to  $V_{ss}$  if function evaluates to '0'
  - Relay network connecting  $V_{ss}$  to Z referred to as the pull-down network (PDN)
  - →Z will not be connected to both  $V_{dd}$  and  $V_{ss}$ . PUN and PDN **complementary**
- Viewed as graphs, the networks are duals of each other

# CMOS logic

$$F = (\bar{A} + \bar{B})\bar{C}$$



$$F = \overline{AB+C}$$



$$\overline{AB+C}$$

$$(\bar{A} + \bar{B}) \bar{C}$$

- Implement logic by connecting output to 1 ( $V_{dd}$ ) or 0 ( $V_{ss}$ )
  - Connect output Z to  $V_{dd}$  if function evaluates to '1'
  - Relay network connecting  $V_{dd}$  to Z referred to as the pull-up network (PUN)
  - Connect Z to  $V_{ss}$  if function evaluates to '0'
  - Relay network connecting  $V_{ss}$  to Z referred to as the pull-down network (PDN)
  - → Z will not be connected to both  $V_{dd}$  and  $V_{ss}$ . PUN and PDN **complementary**
- Viewed as graphs, the networks are duals of each other

## CMOS logic



$$F = (\bar{A} + \bar{B})\bar{C}$$

$$F = \overline{AB+C}$$



$$\overline{AB+C} = 0$$

$$AB+C = 1$$

$$\overline{AB} = 0$$

$$\overline{AB} = 1$$

- Implement logic by connecting output to 1 ( $V_{dd}$ ) or 0 ( $V_{ss}$ )
  - Connect output Z to  $V_{dd}$  if function evaluates to '1'
  - Relay network connecting  $V_{dd}$  to Z referred to as the pull-up network (PUN)
  - Connect Z to  $V_{ss}$  if function evaluates to '0'
  - Relay network connecting  $V_{ss}$  to Z referred to as the pull-down network (PDN)
  - → Z will not be connected to both  $V_{dd}$  and  $V_{ss}$ . PUN and PDN **complementary**
- Viewed as graphs, the networks are duals of each other

# CMOS logic



- Implement logic by connecting output to 1 ( $V_{dd}$ ) or 0 ( $V_{ss}$ )
  - Connect output Z to  $V_{dd}$  if function evaluates to '1'
  - Relay network connecting  $V_{dd}$  to Z referred to as the pull-up network (PUN)
  - Connect Z to  $V_{ss}$  if function evaluates to '0'
  - Relay network connecting  $V_{ss}$  to Z referred to as the pull-down network (PDN)
  - →Z will not be connected to both  $V_{dd}$  and  $V_{ss}$ . PUN and PDN **complementary**
- Viewed as graphs, the networks are duals of each other

# CMOS logic



- Implement logic by connecting output to 1 ( $V_{dd}$ ) or 0 ( $V_{ss}$ )
  - Connect output  $Z$  to  $V_{dd}$  if function evaluates to '1'
  - Relay network connecting  $V_{dd}$  to  $Z$  referred to as the pull-up network (PUN)
  - Connect  $Z$  to  $V_{ss}$  if function evaluates to '0'
  - Relay network connecting  $V_{ss}$  to  $Z$  referred to as the pull-down network (PDN)
  - →  $Z$  will not be connected to both  $V_{dd}$  and  $V_{ss}$ . PUN and PDN **complementary**
- Viewed as graphs, the networks are duals of each other

# CMOS logic



What happens if PUN  
and PDN are not duals  
of each other

- Implement logic by connecting output to 1 ( $V_{dd}$ ) or 0 ( $V_{ss}$ )
  - Connect output Z to  $V_{dd}$  if function evaluates to '1'
  - Relay network connecting  $V_{dd}$  to Z referred to as the pull-up network (PUN)
  - Connect Z to  $V_{ss}$  if function evaluates to '0'
  - Relay network connecting  $V_{ss}$  to Z referred to as the pull-down network (PDN)
  - →Z will not be connected to *both*  $V_{dd}$  and  $V_{ss}$ . PUN and PDN **complementary**
- Viewed as graphs, the networks are duals of each other

## CMOS logic

$$Z = \overline{AB}$$



- Using A,B,C,D as inputs, implement using CMOS Logic
  - $Z = \sim A$
  - $Z = \sim(A \& B)$
  - $Z = \sim(A \& B + C \& D)$

## CMOS logic



- Using A,B,C,D as inputs, implement using CMOS Logic
  - $Z = \sim A$
  - $Z = \sim(A \& B)$
  - $Z = \sim(A \& B + C \& D)$

## CMOS logic



- Using A,B,C,D as inputs, implement using CMOS Logic
  - $Z = \sim A$
  - $Z = \sim(A \& B) == \sim A \mid \sim B$
  - $Z = \sim(A \& B + C \& D)$

## CMOS logic



- Using A,B,C,D as inputs, implement using CMOS Logic
  - $Z = \sim A$
  - $Z = \sim(A \& B) == \sim A \mid \sim B$
  - $Z = \sim(A \& B + C \& D)$

## CMOS logic



- Using A,B,C,D as inputs, implement using CMOS Logic
  - $Z = \sim A$
  - $Z = \sim(A \& B) == \sim A \mid \sim B$
  - $Z = \sim(A \& B + C \& D)$

## A short note on the Threshold Voltage

- Story thus far:
  - NMOS conducts If  $V_{gate} > (V_{drain} \text{ or } V_{source})$
  - PMOS conducts if  $V_{gate} < (V_{drain} \text{ or } V_{source})$
- In Reality :  $V_{th}$  , the threshold voltage plays a role
  - An “overhead” cost that must be paid to enable device to conduct
  - NMOS conducts If  $V_{gate} - V_{th} > (V_{drain} \text{ or } V_{source})$
  - PMOS conducts if  $V_{gate} + V_{th} < (V_{drain} \text{ or } V_{source})$

## CMOS logic



- How about  $Z = (A \& B)$ 
  - NMOS “passes a 1” poorly, PMOS “passes a 0” poorly (More on this shortly)
    - NMOS gate must exceed source/drain by a threshold to conduct
    - PMOS gate must be lower than source/drain by a threshold to conduct
    - Recall discussion on current flow in relay networks
  - How do I get an AND gate then?



$$V_{GS} \geq V_{thn}$$

II

$$0.1V$$

$$V_Z = 0.9V$$

$$Z = \overline{A}^1 = A$$



$$Z = \overline{AB}$$



$$A = ? = \overline{B} / \overline{A} = 0$$



## CMOS logic



- How about  $Z = (A \& B)$ 
  - NMOS “passes a 1” poorly, PMOS “passes a 0” poorly (More on this shortly)
    - NMOS gate must exceed source/drain by a threshold to conduct
    - PMOS gate must be lower than source/drain by a threshold to conduct
    - Recall discussion on current flow in relay networks
  - How do I get an AND gate then?

## CMOS logic



- How about  $Z = (A \& B)$ 
  - NMOS “passes a 1” poorly, PMOS “passes a 0” poorly (More on this shortly)
    - NMOS gate must exceed source/drain by a threshold to conduct
    - PMOS gate must be lower than source/drain by a threshold to conduct
    - Recall discussion on current flow in relay networks
  - How do I get an AND gate then?  $Z = \sim (\sim(A \& B))$

## CMOS logic



- How about  $Z = (A \& B)$ 
  - NMOS “passes a 1” poorly, PMOS “passes a 0” poorly (More on this shortly)
    - NMOS gate must exceed source/drain by a threshold to conduct
    - PMOS gate must be lower than source/drain by a threshold to conduct
    - Recall discussion on current flow in relay networks
  - How do I get an AND gate then?  $Z = \sim (\sim(A \& B))$

# Quick Aside: Voltage swing range for Z



- What is the maximum voltage Z can reach (Ignoring leakage)
- What is the minimum voltage Z can reach (Ignoring leakage)

## Mux

- $Z = (S==1)? A:B$

- $Z = SA + \bar{S}B = \overline{SA + \bar{S}B} = \overline{(\bar{S} + \bar{A})(S + \bar{B})}$
- Use complimentary inputs (create  $\sim S$  if not available)



|    |         |         |
|----|---------|---------|
| If | $S = 0$ | $Y = B$ |
|    | $S = 1$ | $Y = A$ |





# Mux

- $Z = (S==1)? A:B$ 
  - $Z = SA + \bar{S}B = \overline{\overline{SA} + \overline{\bar{S}B}} = \overline{(\bar{S} + \bar{A})(S + \bar{B})}$
  - Use complimentary inputs (create  $\sim S$  if not available)
  - Ensure that both 1 and 0 are passed effectively



## Mux

- $Z = (S==1)? A:B$ 
  - $Z = SA + \bar{S}B = \overline{\overline{SA} + \overline{\bar{S}B}} = \overline{(\bar{S} + \bar{A})(S + \bar{B})}$
  - Use complimentary inputs (create  $\sim S$  if not available)
  - Ensure that both 1 and 0 are passed effectively



## Mux

- $Z = (S == 1) ? A : B$

- $Z = SA + \bar{S}B = \overline{SA + \bar{S}B} = \overline{(\bar{S} + A)(S + \bar{B})}$
- Use complimentary inputs (create  $\sim S$  if not available)
- Ensure that both 1 and 0 are passed effectively



|                            |                 |                 |
|----------------------------|-----------------|-----------------|
| $Z = 1$<br>$(\bar{Z} = 0)$ | $B = 1$ $S = 0$ | $B = 0$ $S = 0$ |
| $Z = 0$<br>$(\bar{Z} = 1)$ | $A = 1$ $S = 1$ | $A = 0$ $S = 1$ |

If  $(S = 0)$     $Z = B$   
If  $(S = 1)$     $Z = A$

# Mux

- $Z = (S==1)? A:B$

- $Z = SA + \bar{S}B = \overline{SA + \bar{S}B} = \overline{(\bar{S} + A)(S + \bar{B})}$
- Use complimentary inputs (create  $\sim S$  if not available)
- Ensure that both 1 and 0 are passed effectively



## Mux

- $Z = (S==1)? A:B$

- $Z = SA + \bar{S}B = \overline{\overline{S}A + \overline{S}B} = \overline{(\bar{S} + \bar{A})(S + \bar{B})}$
- Use complimentary inputs (create  $\sim S$  if not available)
- Ensure that both 1 and 0 are passed effectively



## N:1 Mux

- Any Boolean function can be built using Shannon's expansion theorem
- Two extreme approaches



$S_0 S_1$   
2 bit



$$Z = S_0 S_1 D_3 + \overline{S_0} S_1 D_2 + S_0 \overline{S_1} D_1 + \overline{S_0} \overline{S_1} D_0$$

## N:1 Mux

- Any Boolean function can be built using Shannon's expansion theorem
- Two extreme approaches



## N:1 Mux

- Any Boolean function can be built using Shannon's expansion theorem
- Two extreme approaches



## N:1 Mux

- Any Boolean function can be built using Shannon's expansion theorem
- Two extreme approaches



## N:1 Mux

- Any Boolean function can be built using Shannon's expansion theorem
- Two extreme approaches



## “Bubble” Propagation (De-Morgan’s Theorem)

$$\bar{\bar{X}} = X$$

$$\overline{AB}$$

$$\overline{AB} = \overline{A} + \overline{B}$$

$$\overline{A+B} = \overline{A} \cdot \overline{B}$$



$$Z = \overline{C} + \overline{D}$$

| A | B | Z | $\overline{Z}$ |
|---|---|---|----------------|
| 0 | 0 | 0 | 1              |
| 0 | 1 | 1 | 0              |
| 1 | 0 | 1 | 0              |
| 1 | 1 | 0 | 1              |



## “Bubble” Propagation (De-Morgan’s Theorem)

$$\bar{\bar{X}} = X$$



## “Bubble” Propagation (De-Morgan’s Theorem)

$$\bar{\bar{X}} = X$$



$$\overline{AB} = \bar{A} + \bar{B}$$

## “Bubble” Propagation (De-Morgan’s Theorem)

$$\bar{\bar{X}} = X$$



$$\overline{AB} = \bar{A} + \bar{B}$$



## “Bubble” Propagation (De-Morgan’s Theorem)

$$\bar{\bar{X}} = X$$



$$\overline{AB} = \bar{A} + \bar{B}$$



$$\overline{A + B} = \bar{A} \cdot \bar{B}$$

## “Bubble” Propagation (De-Morgan’s Theorem)

$$\bar{\bar{X}} = X$$



$$\overline{AB} = \bar{A} + \bar{B}$$



$$\overline{A + B} = \bar{A} \cdot \bar{B}$$



## Break-out



$\approx$



# Break-out



# Break-out



# Break-out



## Sum of Products....



- Boolean functions often represented as sum of products
  - E.g.  $F = A\bar{C} + \bar{B}C + AD$

## Sum of Products....



- Boolean functions often represented as sum of products
  - E.g.  $F = A\bar{C} + \bar{B}C + AD$

## ....or Product of Sums



- For boolean functions often represented as product of sums
  - E.g.  $F = (A + \bar{C})(\bar{B} + C)(A + D)$

# Retaining state: Latches and Flip-flops

## Retaining state: Latches and Flip-flops



$$EN = 1$$

$$\begin{aligned} Q &= D \\ \bar{Q} &= \bar{D} \end{aligned}$$

$$EN = 0$$

$EN$   
 $D$   
 $\bar{Q}$



- Logic-level (or state) storage is important for Digital Systems
- Capacitance on Q allows charge (state) storage

## Retaining state: Latches and Flip-flops



- Logic-level (or state) storage is important for Digital Systems
- Capacitance on Q allows charge (state) storage

## Retaining state: Latches and Flip-flops



- Logic-level (or state) storage is important for Digital Systems
- Capacitance on Q allows charge (state) storage

## Retaining state: Latches and Flip-flops



- Logic-level (or state) storage is important for Digital Systems
- Capacitance on Q allows charge (state) storage

## Retaining state: Latches and Flip-flops



- Logic-level (or state) storage is important for Digital Systems
- Capacitance on Q allows charge (state) storage

## Retaining state: Latches and Flip-flops



- Logic-level (or state) storage is important for Digital Systems
- Capacitance on Q allows charge (state) storage
- Avoid fight
  - Select D to drive Q if  $En = 1$
  - Select  $Q_x$  to drive Q if  $En = 0$

## Retaining state: Latches and Flip-flops



- Logic-level (or state) storage is important for Digital Systems
- Capacitance on  $Q$  allows charge (state) storage
- Avoid fight
  - Select  $D$  to drive  $Q$  if  $En = 1$
  - Select  $Q_x$  to drive  $Q$  if  $En = 0$

## Latch: Basic Structure and Operation



$\text{En} = 1$

$\text{En} = 0$

$Q = D$

$Q = \bar{Q}$

$Q$  retains state (value)

- Latch written when  $\text{En}=1$
- Holds state if  $\text{En}=0$
- “Level-sensitive” timing element
- Latch “transparent” when  $\text{En}=1$ , opaque when  $\text{En}=0$





1)



2)

3)



# Flip Flop



- Edge-triggered timing element (“clocked instead of enabled”)
- Sample on the rising or falling edge of clock

## Pseudo NMOS: An alternative?



- Pseudo NMOS logic
  - Use resistive load with NMOS PDN

## Pseudo NMOS: An alternative?



- Pseudo NMOS logic
  - Use resistive load with NMOS PDN

## Pseudo NMOS: An alternative?



- Pseudo NMOS logic
  - Use resistive load with NMOS PDN

What does  $V_{out}$  vs.  $V_{in}$  look like for this gate





| Logic | Voltage  |
|-------|----------|
| 0     | 0 V      |
| 1     | $V_{dd}$ |



$$V_o = \frac{V_{dd} \cdot R_T}{R_T + R_L}$$

## Pseudo NMOS: An alternative?



- Pseudo NMOS logic
  - Use resistive load with NMOS PDN
  - Challenges: Voltage swing, Power dissipation

What does  $V_{out}$  vs.  $V_{in}$  look like for this gate



## Pseudo NMOS: An alternative?



- Pseudo NMOS logic
  - Use resistive load with NMOS PDN
  - Challenges: Voltage swing, Power dissipation

What does  $V_{out}$  vs.  $V_{in}$  look like for this gate

# Performance, gate delay, and drive-strength



- Real world digital systems: M(B)illions of CMOS logic gates
  - Performance heavily depends on circuit speed
  - Logical function → Gate implementation → Physical implementation. What governs speed?

# Performance, gate delay, and drive-strength



- Real world digital systems: M(B)illions of CMOS logic gates
  - Performance heavily depends on circuit speed
  - Logical function → Gate implementation → Physical implementation. What governs speed?

# Performance, gate delay, and drive-strength



- Real world digital systems: M(B)illions of CMOS logic gates
  - Performance heavily depends on circuit speed
  - Logical function → Gate implementation → Physical implementation. What governs speed?

# The MOS Structure



- Metal Oxide Semiconductor
  - “Metal” implemented as poly-crystalline silicon (polysilicon) till recently
  - Conductor-insulator-semiconductor “sandwich”
  - Changing the voltage across Metal-Semiconductor varies the properties of the semiconductor

## Quick Detour: Parasitic Capacitance



### Impact

- Circuit Speed (Digital)
- Power (Digital)
- Bandwidth (Analog)
- Stability (Digital, Analog)

- What is capacitance exactly?
  - So what's so bad about it?
    - V-driven, not Q-driven
    - Low C → Lower Q, faster, lower energy
    - Smaller is faster (Dennard's law)
  - Major Parasitic contributors
    - MOSFET gates, MOSFET source/drain, wire

## Quick Detour: Parasitic Capacitance



- What is capacitance exactly?
  - So what's so bad about it?
    - V-driven, not Q-driven
    - Low C → Lower Q, faster, lower energy
    - Smaller is faster (Dennard's law)
  - Major Parasitic contributors
    - MOSFET gates, MOSFET source/drains, wire

### Impact

- Circuit Speed (Digital)
- Power (Digital)
- Bandwidth (Analog)
- Stability (Digital, Analog)

Calculate the per-unit length capacitance of an infinitely long cylindrical wire, diameter d in free space



## MOS Transistor – A 10K foot view



- Capacitor charge buildup allows for a “channel” to form
- Charge density not uniform → ? Impact on R. ? Impact on  $V(x)$
- How can I reduce the resistance of this device further?

## Reading/Study assignment

- Reading – 2.1, 2.2, 2.3.1
- Optional Reading – 2.3.\*, 2.4.\*
- Homework (**IMPORTANT**)
  1. What is the resistance of a cylindrical conductor (in the height direction) given its conductivity,  $\sigma$ , radius  $r$
  2. Review the MOS current equations in saturation and linear modes