

# CS 110

## Computer Architecture

### Lecture 8:

### *Synchronous Digital Systems*

Instructors:

Sören Schwertfeger & Chundong Wang

<https://robotics.shanghaitech.edu.cn/courses/ca/20s/>

School of Information Science and Technology SIST

ShanghaiTech University

Slides based on UC Berkley's CS61C

# Levels of Representation/Interpretation



$\text{temp} = v[k];$   
 $v[k] = v[k+1];$   
 $v[k+1] = \text{temp};$

lw xt0, 0(x2)  
lw xt1, 4(x2)  
sw xt1, 0(x2)  
sw xt0, 4(x2)

0000 1001 1100 0110 1010 1111 0101 1000  
1010 1111 0101 1000 0000 1001 1100 0110  
1100 0110 1010 1111 0101 1000 0000 1001  
0101 1000 0000 1001 1100 0110 1010 1111



# You are Here!

## Software

## Hardware

- Parallel Requests  
Assigned to computer  
e.g., Search “Katz”
- Parallel Threads  
Assigned to core  
e.g., Lookup, Ads
- Parallel Instructions  
>1 instruction @ one time  
e.g., 5 pipelined instructions
- Parallel Data  
>1 data item @ one time  
e.g., Add of 4 pairs of words
- Hardware descriptions  
All gates @ one time
- Programming Languages

*Harness  
Parallelism &  
Achieve High  
Performance*

Warehouse  
Scale  
Computer



Smart  
Phone



Computer



Today

Logic Gates

# Hardware Design

- Next several weeks: how a modern processor is built, starting with basic elements as building blocks
- Why study hardware design?
  - Understand capabilities and limitations of HW in general and processors in particular
  - What processors can do fast and what they can't do fast (avoid slow things if you want your code to run fast!)
  - Background for more in-depth HW courses
  - Hard to know what you'll need for next 30 years
  - There is only so much you can do with standard processors: you may need to design own custom HW for extra performance
    - Even some commercial processors today have customizable hardware!
    - E.g. Google Tensor Processing Unit (TPU)

# Synchronous Digital Systems

*Hardware of a processor, such as the RISC-V, is an example of a Synchronous Digital System*

*Synchronous:*

- All operations coordinated by a central clock
  - “Heartbeat” of the system!

*Digital:*

- Represent all values by discrete values
- Two binary digits: 1 and 0
- Electrical signals are treated as 1's and 0's
  - 1 and 0 are complements of each other
- High /low voltage for true / false, 1 / 0

# Switches: Basic Element of Physical Implementations

- Implementing a simple circuit (arrow shows action if wire changes to “1” or is *asserted*):



*On*-switch (if A is “1” or asserted)  
turns-on light bulb (Z)



*Off*-switch (if A is “0” or  
unasserted) turns-off light  
bulb (Z)

$$Z \equiv A$$

# Switches (cont'd)

- Compose switches into more complex ones (Boolean functions):

AND



$Z \equiv A \text{ and } B$

OR



$Z \equiv A \text{ or } B$

# Historical Note

- Early computer designers built ad hoc circuits from switches
- Began to notice common patterns in their work: ANDs, ORs, ...
- Master's thesis (by Claude Shannon, 1940) made link between work and 19<sup>th</sup> Century Mathematician George Boole
  - Called it “Boolean” in his honor
- Could apply math to give theory to hardware design, minimization, ...



# Transistors

- High voltage ( $V_{dd}$ ) represents 1, or true
  - In modern microprocessors,  $V_{dd} \sim 1.0$  Volt
- Low voltage (0 Volt or Ground) represents 0, or false
- Pick a midpoint voltage to decide if a 0 or a 1
  - Voltage greater than midpoint = 1
  - Voltage less than midpoint = 0
  - This removes noise as signals propagate – a big advantage of digital systems over analog systems
- If one switch can control another switch, we can build a computer!
- Our switches: CMOS transistors

# CMOS Transistor Networks

- Modern digital systems designed in CMOS
  - MOS: Metal-Oxide on Semiconductor
  - C for complementary: use *pairs* of normally-on and normally-off switches
- CMOS transistors act as voltage-controlled switches
  - Similar, though easier to work with, than electro-mechanical relay switches from earlier era
  - Use energy primarily when switching

# CMOS Transistors



- Three terminals: source, gate, and drain

- Switch action:

if voltage on gate terminal is (some amount) higher/lower than source terminal then conducting path established between drain and source terminals (switch is closed)



*n-channel transistor*

**off** when voltage at Gate is low

**on** when:

voltage (Gate) > voltage (Threshold)

(**High** resistance when gate voltage **Low**, **Low** resistance when gate voltage **High**)



*p-channel transistor*

**on** when voltage at Gate is low

**off** when:

voltage (Gate) > voltage (Threshold)

(**Low** resistance when gate voltage **Low**, **High** resistance when gate voltage **High**)

Field-Effect Transistor (FET) => CMOS circuits use a combination of p-type and n-type metal-oxide-semiconductor field-effect transistors =>  
MOSFET

MOSFET scaling  
(process nodes)

10  $\mu\text{m}$  – 1971  
6  $\mu\text{m}$  – 1974  
3  $\mu\text{m}$  – 1977  
1.5  $\mu\text{m}$  – 1981  
1  $\mu\text{m}$  – 1984  
800 nm – 1987  
600 nm – 1990  
350 nm – 1993  
250 nm – 1996  
180 nm – 1999  
130 nm – 2001  
90 nm – 2003  
65 nm – 2005  
45 nm – 2007  
32 nm – 2009  
22 nm – 2012  
14 nm – 2014  
10 nm – 2016  
7 nm – 2018  
5 nm – ~2020

Future

3 nm – ~2021  
2 nm – ~2024

# MOSFET Operation



## The Transistor



- |                  |          |
|------------------|----------|
| ■ N type silicon | ■ Source |
| ■ P type silicon | ■ Drain  |
| ◆ Electrons      | ■ Gate   |



# #2: Moore's Law

# of transistors on an integrated circuit (IC)



Predicts:  
2X Transistors / chip  
every 2 years

Modern microprocessor chips  
include several billion transistors



Gordon Moore  
Intel Cofounder

Year

# Intel 14nm Technology

1 nm = 1 / 1,000,000,000 m; wavelength visible light: 400 – 700 nm



A FinFET (fin field-effect transistor), a type of multi-gate MOSFET.



Plan view of transistors



Side view of wiring layers

# Sense of Scale



Mark  
1.66 m

Fly  
7 mm

Mite  
300 um

Blood Cell  
7 um

Virus  
100 nm

Silicon Atom  
0.24 nm



$1 \text{ nm} = 1 / 1,000,000,000 \text{ m}$ ; wavelength visible light: 400 – 700 nm

**14nm about 58 Silicon Atoms ...**

Source: Mark Bohr, IDF14

# CMOS Circuit Rules

- Don't pass weak values => Use Complementary Pairs
  - N-type transistors pass weak 1's ( $V_{dd} - V_{th}$ )
  - N-type transistors pass strong 0's (ground)
  - Use N-type transistors only to pass 0's (N for negative)
  - Converse for P-type transistors: Pass weak 0s, strong 1s
    - Pass weak 0's ( $V_{th}$ ), strong 1's ( $V_{dd}$ )
    - Use P-type transistors only to pass 1's (P for positive)
  - Use pairs of N-type and P-type to get strong values
- Never leave a wire undriven
  - Make sure there's always a path to  $V_{dd}$  or GND
- Never create a path from  $V_{dd}$  to GND (ground)
  - This would short-circuit the power supply!

# CMOS Networks

*p-channel transistor*

on when voltage at Gate is low

off when:

voltage(Gate) > voltage (Threshold)



what is the relationship between x and y?

| X            | Y            |
|--------------|--------------|
| 0 Volt (GND) | 1 Volt (Vdd) |
| 1 Volt (Vdd) | 0 Volt (GND) |

*n-channel transistor*

off when voltage at Gate is low

on when:

voltage(Gate) > voltage (Threshold)

Called an *inverter* or *not gate*

# Two-Input Networks



what is the  
relationship between x, y and z?

| X      | Y      | Z      |
|--------|--------|--------|
| 0 Volt | 0 Volt | 1 Volt |
| 0 Volt | 1 Volt | 1 Volt |
| 1 Volt | 0 Volt | 1 Volt |
| 1 Volt | 1 Volt | 0 Volt |

Called a *NAND gate*  
*(NOT AND)*



# Question



| X      | Y      | Z |   |       |
|--------|--------|---|---|-------|
| A      | B      | C | D | Volts |
| 0 Volt | 0 Volt | 0 | 1 | Volts |
| 0 Volt | 1 Volt | 1 | 1 | Volts |
| 1 Volt | 0 Volt | 0 | 1 | Volts |
| 1 Volt | 1 Volt | 1 | 0 | Volts |



# Combinational Logic Symbols

- Common combinational logic systems have standard symbols called logic gates

- Buffer, NOT



- AND, NAND



- OR, NOR



Inverting versions (NOT, NAND, NOR) easiest to implement with CMOS transistors (the switches we have available and use most)

Remember...

- AND

- OR

# Boolean Algebra

- Use plus “+” for OR
  - “logical sum”  $1+0 = 0+1 = 1$  (True);  $1+1=2$  (True);  $0+0 = 0$  (False)
- Use product for AND ( $a \bullet b$  or implied via  $ab$ )
  - “logical product”  $0*0 = 0*1 = 1*0 = 0$  (False);  $1*1 = 1$  (True)
- “Hat” to mean complement (NOT)

- Thus

$$ab + a + \bar{c}$$

$$= a \bullet b + a + \bar{c}$$

= (a AND b) OR a OR (NOT c )



# Truth Tables for Combinational Logic



Exhaustive list of the output value  
generated for each combination of inputs

How many logic functions can be defined  
with  $N$  inputs?

| a | b | c | d | y            |
|---|---|---|---|--------------|
| 0 | 0 | 0 | 0 | $F(0,0,0,0)$ |
| 0 | 0 | 0 | 1 | $F(0,0,0,1)$ |
| 0 | 0 | 1 | 0 | $F(0,0,1,0)$ |
| 0 | 0 | 1 | 1 | $F(0,0,1,1)$ |
| 0 | 1 | 0 | 0 | $F(0,1,0,0)$ |
| 0 | 1 | 0 | 1 | $F(0,1,0,1)$ |
| 0 | 1 | 1 | 0 | $F(0,1,1,0)$ |
| 0 | 1 | 1 | 1 | $F(0,1,1,1)$ |
| 1 | 0 | 0 | 0 | $F(1,0,0,0)$ |
| 1 | 0 | 0 | 1 | $F(1,0,0,1)$ |
| 1 | 0 | 1 | 0 | $F(1,0,1,0)$ |
| 1 | 0 | 1 | 1 | $F(1,0,1,1)$ |
| 1 | 1 | 0 | 0 | $F(1,1,0,0)$ |
| 1 | 1 | 0 | 1 | $F(1,1,0,1)$ |
| 1 | 1 | 1 | 0 | $F(1,1,1,0)$ |
| 1 | 1 | 1 | 1 | $F(1,1,1,1)$ |

# Truth Table Example #1:

$y = F(a,b)$ : 1 iff  $a \neq b$

| <b>a</b> | <b>b</b> | <b>y</b> |
|----------|----------|----------|
| 0        | 0        | 0        |
| 0        | 1        | 1        |
| 1        | 0        | 1        |
| 1        | 1        | 0        |

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

# Truth Table Example #2: 2-bit Adder



How  
Many  
Rows?

| A        | B        | C           |
|----------|----------|-------------|
| $a_1a_0$ | $b_1b_0$ | $c_2c_1c_0$ |
| 00       | 00       | 000         |
| 00       | 01       | 001         |
| 00       | 10       | 010         |
| 00       | 11       | 011         |
| 01       | 00       | 001         |
| 01       | 01       | 010         |
| 01       | 10       | 011         |
| 01       | 11       | 100         |
| 10       | 00       | 010         |
| 10       | 01       | 011         |
| 10       | 10       | 100         |
| 10       | 11       | 101         |
| 11       | 00       | 011         |
| 11       | 01       | 100         |
| 11       | 10       | 101         |
| 11       | 11       | 110         |

# Truth Table Example #3: 32-bit Unsigned Adder

| A         | B         | C          |
|-----------|-----------|------------|
| 000 ... 0 | 000 ... 0 | 000 ... 00 |
| 000 ... 0 | 000 ... 1 | 000 ... 01 |
| .         | .         | .          |
| .         | .         | .          |
| .         | .         | .          |
| .         | .         | .          |
| 111 ... 1 | 111 ... 1 | 111 ... 10 |

How  
Many  
Rows?

# Truth Table Example #4: 3-input Majority Circuit

$$Y = \overline{A}BC + A\overline{B}C + AB\overline{C} + ABC$$

This is called *Sum of Products* form;  
Just another way to represent the TT  
as a logical expression

$$Y = BC + A(\overline{B}C + B\overline{C})$$

$$Y = BC + A(B \oplus C)$$

More simplified forms  
(fewer gates and wires)

| a | b | c | y |
|---|---|---|---|
| 0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 0 |
| 0 | 1 | 0 | 0 |
| 0 | 1 | 1 | 1 |
| 1 | 0 | 0 | 0 |
| 1 | 0 | 1 | 1 |
| 1 | 1 | 0 | 1 |
| 1 | 1 | 1 | 1 |

# Boolean Algebra: Circuit & Algebraic Simplification



original circuit

$$y = ((ab) + a) + c$$

equation derived from original circuit

$$\begin{aligned} &= ab + a + c \\ &= a(b + 1) + c \\ &= a(1) + c \\ &= a + c \end{aligned}$$

algebraic simplification



simplified circuit

# Representations of Combinational Logic (groups of logic gates)



# Laws of Boolean Algebra

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

$$X 0 = 0$$

$$X 1 = X$$

$$X X = X$$

$$X Y = Y X$$

$$(X Y) Z = X (Y Z)$$

$$X (Y + Z) = X Y + X Z$$

$$X Y + X = X$$

$$\bar{X} Y + X = X + Y$$

$$\overline{XY} = \bar{X} + \bar{Y}$$

$$X + \bar{X} = 1$$

$$X + 1 = 1$$

$$X + 0 = X$$

$$X + X = X$$

$$X + Y = Y + X$$

$$(X + Y) + Z = X + (Y + Z)$$

$$X + Y Z = (X + Y) (X + Z)$$

$$(X + Y) X = X$$

$$(\bar{X} + Y) X = X Y$$

$$\overline{X + Y} = \bar{X} \bar{Y}$$

Complementarity

Laws of 0's and 1's

Identities

Idempotent Laws

Commutativity

Associativity

Distribution

Uniting Theorem

Uniting Theorem v. 2

DeMorgan's Law

# Boolean Algebraic Simplification Example

$$\begin{aligned}y &= ab + a + c \\&= a(b + 1) + c \quad \textit{distribution, identity} \\&= a(1) + c \quad \textit{law of 1's} \\&= a + c \quad \textit{identity}\end{aligned}$$

| a | b | c | y |
|---|---|---|---|
| 0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 1 |
| 0 | 1 | 0 | 0 |
| 0 | 1 | 1 | 1 |
| 1 | 0 | 0 | 1 |
| 1 | 0 | 1 | 1 |
| 1 | 1 | 0 | 1 |
| 1 | 1 | 1 | 1 |

CS 110

Computer Architecture

Lecture 8:

*Synchronous Digital Systems*

*Video 2: Clock*

Instructors:

Sören Schwertfeger & Chundong Wang

<https://robotics.shanghaitech.edu.cn/courses/ca/20s/>

School of Information Science and Technology SIST

ShanghaiTech University

Slides based on UC Berkley's CS61C

# Signals and Waveforms



# Signals and Waveforms: Grouping

$x_3 \ x_2 \ x_1 \ x_0$

↑ voltage

→ time



# Signals and Waveforms: Circuit Delay



$$A = [a_3, a_2, a_1, a_0]$$

$$B = [b_3, b_2, b_1, b_0]$$

$$A \xrightarrow{4} = \begin{matrix} a_0 \\ a_1 \\ a_2 \\ a_3 \end{matrix} \longrightarrow$$



# Sample Debugging Waveform



# Type of Circuits

- *Synchronous Digital Systems* consist of two basic types of circuits:
  - Combinational Logic (CL) circuits
    - Output is a function of the inputs only, not the history of its execution
    - E.g., circuits to add A, B (ALUs)
  - Sequential Logic (SL)
    - Circuits that “remember” or store information
    - aka “State Elements”
    - E.g., memories and registers (Registers)

# Uses for State Elements

- Place to store values for later re-use:
  - Register files (like x1-x31 in RISC-V)
  - Memory (caches and main memory)
- *Help control flow of information between combinational logic blocks*
  - State elements hold up the movement of information at input to combinational logic blocks to allow for orderly passage

# Accumulator Example

Why do we need to control the flow of information?



Want:

$$\begin{aligned} S &= 0; \\ \text{for } &(i=0; i < n; i++) \\ S &= S + X_i \end{aligned}$$

Assume:

- Each  $X$  value is applied in succession, one per cycle
- After  $n$  cycles the sum is present on  $S$

# First Try: Does this work?



No!

Reason #1: How to control the next iteration of the 'for' loop?

Reason #2: How do we say: 'S=0'?

# Second Try: How About This?



Register is used to hold up the transfer of data to adder

Rounded Rectangle per clock means could be 1 or 0  
Square wave clock sets when things change

Rough timing ...

High (1)  
Low (0)

LOAD/CLK

High (1)  
Low (0)

$S$

High (1)  
Low (0)

$X$

Time



# Register Internals



- $n$  instances of a “Flip-Flop”
- Flip-flop name because the output flips and flops between 0 and 1
- D is “data input”, Q is “data output”
- Also called “D-type Flip-Flop”

# Hardware Timing Terms

- **Setup Time:** when the input must be stable *before* the edge of the CLK
- **Hold Time:** when the input must be stable *after* the edge of the CLK
- **“CLK-to-Q” Delay:** how long it takes the output to change, measured from the edge of the CLK

# Maximum Clock Frequency

- What is the maximum frequency of this circuit?



Hint:  
Frequency = 1/Period

$$\text{Max Delay} = \text{Setup Time} + \text{CLK-to-Q Delay} + \text{CL Delay}$$

# And in Conclusion, ...

- Multiple Hardware Representations
  - Analog voltages quantized to represent logic 0 and logic 1
  - Transistor switches form gates: AND, OR, NOT, NAND, NOR
  - Truth table mapped to gates for combinational logic design
  - Boolean algebra for gate minimization
- Combinatorial Logic & Sequential Logic
  - Combinatorial Logic: no memory: stateless
  - Sequential Logic: state information => memory
  - Clocks synchronize Register change (Setup; Hold time; CLK-to-Q Delay)

# Question

Piazza: "Lecture 8 Video Poll"

- Assert (select) the statements that are true:
  - A. The Hold Time is essential to calculating the Max Delay of a circuit.
  - B. Modern Processors use a lower  $V_{dd}$ , because it allows a higher clock frequency
  - C. Sequential Logic has elements that store information
  - D. A Register is a memory element in a CPU