# Computer Architecture

IN BA3 - Paolo IENNE

#### Introduction

This document is designed to offer a LaTeX-styled overview of the Computer Architecture course, emphasizing brevity and clarity. Should there be any inaccuracies or areas for improvement, please reach out at ali.elazdi@epfl.ch for corrections. For the latest version, check my GitHub repository.

# Contents

| $\mathbf{C}$ | onter | nts                                                          | 3 |  |  |  |  |  |  |  |  |  |  |
|--------------|-------|--------------------------------------------------------------|---|--|--|--|--|--|--|--|--|--|--|
| 1            | Par   | Part I(a): ISA Reminder, Assembly Language, Compiler - W 1.1 |   |  |  |  |  |  |  |  |  |  |  |
|              | 1.1   | From High Level Languages to Assembly Language               | 4 |  |  |  |  |  |  |  |  |  |  |
|              |       | 1.1.1 High Level Languages                                   | 4 |  |  |  |  |  |  |  |  |  |  |
|              |       | 1.1.2 Assembly Language                                      | 4 |  |  |  |  |  |  |  |  |  |  |
|              | 1.2   | Processors                                                   | 5 |  |  |  |  |  |  |  |  |  |  |
|              | 1.3   | Joint or Disjoint Program and Data Memories                  | 6 |  |  |  |  |  |  |  |  |  |  |
|              | 1.4   | The Encoding problem                                         | 7 |  |  |  |  |  |  |  |  |  |  |
|              |       | 1.4.1 The Stupid Solution                                    |   |  |  |  |  |  |  |  |  |  |  |
|              |       | 1.4.2 RISC-V Encoding (The Solution)                         | 7 |  |  |  |  |  |  |  |  |  |  |
|              |       | 1.4.3 Automating this process                                | 8 |  |  |  |  |  |  |  |  |  |  |
|              | 1.5   | ISA (Instruction Set Architecture)                           | ç |  |  |  |  |  |  |  |  |  |  |

## Chapter 1

# Part I(a): ISA Reminder, Assembly Language, Compiler - W 1.1

#### hum...welcome back

In the first part of the course, professor introduced (for motivational purposes) how computer architecture, specifically processors, have become essential to our lives, and how the field is growing exponentially. (didn't think it was essential to mention here...)

#### 1.1 From High Level Languages to Assembly Language

#### 1.1.1 High Level Languages

When talking about programming we usually think of programs that look like this...

```
int data = 0x00123456;
int result = 0;
int mask = 1;
int count = 0;
int temp = 0;
int limit = 32;
do {
   temp = data & mask;
   result = result + temp;
   data = data >> 1;
   count = count + 1;
} while (count != limit);
```

| name        | value        |
|-------------|--------------|
| data        | 0x00123456   |
| result      | 0            |
| mask        | 1            |
| count       |              |
| temp        |              |
| limit       |              |
|             |              |
| my_float    | 3.141529     |
| $a\_string$ | Hello world! |

#### 1.1.2 Assembly Language

We use such code because we're able to build a Finite State Machine that can execute it (which cannot be done directly for C code.)

In this language, we get a more rigid format, a sequence of numbered instructions, an *opcode* and predefined variable names. We also get a way to jump between lines of code.

```
li x1, 0x00123456
2
       li x2, 0
3
       li x3, 1
       li x4, 0
4
       li x5, 0
5
       li x6, 32
6
   loop: and x5, x1, x3
       add x2, x2, x5
8
       srli x1, x1, 1
9
       addi x4, x4, 1
10
       bne x4, x6, loop
11
```

#### 1.2 Processors

Last year, we studies Processors for a good reason, they are the closest machines to the code we write.

#### Remember, a processor can be decomposed into five components:

- ALU (Arithmetic and Logic Unit): Performs arithmetic and logical operations.
- Register File: Stores data temporarily for quick access during processing.
- Memory: Holds data and instructions needed by the processor.
- Control Logic: Directs the operation of the processor by coordinating the other components.
- PC (Program Counter): Keeps track of the address of the next instruction to be executed.
- Instruction Memory: Stores the program instructions that the processor will execute.



We may distinguish three types of operations:

#### Encoding



#### **Fetching**



#### Executing



### 1.3 Joint or Disjoint Program and Data Memories

There are two main types of architectures one called the Harvard Architecture (Where the data and the memory are seperate) and pne called Unified Architecture (where data is shared with the program





#### 1.4 The Encoding problem

We may ask ourselves how we encode assembly written instructions into actual 0s and 1s.

#### 1.4.1 The Stupid Solution

Now, the professor throws out the "stupid idea" (his words) of just counting all possible instructions, assigning a number to each one, and writing the numbers in binary. The problem with such a method is that the number of instructions could grow exponentially, requiring an unmanageable number of bits to represent each one, leading to inefficiency.



#### 1.4.2 RISC-V Encoding (The Solution)

Instead, the chosen solution is to use an instruction set encoding where instructions are grouped into classes, each with a fixed format. This approach optimizes both memory usage and processing speed by limiting the number of bits required to represent instructions, while still allowing for a large variety of operations.

| Instruction     | Pseudoc             | ode                                                    |               | Тур        | e funct7 | funct3   | opcod  | e      |                          |
|-----------------|---------------------|--------------------------------------------------------|---------------|------------|----------|----------|--------|--------|--------------------------|
| Shift           |                     |                                                        |               |            |          |          |        |        |                          |
| sll rd,rs1,rs2  | $rd \leftarrow rs1$ | $\mathtt{rd} \leftarrow \mathtt{rs1} \ll \mathtt{rs2}$ |               |            |          | 0x1      | 0x33   |        |                          |
| slli rd,rs1,imm | $rd \leftarrow rs1$ | $\ll$ imm                                              | 1             | I          | 0x00     | 0x1      | 0x13   | (      |                          |
| srl rd,rs1,rs2  | $rd \leftarrow rs1$ | $\gg_u$ rs                                             | 2             | R          | 0x00     | 0x5      | 0x33   |        | Complete ISA             |
| srli rd,rs1,imm | $rd \leftarrow rs1$ | $rd \leftarrow rs1 \gg_u imm$                          |               |            | 0x00     | 0x5      | 0x13   |        |                          |
| sra rd,rs1,rs2  | $rd \leftarrow rs1$ | $\gg_s$ rs                                             | 2             | R          | 0x20     | 0x5      | 0x33   |        | Moodle!                  |
| srai rd,rs1,imm | $rd \leftarrow rs1$ | $\gg_s$ im                                             | m             | I          | 0x20     | 0x5      | 0x13   |        |                          |
| Arithmetic      |                     |                                                        |               |            |          |          |        | _      |                          |
| add rd,rs1,rs2  | $rd \leftarrow rs1$ | + rs2                                                  |               | R          | 0x00     | 0x0      | 0x33   |        |                          |
| addi rd,rs1,imm | $rd \leftarrow rs1$ | + sext                                                 | (imm)         | I          |          | 0x0      | 0x13   |        |                          |
| sub rd,rs1,rs2  | $rd \leftarrow rs1$ | - rs2                                                  |               | R          | 0x20     | 0x0      | 0x33   |        |                          |
| lui rd,imm      | $rd \leftarrow imm$ | Inct                                                   | ruction types |            |          |          |        |        |                          |
| auipc rd,imm    | $rd \leftarrow pc$  | IIISU                                                  | ruction types |            |          |          |        |        |                          |
| Logical         |                     | 1                                                      | 31 25         | 24 20 19   | 9 15 14  | 12 11    | 7      | 6 0    | )                        |
| xor rd,rs1,rs2  | rd ← rs1            | $\mathbf{R}$                                           | funct7        | rs2        | rs1 func | 3 r      | d      | opcode | Register-Register        |
| xori rd,rs1,imm | $rd \leftarrow rs1$ | I                                                      | imm[11:       | :0]        | rs1 func | 3 r      | d      | opcode | Register-Immediate       |
| or rd,rs1,rs2   | $rd \leftarrow rs1$ | I                                                      | funct7        | imm[4:0]   | rs1 func | :3 r     | d      | opcode | Register-Immediate Shift |
| ori rd,rs1,imm  | $rd \leftarrow rs1$ | $\mathbf{s}$                                           | imm[11:5]     | rs2        | rs1 func | 3 imm    | [4:0]  | opcode | Store                    |
| and rd,rs1,rs2  | $rd \leftarrow rs1$ | В                                                      | imm[12—10:5]  | rs2        | rs1 func | 3 imm[4: | :1—11] | opcode | Branch                   |
| andi rd,rs1,imm | $rd \leftarrow rs1$ | U                                                      |               | imm[31:12] |          | r        | d      | opcode | Upper Immediate          |
|                 |                     | J                                                      | imm[20        | -10:1-11-1 | 9:12]    | r        | d      | opcode | Jump                     |
|                 |                     |                                                        |               |            |          |          |        |        |                          |
|                 |                     |                                                        |               |            |          |          |        |        |                          |

#### 1.4.3 Automating this process

#### Assembler

The program that does this is called an assembler. It takes the assembly code and converts it into machine code.



#### Compiler

A compiler is a program that translates high-level source code written in languages like C or Java into machine code or an intermediate representation. This machine code can then be executed by the processor. The compiler performs various stages, such as lexical analysis, parsing, optimization, and code generation, ensuring that the program runs efficiently on the target hardware.

```
int data
           = 0x00123456;
                                                    li
                                                         x1, 0x00123456
int result = 0;
                                          1
                                                    li
                                                         x2, 0
int mask
           = 1;
                                          2
                                                    li
                                                         x3, 1
int count = 0;
                                          3
                                                    li
                                                         x4, 0
int temp
           = 0;
                                                         x5, 0
                                          4
                                                    li
int limit = 32;
                                          5
                                                    li
                                                         x6, 32
do {
                                                    and x5, x1, x3
                                             loop:
  temp
         = data & mask;
                                          7
                                                    add x2, x2, x5
  result = result + temp;
                                          8
                                                    srli x1, x1, 1
         = data >> 1;
                                          9
                                                    addi x4, x4, 1
  count = count + 1;
                                                    bne x4, x6, loop
} while (count != lim
                          A pretty hard job!...
                                                                          Compilation
```

## 1.5 ISA (Instruction Set Architecture)

The ISA is the interface between the hardware and the software. It defines the instructions that a processor can execute, as well as the format of those instructions.

