

# Lecture 1 - Introduction

---



ET3233 - Digital Systems Design

Geeth Karunarathne

# Module Outline

---

1. Hardware Description Languages
2. RTL Based System Design
3. RISC Architecture
4. Processor Design
5. Memory Design
6. Design of an ALU
7. Asynchronous Sequential System Design

# Digital Logic

---

1 and 0

# Boolean Algebra - Axioms

---

$$(A1) \quad X = 0 \quad \text{If } X \neq 1$$

$$(A2) \quad \text{If } X = 0, \text{ then } X' = 1$$

$$(A3) \quad 0 \cdot 0 = 0$$

$$(A4) \quad 1 \cdot 1 = 1$$

$$(A5) \quad 0 \cdot 1 = 1 \cdot 0 = 0$$

$$(A1') \quad X = 1 \quad \text{If } X \neq 0$$

$$(A2') \quad \text{If } X = 1, \text{ then } X' = 0$$

$$(A3') \quad 1 + 1 = 1$$

$$(A4') \quad 0 + 0 = 0$$

$$(A5') \quad 1 + 0 = 0 + 1 = 1$$

# Single Variable Theorems

---

$$(T1) \quad X + 0 = X$$

$$(T1') \quad X \cdot 1 = X$$

(Identities)

$$(T2) \quad X + 1 = 1$$

$$(T2') \quad X \cdot 0 = 0$$

(Null elements)

$$(T3) \quad X + X = X$$

$$(T3') \quad X \cdot X = X$$

(Idempotency)

$$(T4) \quad (X')' = X$$

(Involution)

$$(T5) \quad X + X' = 1$$

$$(T5') \quad X \cdot X' = 0$$

(Complements)

\*All the above theorems involves Boolean rules related to a single variable “ $X$ ”, hence called single variable theorems.

# Multiple Variable Theorems

---

|       |                                                               |        |                                                                 |                  |
|-------|---------------------------------------------------------------|--------|-----------------------------------------------------------------|------------------|
| (T6)  | $X + Y = Y + X$                                               | (T6')  | $X \cdot Y = Y \cdot X$                                         | (Commutativity)  |
| (T7)  | $(X + Y) + Z = X + (Y + Z)$                                   | (T7')  | $(X \cdot Y) \cdot Z = X \cdot (Y \cdot Z)$                     | (Associativity)  |
| (T8)  | $X \cdot Y + X \cdot Z = X \cdot (Y + Z)$                     | (T8')  | $(X + Y) \cdot (X + Z) = X + Y \cdot Z$                         | (Distributivity) |
| (T9)  | $X + X \cdot Y = X$                                           | (T9')  | $X \cdot (X + Y) = X$                                           | (Covering)       |
| (T10) | $X \cdot Y + X \cdot Y' = X$                                  | (T10') | $(X + Y) \cdot (X + Y') = X$                                    | (Combining)      |
| (T11) | $X \cdot Y + X' \cdot Z + Y \cdot Z = X \cdot Y + X' \cdot Z$ | (T11') | $(X + Y) \cdot (X' + Z) \cdot (Y + Z) = (X + Y) \cdot (X' + Z)$ | (Consensus)      |

- \* Above theorems involves Boolean rules related to two or three variables, hence called multiple variable theorems.

# Transistor Fabrication

---

## D Transistor fabrication in silicon chips

Traditional Planar Transistor



22 nm Tri-Gate Transistor





# How are microchips made?

From sand to semiconductors

# Transistor as a Switch

D NOR gate implementation using transistors.

| B | A | OUT |
|---|---|-----|
| 0 | 0 | 1   |
| 0 | 1 | 0   |
| 1 | 0 | 0   |
| 1 | 1 | 0   |



# Logic Circuit Design

---

## Combinational Logic

Output is only a function of the current inputs.

They are stateless.

## Sequential Logic

The output of Sequential logic circuits depends on BOTH current inputs and previous inputs.

Sequential Logic circuits have memory due to this property.

# Logic Circuit Design

---

## Combinational Logic

Output is only a function of the current inputs.

They are stateless.



$$\text{Output} = F(\text{Inputs})$$



$$Y = F(A, B, C)$$

# Logic Circuit Design

---



## Sequential Logic

The output of Sequential logic circuits depends on BOTH current inputs and previous inputs.

Sequential Logic circuits have memory due to this property.

# Combinational Logic Examples

---

- D Enabling Circuits
- D Encoder
- D Decoder
- D Multiplexer
- D Demultiplexer
- D Comparator
- D Adder/ Subtractor

# Multiplexer (MUX)

---

- D Combinational circuit that selects binary data from one of many input lines to the output line.
- D Multiplexer is also known as Data Selector.



# 2 to 1 Multiplexer



Truth Table

| S | F |
|---|---|
| 0 | A |
| 1 | B |

Abbreviated Truth Table  
Inputs A,B listed in output column



# Full Adder

Truth Table

| C <sub>IN</sub> | X | Y | C <sub>OUT</sub> | S |
|-----------------|---|---|------------------|---|
| 0               | 0 | 0 | 0                | 0 |
| 0               | 0 | 1 | 0                | 1 |
| 0               | 1 | 0 | 0                | 1 |
| 0               | 1 | 1 | 1                | 0 |
| 1               | 0 | 0 | 0                | 1 |
| 1               | 0 | 1 | 1                | 0 |
| 1               | 1 | 0 | 1                | 0 |
| 1               | 1 | 1 | 1                | 1 |



Full adder: (a) gate level circuit diagram; (b) logic symbol;  
(c) alternate logic symbol suitable for cascading.

# Ripple Carry Adder

- D Several full adders could be cascaded to make a ripple carry adder.
  - Four Bit Ripple Carry Adder



# Sequential Logic Examples

---

- D Latches
- D Flip Flops
- D Counters
- D Registers

# Latches - D Latch



(a) circuit design using NAND gates

| C | D | Q      | QN      |
|---|---|--------|---------|
| 1 | 0 | 0      | 1       |
| 1 | 1 | 1      | 0       |
| 0 | x | last Q | last QN |

(b) function table



(c) logic symbol



Functional behavior of a D latch for various inputs.

# Flip Flops - D Flip Flop

Positive-edge-triggered D flip-flop:



(a) circuit design using D latches

| D | CLK | Q      | QN      |
|---|-----|--------|---------|
| 0 | 0   | 0      | 1       |
| 1 | 1   | 1      | 0       |
| x | 0   | last Q | last QN |
| x | 1   | last Q | last QN |

(b) function table



(c) logic symbol



# Divide by 2 Counter

---

- D The divide by two counter is the simplest counter which can only count up to 1 before it resets.
- D This counter could also be used as a frequency divider which divide the input frequency by 2.



# 3-bit Ripple Counter

- D A  $n$ -bit ripple counter could count up to a maximum of  $2^n - 1$ .
- D The 3-bit ripple counter can count up to 7.



# Serial-in to Parallel-out (SIPO) Shift Register



# Serial-in to Parallel-out (SIPO) Shift Register ctd..

| Clock Pulse No | QA | QB | QC | QD |
|----------------|----|----|----|----|
| 0              | 0  | 0  | 0  | 0  |
| 1              | 1  | 0  | 0  | 0  |
| 2              | 0  | 1  | 0  | 0  |
| 3              | 0  | 0  | 1  | 0  |
| 4              | 0  | 0  | 0  | 1  |
| 5              | 0  | 0  | 0  | 0  |



# Recall: Transistor Fabrication

---

## D Transistor fabrication in silicon chips

Traditional Planar Transistor



22 nm Tri-Gate Transistor



# Transistor Implementation of Logic Circuits

---

- D Transistors could be used to create simple circuits which implement logic gates.
- D Logic gates are connected together to build simple logic circuits which will perform specific tasks such as:
  - Multiplexers
  - Decoders
  - Flip flops
  - Counters
  - Registers



# Microprocessor

D Microprocessor has only a CPU, inside them one or few Integrated Circuits.

D It does not have RAM, ROM and other peripherals.

D Microprocessors are not made for specific task but they are required where tasks are complex and tricky



# 4-bit CPU



MP-4 CPU Complete diagram by M.K.PEKER 14 May 2017



# Processor Manufacturing

---

# FPGA

- D An FPGA is an **array of logic gates**, and this array can be **configured in the field**.
- D It consists of a set of **Configurable Logic Blocks** and **Switching Blocks**.



---

# Thank You!

---