# Digital Design and Computer Architecture

Danny Camenisch (dcamenisch)

 $March\ 11,\ 2021$ 

# Contents

| 1        | Ten  | aplate 2                       | 2 |
|----------|------|--------------------------------|---|
|          | 1.1  | tcolorbox                      | 2 |
|          | 1.2  | minted                         | 2 |
| <b>2</b> | Intr | roduction                      | 3 |
|          | 2.1  | Description                    | 3 |
| 3        | Bas  | ics                            | 4 |
|          | 3.1  | Definitions                    | 4 |
|          | 3.2  | Design and Choices             |   |
|          | 3.3  | Representing Numbers           |   |
|          | 3.4  | Logic Gates                    |   |
|          | 3.5  | Beneath the Abstraction        |   |
| 4        | Cor  | nbination Logic Design         | 9 |
|          | 4.1  | Introduction                   | 9 |
|          | 4.2  | Boolean Algebra                | Э |
|          |      | 4.2.1 Axioms and Theorems      |   |
|          | 4.3  | From Logic to Gates            |   |
|          | 4.4  | Multilevel Combinational Logic |   |
|          | 4.5  | Illegal and Floating Values    |   |
|          | 4.6  | Karnaugh Maps                  |   |
|          | 4.7  | Combinational Building Blocks  |   |
|          |      | 4.7.1 Multiplexer (mux)        |   |
|          |      | 4.7.2 Decoders                 |   |
|          | 4.8  | Timing                         |   |

# Template

#### 1.1 tcolorbox

## Definition

Definition...

#### Lemma

Lemma...

#### Satz von Danny

Satz...

#### My Heading

This is a **tcolorbox**.

Here, you see the lower part of the box.

subtitle

## 1.2 minted

```
// Hello.java
import javax.swing.JApplet;
import java.awt.Graphics;

public class Hello extends JApplet {
    public void paintComponent(Graphics g) {
        g.drawString("Hello, world!", 65, 95);
    }
}
```

## Introduction

## 2.1 Description

The class provides a first introduction to the design of digital circuits and computer architecture. It covers technical foundations of how a computing platform is designed from the bottom up. It introduces various execution paradigms, hardware description languages, and principles in digital design and computer architecture. The focus is on fundamental techniques employed in the design of modern microprocessors and their hardware/software interface.

#### Overview

This class provides a first approach to Computer Architecture. The students learn the design of digital circuits in order to:

- understand the basics
- understand the principles of design
- understand the precedents in computer architecture

Based on such understanding, the students are expected to:

- learn how a modern computer works underneath, from the bottom up
- evaluate tradeoffs of different designs and ideas
- implement a principled design (a simple microprocessor)
- learn to systematically debug increasingly complex systems
- hopefully be prepared to develop novel, out-of-the-box designs

The focus is on basics, principles, precedents, and how to use them to create/implement good designs.

## **Basics**

#### 3.1 Definitions

In this script we will use the terms '1', TRUE and HIGH synonymously. Similarly, we will use '0', FALSE and LOW. Further we will use two's complement for signed binary numbers.

## 3.2 Design and Choices

Microprocessors where and still are a fundamental building block for the technological progess in the past three decades. Without them things like the Internet and cell phones would not exist. But for the development of new chips performance is not always the main priority. While performance is important, there is always a tradeoff between many different other aspects, including power consumption, temperature price and size, only to mention some of them.

Systems like a microprocessor can get really complicated to understand on a low level. To get a better understanding of such a system, it is necessary to use different techniques:

- Abstraction: hiding details when they are not important
- Disciplin: intentionally restricting design choices so that you can work more productively at a higher level of abstraction
- Hierarchy, Modularity, Regularity: defining a clear structure dividing a system into well-defined modules and reusing them among multiple points

Microarchitecture links the logic and architecture levels of abstraction. This will be the main focuse of this course.



Figure 3.1: Levels of abstraction for a electronic computing system

### 3.3 Representing Numbers

There are three commonly used systems to represent numbers. We normally use decimal numbers, but in digital systems binary and hexadecimal numbers are more convienient. It is assumed that the reader is familiary with using these number systems and knows how to perform simple operations in them. When dealing with addition one has to be carefull to check for overflow of the carry bit.

#### **Important Terms**

- **Bit**: A single 0 or 1
- Byte: A group of eight bits, can be represented by two hexadecimal digit
- Nibble: Half a byte, can be represented by one hexadecimal digit
- Word: Data chunks a microprocessor handels, today 64 or 32 bit
- LSB: least significant bit, right-most bit in a group of bits
- MSB: most significant bit, left-most bit in a group of bits

There are multiple ways to represent a negative number in the binary system. The two most common ones are called sign/magnitude and two's complement.

**Sign/Magnitude**: We use the MSB as a sign bit, this causes the problems that addition will no longer work and there exists both +0 and -0. This covers the range  $[-2^{N-1}+1,2^{N-1}-1]$ .

**Two's Complement:** Same system as a unsigned binary number except the MSB has a weight of  $-2^{N-1}$ . Here addition works fine and there is only one representation for 0. The process of creating a negative number consists of inverting all the bits of the number and adding 1 to the LSB. This covers the range  $[-2^{N-1}, 2^{N-1} - 1]$ .

### 3.4 Logic Gates

Logic Gates are simple digital circuits that take one or more binary inputs (denoted by letters from the beginning of the alphabet) and produce a binary output (commonly denoted Y). The most common logic gates are:



Figure 3.2: Most important logic gates

Note that a N-input XOR produces a TRUE output when an odd number of inputs are TRUE. From a logical point of view, a buffer might seem useless. However, from the analog point of view, the buffer has multiple, desirable characteristics such as the ability to quickly send its output to many gates. The logic operations can be denoted as follows:

$$\begin{array}{ll} \text{BUFFER} & Y = A \\ \text{NOT} & Y = \overline{A} \\ \text{AND} & Y = A \cdot B = AB = A \cap B \\ \text{OR} & Y = A + B = A \cup B \\ \text{XOR} & Y = A \oplus B \\ \text{NAND} & Y = \overline{AB} \\ \text{NOR} & Y = \overline{A + B} \\ \text{XNOR} & Y = \overline{A \oplus B} \end{array}$$

There also exist logic gates with more than two inputs.

#### 3.5 Beneath the Abstraction

**Supply Voltage:** In reality, binary signals are represented with a voltage on a wire. The lowest voltage in a system (0 V) is called the ground GND and the highest is denotes as  $V_{DD}$  (between 1.2 and 3.3 V).

**Noise:** Since in reality this signal is analog and could theoretically have every value between GND and  $V_{DD}$  it could be that we encounter noise. We can use a trick to filter such noise and get a clear signal. The noise margin is the amount of noise we can add to

a signal and it can still be correctly interpreted. In this example we look at two simple logic gates, a driver and receiver. The noise margin is calculated  $NM_L = V_{IL} - V_{OL}$ ,  $NM_H = V_{OH} - V_{IH}$ .



Figure 3.3: Example

**CMOS Transistors:** We skip the detailed explanation of how a transistor works and look at what it does. A transistor can be viewed as a electrically controlled switch that turns ON or OFF when a voltage is applied to a controll terminal. The most common transistors are MOS transistors (or MOSFET). There are two types nMOS and pMOS.



Figure 3.4: MOS transistors

**Logic Gates:** We can use transistor to build logic gates, as an example we will have a look at how a AND gate is built. A AND gate consists of a NAND gate and a NOT gate, that are made up by transistors as can be seen in the figure.



Figure 3.5: MOS transistors

# Combination Logic Design

#### 4.1 Introduction

A circuit is a network that processes distinct-value variables. It has:

- one or more input terminals
- one or more output terminals
- a functional specification (expressed by a truth table)
- a timing specification

Digital circuits are classified as **sequential** or **combinational** (this chapter will discuss the later one). The difference between these two is, that a combinational circuit combines the current input values to compute the output, whereas in a sequential circuit, the output depends on the current input and on the previous input values. In another way, a combinational circuit is **memoryless** and a sequential circuit has **memory**.

Combination circuit therefore have to satisfie the following requirements:

- every circuit (element) is itself combinational
- every wire (node) of the circuit is either designated as input or output
- the circuit contains no cyclic paths

## 4.2 Boolean Algebra

#### Definition

- $\bullet$  Complement The inverse of a variable,  $\bar{A}$
- Literal A variable in a equation
- **Product** The AND of two or more literals
- Minterm The product of all inputs (or their complement) of a function
- $\bullet$   $\mathbf{Sum}$  The OR of two or more literals
- Maxterm The sum of all inverse of inputs (or their complement) of a function
- Precedence The order of operations: NOT ¿ AND ¿ OR
- $\bullet$   $\mathbf{Sum}$  of  $\mathbf{product}$  form The sum of all minterms for which a function is true
- **Prime implication** An implicant that cannot be combined with other implicants to for a new implicant with fewer literals

#### 4.2.1 Axioms and Theorems

|    | Axiom                           |     | Dual               | Name         |
|----|---------------------------------|-----|--------------------|--------------|
| A1 | $B = 0$ if $B \neq 1$           | A1′ | $B=1$ if $B\neq 0$ | Binary field |
| A2 | $\overline{0} = 1$              | A2′ | $\overline{1} = 0$ | NOT          |
| A3 | $0 \bullet 0 = 0$               | A3′ | 1 + 1 = 1          | AND/OR       |
| A4 | 1 • 1 = 1                       | A4′ | 0 + 0 = 0          | AND/OR       |
| A5 | $0 \bullet 1 = 1 \bullet 0 = 0$ | A5′ | 1 + 0 = 0 + 1 = 1  | AND/OR       |

Figure 4.1: Axioms

|    | Theorem                      |                               | Dual                   | Name         |
|----|------------------------------|-------------------------------|------------------------|--------------|
| T1 | $B \bullet 1 = B$            | T1′                           | B+0=B                  | Identity     |
| T2 | $B \bullet 0 = 0$            | T2′                           | B + 1 = 1              | Null Element |
| Т3 | $B \bullet B = B$            | T3′                           | B+B=B                  | Idempotency  |
| T4 |                              | $\overline{\overline{B}} = B$ |                        | Involution   |
| T5 | $B \bullet \overline{B} = 0$ | T5′                           | $B + \overline{B} = 1$ | Complements  |

Figure 4.2: Theorems

|     | Theorem                                                                                                   |      | Dual                                                                                 | Name                   |
|-----|-----------------------------------------------------------------------------------------------------------|------|--------------------------------------------------------------------------------------|------------------------|
| Т6  | $B \bullet C = C \bullet B$                                                                               | T6′  | B+C=C+B                                                                              | Commutativity          |
| T7  | $(B \bullet C) \bullet D = B \bullet (C \bullet D)$                                                       | T7′  | (B+C)+D=B+(C+D)                                                                      | Associativity          |
| Т8  | $(B \bullet C) + (B \bullet D) = B \bullet (C + D)$                                                       | T8′  | $(B+C) \bullet (B+D) = B + (C \bullet D)$                                            | Distributivity         |
| Т9  | $B \bullet (B+C) = B$                                                                                     | T9′  | $B + (B \bullet C) = B$                                                              | Covering               |
| T10 | $(B \bullet C) + (B \bullet \overline{C}) = B$                                                            | T10' | $(B+C)  \bullet  (B+\overline{C}) = B$                                               | Combining              |
| T11 | $(B \bullet C) + (\overline{B} \bullet D) + (C \bullet D)$<br>= $B \bullet C + \overline{B} \bullet D$    | T11′ | $(B+C) \bullet (\overline{B}+D) \bullet (C+D)$<br>= $(B+C) \bullet (\overline{B}+D)$ | Consensus              |
| T12 | $\overline{B_0 \bullet B_1 \bullet B_2 \dots} = (\overline{B_0 + \overline{B}_1 + \overline{B}_2 \dots})$ | T12′ | $\overline{B_0 + B_1 + B_2 \dots} = (\overline{B_0 \bullet B_1 \bullet B_2} \dots)$  | De Morgan's<br>Theorem |

Figure 4.3: Theorems for multiple variables

We can use these helpful theorems to reduce boolean equations into prime implicants.

## 4.3 From Logic to Gates

When drawing a **schemantic** we generally follow these rules:

- Inputs are on the left / top side
- Ouputs are on the right / bottom side
- Gates should flow from left to right
- Straight wires are better
- Wires always connect at a T Junction
- Wires crossing without a dot make no connection

To draw such a schemantic it can be usefull to first draw a truth table. In a truth table a X marks a don't care.

## 4.4 Multilevel Combinational Logic

In this section we will shortly mention bubble pushing as a helpful way to redraw combinational circuits so that bubbles cancel out and the function can be more easily determined. (More details can be found in the book)

## 4.5 Illegal and Floating Values

The symbol X indicates that the circuit node has an **unknown** or **illegal** value, this commonly happens if a node is being driven both by a 0 and a 1 at the same time. This situation is also called **contention**. Be carefull to not mistake this X with a don't care in truth tables.

The symbol Z denotes that a node is being driven neither by HIGH nor LOW. The node is said to be **floating**, **heigh impedance** or **high Z**. In reality, a floating node might be 0 or 1 or something in between.

### 4.6 Karnaugh Maps

Karnaugh Maps are a usefull graphical method for simplifying Boolean equations. They work well for equations with up to four variables.



Figure 4.4: A Karnaugh Maps

Note that the AB combinations are in Gray code.



Figure 4.5: A Karnaugh Maps

We use the following rules to minimize a expression using a K-map:

- Us the fewest circles necessary to cover all 1's
- A circle can only contain 1's
- Each circle must span a rectangular block that is a power of 2 in each direction
- Each circle should be as large as possible
- A circle may wrap around the edge of the K-map
- A 1 in a K-map may be circled multiple times

## 4.7 Combinational Building Blocks

Combinational Logic is often grouped into larger building blocks to build more complex systems. This is an application fo the principle of abstraction. Some of these building blocks are full adders, priority circuits and seven-segment display decoders. In this section we will look at another two building blocks.

#### 4.7.1 Multiplexer (mux)

Multiplexers (short mux) are among the most commonly used combinational circuits. They choose an output among several possible inputs based on the value of a select signal. A 2:1 mux chooses between 2 different input signals.



Figure 4.6: 4:1 mux implementations

### 4.7.2 Decoders

A decoder has n inputs and  $2^n$  outputs. It asserts exactly one of its outputs depending on the input combination. The output of a decoder are called **one-hot**, because exactly one of them is hot at a given time.



Figure 4.7: 2:4 decoder

### 4.8 Timing

An output takes time to change in response to a change of input. We can draw a **timing diagram** to visialize the transient response of a combinational circuit. The transition from LOW to HIGH is called the **rising edge** and from HIGH to LOW it's called the **falling edge**.



Figure 4.8: timing diagram of a buffer

Combinational logic is characterized by its **propagation delay**  $t_{pd}$ , the maximum time from when a input changes until the output reaches their final state, and the **contamination delay**  $t_{cd}$ , the minimum time from an input change until the output starts changing.

Since  $t_{pd}$  and  $t_{cd}$  are determined by signal paths in a combinational circuit, we introduce the following two definitions:

- Critical path The longest and therefore slowest path in a circuit
- Short path The shortest and therefore fastest path through a circuit

We can now calculate the  $t_{pd}$  by adding up the propagation time for each element along the critical path, and similarly calculate the  $t_{cp}$  by adding all propagation times along the short path.