## Computer Organization and Networks

(INB.06000UF, INB.07001UF)

#### Chapter 1 – Combinational Circuits

Winter 2023/2024



Stefan Mangard, www.iaik.tugraz.at

#### **Computation and Physics**

#### We Need to Map our Programs to Physics

$$1 + 1 = ?$$





Mechanics

Voltage

Current

Quantum Mechanics

• ...

### Examples of Computation Machines

#### Enigma

an electromechanical encryption machine



Museo della Scienza e della Tecnologia "Leonardo da Vinci" CC BY-SA

#### "British Bombe" by Alan Turing

An electromechanical machine to break Enigma



# We Need to Map our Programs to Physics

```
1 + 1 = ?
```

```
include <stdio.h>
int main()
{
         printf("Hello World");
         return 0;
}
```



IBM quantum computer (Lars Plougmann via flickr CC BY-SA 2.0)



Zuse Z1 (mechanical)
ComputerGeek via Wikipedia CC BY-SA 3.0



CMOS Processor (http://asic.ethz.ch)

# Complementary Metal-Oxide-Semiconductor (CMOS)

Invented at Bell Labs by Mohamed Atalla and Dawon Kahng in 1959

CMOS uses PMOS and NMOS transistors



 CMOS is the technology of almost all digital circuits (from contactless RFID chips to server CPUs

#### Two Types of Transistors

```
PMOS transistor: is conducting, if A is connected to GND

A—

NMOS transistor: is conducting, if A is connected to Vdd
```

- PMOS and NMOS transistors are essentially switches
  - PMOS:  $A=0 \rightarrow$  transistor conducting;  $A=1 \rightarrow$  transistor not conducting
  - NMOS:  $A=0 \rightarrow$  transistor not conducting;  $A=1 \rightarrow$  transistor conducting

How do we build a computer from these two types of transistors?

#### We Need Two Things From Transistors

#### Computation (Combinational Logic)

How to apply a function to input data to generate an output?

#### Storage (Sequential Logic)

How to store data and intermediate results of computations?

#### **Computation – Logic Gates**

#### The Big Picture



#### A Logic Gate – "The Smallest Functional Unit"



#### The Simplest Gate – A CMOS Inverter



| Α        | Q        |
|----------|----------|
| High (1) | Low (0)  |
| Low (0)  | High (1) |



### CMOS NAND gate



| А        | В        | Out      |
|----------|----------|----------|
| Low (0)  | Low (0)  | High (1) |
| Low (0)  | High (1) | High (1) |
| High (1) | Low (0)  | High (1) |
| High (1) | High (1) | Low (0)  |

#### CMOS Design Principle



Pull-Up and Pull-Down networks are complementary

-> given static inputs, the output is either pulled up or pulled down

Based on this principle, different logic gates can be built

### CMOS NOR gate

| А        | В        | Out      |
|----------|----------|----------|
| Low (0)  | Low (0)  | High (1) |
| Low (0)  | High (1) | Low (0)  |
| High (1) | Low (0)  | Low (0)  |
| High (1) | High (1) | Low (0)  |

## More Complex Gates

#### Building an AND Gate

- An AND gate cannot be built using a single pull-up/pull-down network
- It is built by a NAND gate followed by an inverter



| А        | В        | Out (Q)  |
|----------|----------|----------|
| Low (0)  | Low (0)  | Low (0)  |
| Low (0)  | High (1) | Low (0)  |
| High (1) | Low (0)  | Low (0)  |
| High (1) | High (1) | High (1) |

#### AND Gate



#### AND Gate



#### AND Gate



#### Cascading Gates





## The Mathematical View of a Combinational Circuit

• Combinational circuits (physical view) realize logic functions (mathematical view)

• With "function" we mean a mapping from a set of inputs to a set of outputs

• In mathematics, we typically express such a mapping as a function, e.g.:  $y = f(x) = x^2$ 

If you choose a value for x, you get a value for y. We call x the independent value and
y the dependent value

#### Logic Functions (or Boolean Functions)

- The "input" of a logic function is a tuple consisting of 0's and 1's
- The "output" of a logic function is, depending on the input values, 0 or 1

http://en.wikipedia.org/wiki/Boolean\_function

 $\mathbf{B}^k \to \mathbf{B}$ , where  $\mathbf{B} = \{0, 1\}$  is a <u>Boolean domain</u> and k is a non-negative integer called the <u>arity</u> of the function. In the case where k = 0, the "function" is essentially a constant element of **B**.

#### How can be describe Logic functions?

- A logic function defines how to map a number of binary inputs to an a binary ouput
- For some input combinations, the output will be 1
- For some input combinations, the output will be 0
- The most simply way of describing a logic function: make a table with all input combinations and define the output for each combination
  - → this is called truth table

#### Truth Table

- A truth table uniquely describes a logic function.
- Example: The logic-AND function with 2 input variables  $x_1$  and  $x_0$

| $x_1$ | $x_0$ | У |
|-------|-------|---|
| 0     | 0     | 0 |
| 0     | 1     | 0 |
| 1     | 0     | 0 |
| 1     | 1     | 1 |

$$y = f(x_1, x_0)$$





$$y = f(x_1, x_0)$$

List all combinations of input variables. It is convenient to list them in sorted order. We usually start with all zeroes.

## Input variables

| $x_1$ | $\mathbf{x}_{0}$ |  |
|-------|------------------|--|
| 0     | 0                |  |
| 0     | 1                |  |
| 1     | 0                |  |
| 1     | 1                |  |

$$y = f(x_1, x_0)$$

List all combinations of input variables. It is convenient to list them in sorted order. We usually start with all zeroes.

# Input variables Output

| $x_1$ | $X_0$ | У |
|-------|-------|---|
| 0     | 0     |   |
| 0     | 1     |   |
| 1     | 0     |   |
| 1     | 1     |   |

$$y = f(x_1, x_0)$$

List all combinations of input variables. It is convenient to list them in sorted order. We usually start with all zeroes.

## Input variables Output

| $X_1$ | $X_0$ | У      |
|-------|-------|--------|
| 0     | 0     | f(0,0) |
| 0     | 1     | f(0,1) |
| 1     | 0     | f(1,0) |
| 1     | 1     | f(1,1) |

| X | f(x) |
|---|------|
| 0 | f(0) |
| 1 | f(1) |

1 input variable

2<sup>1</sup> possible values for x



2 input variables

 $2^2$  possible combinations for (x1, x0)



#### 3 input variables

2<sup>3</sup> possible combinations for (x2, x1, x0)

n input variables

2<sup>n</sup> possible combinations

The size of a truth table grows exponentially with n.

→ Except for very simple functions, we will need a different way of describing logic functions

How many logic functions are possible?

• Let's start with logic functions with 1 input variable

#### How many logic functions are possible?

- Let's start with logic functions with 1 input variable
- There exist 4 possible different truth tables:

| X | У | X | У | X | У | X | У |
|---|---|---|---|---|---|---|---|
| 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 |
| 1 | 0 | 1 | 0 | 1 | 1 | 1 | 1 |

- Let's start with logic functions with 1 input variable
- There exist 4 possible different truth tables
- In the y-column we see all possible combinations

| X | У | X | У | X | У | X | У |
|---|---|---|---|---|---|---|---|
| 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 |
| 1 | 0 | 1 | 0 | 1 | 1 | 1 | 1 |

- Let's start with logic functions with 1 input variable
- There exist 4 possible different truth tables
- In the y-column we see all possible combinations

| X | $y_0$ | $y_1$ | <b>y</b> <sub>2</sub> | <b>y</b> <sub>3</sub> |
|---|-------|-------|-----------------------|-----------------------|
| 0 | 0     | 1     | 0                     | 1                     |
| 1 | 0     | 0     | 1                     | 1                     |

| $X_1$ | x <sub>o</sub> | <b>y</b> <sub>0</sub> | <b>y</b> <sub>1</sub> | <b>y</b> <sub>2</sub> | <b>y</b> <sub>3</sub> | <b>y</b> <sub>4</sub> | <b>y</b> <sub>5</sub> | <b>y</b> <sub>6</sub> | <b>y</b> <sub>7</sub> | <b>y</b> <sub>8</sub> | <b>y</b> <sub>9</sub> | <b>y</b> <sub>10</sub> | y <sub>11</sub> | <b>y</b> <sub>12</sub> | <b>y</b> <sub>13</sub> | <b>y</b> <sub>14</sub> | <b>y</b> <sub>15</sub> |
|-------|----------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|------------------------|-----------------|------------------------|------------------------|------------------------|------------------------|
| 0     | 0              | 0                     | 1                     | 0                     | 1                     | 0                     | 1                     | 0                     | 1                     | 0                     | 1                     | 0                      | 1               | 0                      | 1                      | 0                      | 1                      |
| 0     | 1              | 0                     | 0                     | 1                     | 1                     | 0                     | 0                     | 1                     | 1                     | 0                     | 0                     | 1                      | 1               | 0                      | 0                      | 1                      | 1                      |
|       |                |                       |                       |                       |                       |                       |                       |                       |                       |                       |                       | 0                      |                 |                        |                        |                        |                        |
| 1     | 1              | 0                     | 0                     | 0                     | 0                     | 0                     | 0                     | 0                     | 0                     | 1                     | 1                     | 1                      | 1               | 1                      | 1                      | 1                      | 1                      |







$$2^{2^n} = 2^{2^2} = 16$$

With 
$$n = 3, 4, ...$$

• n = 3,  $2^3$  = 8 lines,  $2^8$  = 256 functions

• n = 4,  $2^4$  = 16 lines,  $2^{16}$  = 65536 functions

• n = 5,  $2^5$  = 32 lines,  $2^{32}$  = 4294967296 functions

• n = 6,  $2^6$  = 64 lines,  $2^{64}$  = 18446744073709551616 functions

#### Back to n = 2

Some functions are "popular" and have names and symbols for corresponding logic gates

| <b>X</b> <sub>1</sub> | $X_0$ | <b>y</b> <sub>0</sub> | <b>y</b> <sub>1</sub> | <b>y</b> <sub>2</sub> | <b>У</b> 3 | <b>y</b> <sub>4</sub> | <b>y</b> <sub>5</sub> | <b>y</b> <sub>6</sub> | <b>y</b> <sub>7</sub> | <b>y</b> <sub>8</sub> | <b>y</b> 9 | <b>y</b> <sub>10</sub> | y <sub>11</sub> | <b>y</b> <sub>12</sub> | <b>y</b> <sub>13</sub> | y <sub>14</sub> | <b>y</b> <sub>15</sub> |
|-----------------------|-------|-----------------------|-----------------------|-----------------------|------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|------------|------------------------|-----------------|------------------------|------------------------|-----------------|------------------------|
| 0                     | 0     | 0                     | 1                     | 0                     | 1          | 0                     | 1                     | 0                     | 1                     | 0                     | 1          | 0                      | 1               | 0                      | 1                      | 0               | 1                      |
| 0                     | 1     | 0                     | 0                     | 1                     | 1          | 0                     | 0                     | 1                     | 1                     | 0                     | 0          | 1                      | 1               | 0                      | 0                      | 1               | 1                      |
|                       |       |                       |                       |                       |            |                       |                       |                       |                       |                       |            | 0                      |                 |                        |                        |                 |                        |
| 1                     | 1     | 0                     | 0                     | 0                     | 0          | 0                     | 0                     | 0                     | 0                     | 1                     | 1          | 1                      | 1               | 1                      | 1                      | 1               | 1                      |

**AND** 



| <b>X</b> <sub>1</sub> | $\mathbf{x}_{0}$ | <b>y</b> <sub>0</sub> | <b>y</b> <sub>1</sub> | <b>y</b> <sub>2</sub> | <b>y</b> <sub>3</sub> | <b>y</b> <sub>4</sub> | <b>y</b> <sub>5</sub> | <b>y</b> <sub>6</sub> | <b>y</b> <sub>7</sub> | <b>y</b> <sub>8</sub> | <b>y</b> <sub>9</sub> | y <sub>10</sub> | <b>y</b> <sub>11</sub> | y <sub>12</sub> | <b>y</b> <sub>13</sub> | <b>y</b> <sub>14</sub> | <b>y</b> <sub>15</sub> |
|-----------------------|------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------|------------------------|-----------------|------------------------|------------------------|------------------------|
| 0                     | 0                | 0                     | 1                     | 0                     | 1                     | 0                     | 1                     | 0                     | 1                     | 0                     | 1                     | 0               | 1                      | 0               | 1                      | 0                      | 1                      |
| 0                     | 1                | 0                     | 0                     | 1                     | 1                     | 0                     | 0                     | 1                     | 1                     | 0                     | 0                     | 1               | 1                      | 0               | 0                      | 1                      | 1                      |
| 1                     | 0                | 0                     | 0                     | 0                     | 0                     | 1                     | 1                     | 1                     | 1                     | 0                     | 0                     | 0               | 0                      | 1               | 1                      | 1                      | 1                      |
| 1                     | 1                | 0                     | 0                     | 0                     | 0                     | 0                     | 0                     | 0                     | 0                     | 1                     | 1                     | 1               | 1                      | 1               | 1                      | 1                      | 1                      |
|                       |                  |                       |                       |                       |                       |                       |                       |                       |                       | AND                   | ,                     |                 |                        |                 |                        | OR                     |                        |

| <b>X</b> <sub>1</sub> | $\mathbf{x}_{0}$ | <b>y</b> <sub>0</sub> | <b>y</b> <sub>1</sub> | <b>y</b> <sub>2</sub> | <b>y</b> <sub>3</sub> | <b>y</b> <sub>4</sub> | <b>y</b> <sub>5</sub> | <b>y</b> <sub>6</sub> | <b>y</b> <sub>7</sub> | <b>y</b> 8 | <b>y</b> 9 | <b>y</b> <sub>10</sub> | y <sub>11</sub> | y <sub>12</sub> | <b>y</b> <sub>13</sub> | <b>y</b> <sub>14</sub> | <b>y</b> <sub>15</sub> |
|-----------------------|------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|------------|------------|------------------------|-----------------|-----------------|------------------------|------------------------|------------------------|
| 0                     | 0                | 0                     | 1                     | 0                     | 1                     | 0                     | 1                     | 0                     | 1                     | 0          | 1          | 0                      | 1               | 0               | 1                      | 0                      | 1                      |
| 0                     | 1                | 0                     | 0                     | 1                     | 1                     | 0                     | 0                     | 1                     | 1                     | 0          | 0          | 1                      | 1               | 0               | 0                      | 1                      | 1                      |
| 1                     | 0                | 0                     | 0                     | 0                     | 0                     | 1                     | 1                     | 1                     | 1                     | 0          | 0          | 0                      | 0               | 1               | 1                      | 1                      | 1                      |
| 1                     | 1                | 0                     | 0                     | 0                     | 0                     | 0                     | 0                     | 0                     | 0                     | 1          | 1          | 1                      | 1               | 1               | 1                      | 1                      | 1                      |
|                       |                  |                       |                       |                       |                       |                       |                       | XOR                   |                       | AND        |            |                        |                 |                 |                        | OR                     |                        |





#### **NAND**

| <b>X</b> <sub>1</sub> | $\mathbf{x}_0$ | <b>y</b> <sub>0</sub> | <b>y</b> <sub>1</sub> | <b>y</b> <sub>2</sub> | у <sub>3</sub> | <b>y</b> <sub>4</sub> | <b>y</b> <sub>5</sub> | <b>y</b> <sub>6</sub> | <b>y</b> <sub>7</sub> | <b>y</b> 8 | <b>y</b> <sub>9</sub> | <b>y</b> <sub>10</sub> | y <sub>11</sub> | <b>y</b> <sub>12</sub> | <b>y</b> <sub>13</sub> | У <sub>14</sub> | <b>y</b> <sub>15</sub> |
|-----------------------|----------------|-----------------------|-----------------------|-----------------------|----------------|-----------------------|-----------------------|-----------------------|-----------------------|------------|-----------------------|------------------------|-----------------|------------------------|------------------------|-----------------|------------------------|
| 0                     | 0              | 0                     | 1                     | 0                     | 1              | 0                     | 1                     | 0                     | 1                     | 0          | 1                     | 0                      | 1               | 0                      | 1                      | 0               | 1                      |
| 0                     | 1              | 0                     | 0                     | 1                     | 1              | 0                     | 0                     | 1                     | 1                     | 0          | 0                     | 1                      | 1               | 0                      | 0                      | 1               | 1                      |
| 1                     | 0              | 0                     | 0                     | 0                     | 0              | 1                     | 1                     | 1                     | 1                     | 0          | 0                     | 0                      | 0               | 1                      | 1                      | 1               | 1                      |
| 1                     | 1              | 0                     | 0                     | 0                     | 0              | 0                     | 0                     | 0                     | 0                     | 1          | 1                     | 1                      | 1               | 1                      | 1                      | 1               | 1                      |
|                       |                |                       |                       |                       |                |                       |                       | XOR                   |                       | AND        | ,                     |                        |                 |                        |                        | OR              |                        |



|                       |       |                       | NOR                   |                       |                       |                       |                       | 1                     | VAND                  |                       |                       |                        |                 |                 |                        |                 |                        |
|-----------------------|-------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|------------------------|-----------------|-----------------|------------------------|-----------------|------------------------|
| <b>X</b> <sub>1</sub> | $x_0$ | <b>y</b> <sub>0</sub> | <b>y</b> <sub>1</sub> | <b>y</b> <sub>2</sub> | <b>y</b> <sub>3</sub> | <b>y</b> <sub>4</sub> | <b>y</b> <sub>5</sub> | <b>y</b> <sub>6</sub> | <b>y</b> <sub>7</sub> | <b>y</b> <sub>8</sub> | <b>y</b> <sub>9</sub> | <b>y</b> <sub>10</sub> | y <sub>11</sub> | y <sub>12</sub> | <b>y</b> <sub>13</sub> | y <sub>14</sub> | <b>y</b> <sub>15</sub> |
| 0                     | 0     | 0                     | 1                     | 0                     | 1                     | 0                     | 1                     | 0                     | 1                     | 0                     | 1                     | 0                      | 1               | 0               | 1                      | 0               | 1                      |
| 0                     | 1     | 0                     | 0                     | 1                     | 1                     | 0                     | 0                     | 1                     | 1                     | 0                     | 0                     | 1                      | 1               | 0               | 0                      | 1               | 1                      |
| 1                     | 0     | 0                     | 0                     | 0                     | 0                     | 1                     | 1                     | 1                     | 1                     | 0                     | 0                     | 0                      | 0               | 1               | 1                      | 1               | 1                      |
| 1                     | 1     | 0                     | 0                     | 0                     | 0                     | 0                     | 0                     | 0                     | 0                     | 1                     | 1                     | 1                      | 1               | 1               | 1                      | 1               | 1                      |
|                       |       |                       |                       |                       |                       |                       |                       | XOR                   |                       | AND                   |                       |                        |                 |                 |                        | OR              |                        |



|                       |                  |                       | VOR                   |                       |                       |                       |                       | ſ                     | NAND                  | )                     | XNO        | R                      |                 |                 |                        |                        |                        |
|-----------------------|------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|------------|------------------------|-----------------|-----------------|------------------------|------------------------|------------------------|
| <b>X</b> <sub>1</sub> | $\mathbf{x}_{0}$ | <b>y</b> <sub>0</sub> | <b>y</b> <sub>1</sub> | <b>y</b> <sub>2</sub> | <b>y</b> <sub>3</sub> | <b>y</b> <sub>4</sub> | <b>y</b> <sub>5</sub> | <b>y</b> <sub>6</sub> | <b>y</b> <sub>7</sub> | <b>y</b> <sub>8</sub> | <b>y</b> 9 | <b>y</b> <sub>10</sub> | y <sub>11</sub> | y <sub>12</sub> | <b>y</b> <sub>13</sub> | <b>y</b> <sub>14</sub> | <b>y</b> <sub>15</sub> |
| 0                     | 0                | 0                     | 1                     | 0                     | 1                     | 0                     | 1                     | 0                     | 1                     | 0                     | 1          | 0                      | 1               | 0               | 1                      | 0                      | 1                      |
| 0                     | 1                | 0                     | 0                     | 1                     | 1                     | 0                     | 0                     | 1                     | 1                     | 0                     | 0          | 1                      | 1               | 0               | 0                      | 1                      | 1                      |
| 1                     | 0                | 0                     | 0                     | 0                     | 0                     | 1                     | 1                     | 1                     | 1                     | 0                     | 0          | 0                      | 0               | 1               | 1                      | 1                      | 1                      |
| 1                     | 1                | 0                     | 0                     | 0                     | 0                     | 0                     | 0                     | 0                     | 0                     | 1                     | 1          | 1                      | 1               | 1               | 1                      | 1                      | 1                      |
|                       |                  |                       |                       |                       |                       |                       |                       | XOR                   |                       | AND                   |            |                        |                 |                 |                        | OR                     |                        |









#### Some functions are "almost trivial"

|       |                  |                       | NOR                   |                       |                       |                       |                       | 1                     | NAND                  |                       | XNOF       | ?                      |                 |                       |                 |                        |                 |
|-------|------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|------------|------------------------|-----------------|-----------------------|-----------------|------------------------|-----------------|
| $X_1$ | $\mathbf{x}_{0}$ | <b>y</b> <sub>0</sub> | <b>y</b> <sub>1</sub> | <b>y</b> <sub>2</sub> | <b>y</b> <sub>3</sub> | <b>y</b> <sub>4</sub> | <b>y</b> <sub>5</sub> | <b>y</b> <sub>6</sub> | <b>y</b> <sub>7</sub> | <b>y</b> <sub>8</sub> | <b>y</b> 9 | <b>y</b> <sub>10</sub> | y <sub>11</sub> | У <sub>12</sub>       | y <sub>13</sub> | <b>y</b> <sub>14</sub> | У <sub>15</sub> |
| 0     | 0                | 0                     | 1                     | 0                     | 1                     | 0                     | 1                     | 0                     | 1                     | 0                     | 1          | 0                      | 1               | 0                     | 1               | 0                      | 1               |
| 0     | 1                | 0                     | 0                     | 1                     | 1                     | 0                     | 0                     | 1                     | 1                     | 0                     | 0          | 1                      | 1               | 0                     | 0               | 1                      | 1               |
| 1     | 0                | 0                     | 0                     | 0                     | 0                     | 1                     | 1                     | 1                     | 1                     | 0                     | 0          | 0                      | 0               | 1                     | 1               | 1                      | 1               |
| 1     | 1                | 0                     | 0                     | 0                     | 0                     | 0                     | 0                     | 0                     | 0                     | 1                     | 1          | 1                      | 1               | 1                     | 1               | 1                      | 1               |
|       |                  | 0                     |                       |                       | ~x <sub>1</sub>       |                       |                       | XOR                   |                       | AND                   |            | <b>x</b> <sub>0</sub>  |                 | <b>X</b> <sub>1</sub> |                 | OR                     | 1               |



#### Some functions are "almost trivial"

|                       |                | l                     | NOR                   |                       |                       |                       |                       | 1                     | VAND                  | )                     | XNOF       | ?               |                 |                        |                 |                 |                 |
|-----------------------|----------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|------------|-----------------|-----------------|------------------------|-----------------|-----------------|-----------------|
| <b>X</b> <sub>1</sub> | x <sub>o</sub> | <b>y</b> <sub>0</sub> | <b>y</b> <sub>1</sub> | <b>y</b> <sub>2</sub> | <b>y</b> <sub>3</sub> | <b>y</b> <sub>4</sub> | <b>y</b> <sub>5</sub> | <b>y</b> <sub>6</sub> | <b>y</b> <sub>7</sub> | <b>y</b> <sub>8</sub> | <b>y</b> 9 | y <sub>10</sub> | y <sub>11</sub> | <b>y</b> <sub>12</sub> | y <sub>13</sub> | У <sub>14</sub> | У <sub>15</sub> |
| 0                     | 0              | 0                     | 1                     | 0                     | 1                     | 0                     | 1                     | 0                     | 1                     | 0                     | 1          | 0               | 1               | 0                      | 1               | 0               | 1               |
| 0                     | 1              | 0                     | 0                     | 1                     | 1                     | 0                     | 0                     | 1                     | 1                     | 0                     | 0          | 1               | 1               | 0                      | 0               | 1               | 1               |
| 1                     | 0              | 0                     | 0                     | 0                     | 0                     | 1                     | 1                     | 1                     | 1                     | 0                     | 0          | 0               | 0               | 1                      | 1               | 1               | 1               |
| 1                     | 1              | 0                     | 0                     | 0                     | 0                     | 0                     | 0                     | 0                     | 0                     | 1                     | 1          | 1               | 1               | 1                      | 1               | 1               | 1               |
|                       |                | 0                     |                       |                       | ~x <sub>1</sub>       |                       | ~x <sub>0</sub>       | XOR                   |                       | AND                   |            | $\mathbf{x}_0$  |                 | <b>X</b> <sub>1</sub>  |                 | OR              | 1               |



### Some functions are "implications"



### Some functions are "implications"



#### And some functions are "inverse implications"



#### And some functions are "inverse implications"



The popular functions can also have more than 2 inputs

• Example: 5-input AND



Only if all input values are 1, the output is 1

# The popular functions can also have more than 2 inputs

• Example: 3-input OR



• If at least one input values is 1, the output is 1

# Be careful with XOR function with more than 2 inputs

• Interpretation #1: Output is 1, if an odd number of input values is 1

Interpretation #2: Output is 1, if exactly 1 input value is 1

Interpretation #1 is the "common" interpretation! → This is what we use in the lecture



## Other Important Gates – Multiplexer (MUX)



- The select signal (sel) determines whether out is equal to  $I_0$  or  $I_1$ :
  - Sel = 0 means out =  $I_0$
  - Sel = 1 means out =  $I_1$

## Scaling to more inputs

 With each additional select signal, the number of selectable inputs doubles

- 2to1MUX: 1 select signal
- 4to1MUX: 2 select signals
- 8to1MUX: 3 select signals

• ...



4to1MUX

## Other Important Gates – Demultiplexer

- The select signals (sel) of a demultiplexer determine whether to which output the input is mapped:
  - Sel = 0 means out<sub>0</sub> = in
  - Sel = 1 means out<sub>1</sub> = in



1to2 DEMUX

## Tooling

Recommended tools for understanding logic circuits

- Tool DIGITAL (installed on your VM)
  - https://github.com/hneemann/Digital

- Online tool for logic circuit design
  - https://circuitverse.org/

How many different types of gates are needed to be able to implement any logic function?

## Functional Completeness

• A functionally complete set of logic gates is a set that allows to build all possible truth tables by combining gates of this set.

- Important sets are:
  - {NAND}: Any circuit can be built just by using NAND gates (try it out in Digital!)
  - {NOR}: Any circuit can be built just by using NOR gates
  - {AND, NOT}: Any circuit can be built just by using AND and NOT gates
  - {AND, OR, NOT}: The set we use to map truth tables to equations

#### **Combinational Circuits**

(Composing logic gates to implement a desired functionality)

## Describing Combinational Circuits

In practice, it does not work to describe the functionality of larger compositions of logic gates based on a single truth table

→ We need a more powerful description

## Boolean Functions – The Mathematical Description of Combinational Circuits

Symbol for inversion:
Symbol for AND:
Symbol for OR:

• Example:

$$y = (^{\sim}x_1 \& x_0) | (x_2 \& ^{\sim}x_0) | (x_2 \& x_1)$$

## Logic functions map to Combinational Circuits and Vice Versa







$$q = (^a \& b) | c$$



$$q = (^a \& b) | c$$



$$q = (^a \& b) | c$$



Start with developing a truth table

• Example: Adding three binary variables u, v and w: s = u + v + w

• With 3 variables we have 2<sup>3</sup> possible combinations for input situations.

```
W
           8 possible combinations;
           sorted from (0, 0, 0) to (1, 1, 1)
```

```
W
+
```

The result for each possible case

```
W
+
+
```

Re-writing the result as a binary number

| u | V | W | S <sub>1</sub> | $s_0$ |
|---|---|---|----------------|-------|
| 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     |

The truth table

| u | V | W | S <sub>1</sub> | $s_0$ |
|---|---|---|----------------|-------|
| 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     |

#### The logic function for $s_0$ :

We only look at lines where  $s_0$  gets "true" i.e. "1".

| u | V | W | S <sub>1</sub> | $s_0$ |
|---|---|---|----------------|-------|
| 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     |

$$s_0 = (^u \& ^v \& w) ...$$

| u | V | W | S <sub>1</sub> | $s_0$ |
|---|---|---|----------------|-------|
| 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     |

$$s_0 = (^u \& ^v \& w) |$$
 $(^u \& ^v \& ^w) ...$ 

| u | V | W | s <sub>1</sub> | $s_0$ |
|---|---|---|----------------|-------|
| 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     |

| u | V | W | s <sub>1</sub> | $s_0$ |
|---|---|---|----------------|-------|
| 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     |

https://github.com/hneemann/Digital



Start Digital

Goto Analysis → Synthesis



Start Digital

Goto Analysis → Synthesis

Adjust inputs and outputs



Start Digital

Goto Analysis → Synthesis

Adjust inputs and outputs

Specify the output section of the truth table



Start Digital

Goto Analysis → Synthesis

Adjust inputs and outputs

Specify the output section of the truth table



Start Digital

Goto Analysis → Synthesis

Adjust inputs and outputs

Specify the output section of the truth table

Optionally: Check plain text export



Start Digital

Goto Analysis → Synthesis

Adjust inputs and outputs

Specify the output section of the truth table

Optionally: Check plain text export

Click "Create" and "Circuit".



Switch to Simulation Mode:



Simulate circuit with all possible input combinations.



Alternative: specify the expression

Use "let" to specify outputs. Separate formulas by comma.

(Rules to transform/simplify logic functions)

#### Motivation

- A truth table is a unique representation of a logic function
- Describing a given functionality as a Boolean function is **not unique** 
  - The same functionality can be described using different Boolean functions
- There is also **no unique circuit representation** for a logic function
  - → The same functionality can be described by different combinational circuits

When building digital circuits, there is always an optimization towards different targets, such as minimum area, shortest latency, minimum power consumption, ....

Values of variables are only 0 or 1.

- 3 main operations:
  - Negation, also known as "inversion"
  - Conjunctions, also known as "ANDing"
  - Disjunction, also known as "ORing"
- Boolean Algebra allows to transform Boolean functions/equations

$$a \mid 0 = a$$

$$a \mid a = a$$

$$a \mid (a \& b) = a$$

$$a \& (a | b) = a$$

$$a \& 0 = 0$$

$$a \& a = a$$

$$a \& ^a = 0$$

$$a ^0 = a$$

$$a \wedge a = 0$$

#### **Associative Law:**

#### Commutative Law:

#### Distributive Law:

$$a \mid (b \& c) = (a \mid b) \& (a \mid c)$$

$$a \& (b | c) = (a \& b) | (a \& c)$$

De Morgan's Law:

$$^{\sim}(a \& b) = ^{\sim}a | ^{\sim}b$$

$$^{(a | b)} = ^{a \& ^{b}}$$

De Morgan's Law:

$$^{\sim}(a \& b) = ^{\sim}a | ^{\sim}b$$



$$^{\sim}$$
(a | b) =  $^{\sim}$ a &  $^{\sim}$ b

De Morgan's Law:

$$^{\sim}(a \& b) = ^{\sim}a | ^{\sim}b$$



#### Incomplete specification: "Don't Cares"

- Sometimes we are not interested in some input combinations; we "don't care" about the output of the logic function in this case.
- This is the case, when not all input combinations occur in some context.

#### Incomplete specification: "Don't Cares"

• Example: 3 inputs, 2 "don't cares".



#### Result after "synthesizing" with Digital













circuit

**Truth Tables** 

(exhaustive listing of all input/output combinations)

inputs

**Logic Equation** 

(one equation for each output)

Circuit Netlist

("connected logic gates")

outputs

Hardware Description Language

("writing code that describes physical hardware")

circuit

**Truth Tables** 

Truth tables are only practical for small input sizes.

inputs

**Logic Equation** 

Ideal format to apply transformations and optimizations (Boolean algebra).

Circuit Netlist

This is what is needed to physically build a chip.

outputs

Hardware Description Language

This is the standard way of describing the behavior of complex circuits.

### Example 1

| in_a | in_b | in_c | out_q |
|------|------|------|-------|
| 0    | 0    | 0    | 0     |
| 0    | 0    | 1    | 1     |
| 0    | 1    | 0    | 1     |
| 0    | 1    | 1    | 1     |
| 1    | 0    | 0    | 0     |
| 1    | 0    | 1    | 1     |
| 1    | 1    | 0    | 0     |
| 1    | 1    | 1    | 1     |
|      |      |      |       |
|      |      |      |       |
|      |      |      |       |

out\_q = (~in\_a & in\_b) | in\_c

```
module simple_circuit (
  input in_a,
  input in_b,
  input in_c,
  output out_q
);
  assign out_q = ((~ in_a & in_b) | in_c);
  endmodule
```





```
module simple_circuit (
  input in_a,
  input in_b,
  input in_c,
  output out_q
);
  assign out_q = ((~ in_a & in_b) | in_c);
  endmodule
```



# SystemVerilog – A Hardware Description Language

```
module simple_circuit (
  input in_a,
  input in_b,
  input in_c,
  output out_q
);
  assign out_q = ((~ in_a & in_b) | in_c);
  endmodule
```

#### Example 2

```
module simple_circuit_with_mux (
 input logic in_a,
 input logic in_b,
 input logic in_c,
 input logic in_x,
 input logic in_y,
 input logic in_z,
 input logic mux_sel,
 output logic out_q
 always_comb begin
  if (mux_sel == 0)
   out_q = (~in_a & in_b) | in_c;
  else
   out_q = (in_x ^ in_y) | ~in_z;
 end
endmodule
```



# (System) Verilog

 Powerful and widely used hardware description language (HDL); The second important HDL besides SystemVerilog is VHDL

- SystemVerilog was not created on the greenfield
  - SystemVerilog is an extension of Verilog (all features of Verilog are also available in SystemVerilog)
  - → There are many variants and coding styles of how to use System Verilog
  - →In CON we focus on widely-used best-practice and current coding styles

### Two Main Styles for Hardware Description

#### Gate-Level

- The module body contains a gate-level description of the circuit
- Circuits are created by instantiating gates (modules) and by connecting these modules

#### Behavioral

- The module body contains
  - a functional description of the circuit
  - logical and mathematical operators
- The level of abstraction is higher and there are many gate-level realizations for behavioral descriptions
- For composing circuits, also structural mechanisms for composition like instantiations (yet at a higher level of abstraction) are used

or

Module Description in HDL

or

Design Flow

Description in SystemVerilog (mostly behavioral)

This is what is provided by the manufacturing plant

Cell library is provided at at different levels – from physical level to Verilog level

Cell Library

("a description of available logic gates")

**Synthesis** Circuit Netlist ("connected logic gates") Place&Route Physical layout of transistors and

Constraints

("definition of optimization goals")

Gate-level netlist in Verilog (structural)

Constraints

("definition of optimization goals")

wiring for fabrication as ASIC (GDSII level)

#### The Toolchain in our Practical

- iVerilog:
  - Simulator for Verilog code
- SV2V
  - Converts SystemVerilog to Verilog
- Yosys:
  - Synthesis Tool
- Our flow does not do the place & route step we stop at the gate-level netlist

#### The Commands for Our Toolchain

Make

• **build:** Compile code

• run: Run simulation

• view: View simulation result in wave viewer

• **syn:** Synthesize code

• build-syn: compile synthesized code

run-syn: Run Simulation based on netlist (synthesis result)

• **show:** Show netlist after synthesis

**Behavioral Level** 

**Gate Level** 

### Synthesis and Place&Route

 Logic Synthesis is the process of mapping an abstract description (typically done in a hardware description language) of a circuit to a list of available logic gates

 Place&Route is the process of mapping a gate-level netlist to a physical layout that is ready for production

 Synthesis and Place&Route are parametrized to optimize different properties, like speed, area, or power consumption

### Building a physical device in practice



Field Programmable Gate Array

(FPGA)

**Application-Specific Integrated Circuit** 

(ASIC)

# ASIC – Application-Specific Integrated Circuit

A chip that physically realizes your circuit

- Basic steps to building your ASIC (very high level view):
  - Select your favorite semiconductor manufacturing plant (see https://en.wikipedia.org/wiki/List of semiconductor fabrication plants)
  - Receive the standard cell library from the plant ("the list of logic gates that the plant can build")
  - Map our circuit to the available cells (called "synthesis")
  - Place and route the cells
  - Let the plant physically build your circuit



The Complexity of building a Microchip

• Get an impression of the size and structure

https://www.youtube.com/watch?v=2z9qme\_ygRI



- Get an impression of the manufacturing process
  - https://www.youtube.com/watch?v=c9arR8T0Qts

• Today's chips contain billions of transistors connected by multiple layers of metal Recent Example: Apple M2 Ultra has about 134.000.000.000 transistors



#### US and European Chips Acts

#### EU

 The EU aims to double its market share of the global chip production from currently 10% to 20% in 2030

• € 43 billion investment

#### **USA**

- The USA seeks to relocate the chips supply chain to the USA.
- \$52.7 billion

### FPGAs – Field Programmable Gate Arrays

Existing hardware that can be configured to correspond to your circuit ("programmable hardware")

- Basic concept (high level view):
  - FPGA vendors build huge arrays of LUTs (Look-Up-Tables) and switches (highly regular repeated physical structure)
  - You can map your design to this hardware (the gates are mapped to LUTs and the wiring is mapped to the switches connecting the LUTs)
  - An FPGA bitfile stores how a given FPGA needs to be configured to realize your circuit (format is vendor-specific)
  - Load the bitfile into the FPGA and the FPGA realizes your circuit

#### FPGA boards

- FPGAs are trade-off between hardware and software
  - Less efficient than hardware, but more efficient than software
  - Less expensive than hardware, but more expensive than software
- You can get small FPGA boards already for less than EUR 50.
  - Interested in putting your practical of this semester on physical hardware?
  - Basically, any FPGA works for this purpose; ICE40 FGPAs offer an open source toolflow based on the tools we also use in this class (e.g. <a href="https://www.mouser.at/ProductDetail/Lattice/ICE40HX1K-STICK-EVN?qs=hJ2CX3hEdVEyBLaHAEXelA%3D%3D">https://www.mouser.at/ProductDetail/Lattice/ICE40HX1K-STICK-EVN?qs=hJ2CX3hEdVEyBLaHAEXelA%3D%3D</a>)

### **A Note on Complexity**

#### Moore's Law: The number of transistors on microchips doubles every two years Our World



Moore's law describes the empirical regularity that the number of transistors on integrated circuits doubles approximately every two years. This advancement is important for other aspects of technological progress in computing – such as processing speed or the price of computers.



Data source: Wikipedia (wikipedia.org/wiki/Transistor count)

OurWorldinData.org - Research and data to make progress against the world's largest problems.

# Linear Scaling



Beauty and Joy of Computing by University of California, Berkeley and Education Development Center, Inc, CC-BY-SA-NC https://bjc.edc.org/bjc-r/cur/programming/6-computers/3-history-impact/2-moore.html