# DEVOIR 4 PROCESSEUR MIPS

ETIENNE COLLIN | 20237904

ANGE LILIAN TCHOMTCHOUA TOKAM | 20230129

JUSTIN VILLENEUVE | 20132792

ARCHITECTURE DES ORDINATEURS - IFT1227

## Section A Professeure Alena Tsikhanovich

UNIVERSITÉ DE MONTRÉAL À remettre le 30 Avril 2023 à 23:59



## Table des matières

| Ta       | able des matières                                   |  |  |  |  |  |  |  |  |  |  |  |
|----------|-----------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|
| 1        | Solution schématique du processeur MIPS un cycle    |  |  |  |  |  |  |  |  |  |  |  |
|          | 1.1 Chemin de données                               |  |  |  |  |  |  |  |  |  |  |  |
|          | 1.2 Contrôleur                                      |  |  |  |  |  |  |  |  |  |  |  |
| <b>2</b> | Solution schématique du processeur MIPS multicycles |  |  |  |  |  |  |  |  |  |  |  |
|          | 2.1 Chemin de données                               |  |  |  |  |  |  |  |  |  |  |  |
|          | 2.2 Contrôleur                                      |  |  |  |  |  |  |  |  |  |  |  |
| 3        | Code Testbench                                      |  |  |  |  |  |  |  |  |  |  |  |
|          | 3.1 MIPS Assembly                                   |  |  |  |  |  |  |  |  |  |  |  |
|          | 3.2 MIPS Hexadécimal                                |  |  |  |  |  |  |  |  |  |  |  |

## 1 Solution schématique du processeur MIPS un cycle

## 1.1 Chemin de données



## 1.2 Contrôleur

| Instr       | Op5:0   | RegWrite | RegDst | AluSrc | Branch | MemWrite | MemtoReg | ALUControl <sub>2:0</sub> | Jump | indextoodds | jal |  |
|-------------|---------|----------|--------|--------|--------|----------|----------|---------------------------|------|-------------|-----|--|
| R-type      | 000000  | 1 0      | 1      | 0      | 0      | o        | 0        | Diff.                     | o    | 0           | 0   |  |
| lw          | 100011  | 1 0      | 0      | 1      | 0      | О        | 1        | 010 (add)                 | 0    | 0           | 0   |  |
| sw          | 101011  | 0 ×      | x      | 1      | 0      | 1        | х        | 010 (add)                 | 0    | 0           | 0   |  |
| beq         | 000100  | o X      | x      | 0      | 1      | 0        | х        | 110 (sub)                 | 0    | ٥           | Х   |  |
| j           | 000010  | o X      | x      | х      | х      | 0        | x        | xxx                       | 1    | Х           | X   |  |
| addi        | 001000  | 1 0      | 0      | 1      | 0      | 0        | 0        | 010 (add)                 | 0    | Ô           | B   |  |
| index 2 Adr | 000 000 | 1        | 01     | 0      | 0      | 0        | 0        | 010 (add)                 | 0    | (           | Ó   |  |
| jal         | 000011  |          | 10     | X      | X      | 0        | X        | XXX                       | 1    | X           |     |  |
|             |         |          |        |        |        |          |          |                           |      |             |     |  |
|             |         |          |        |        |        |          |          |                           |      |             |     |  |
|             |         |          |        |        |        |          |          |                           |      |             |     |  |
|             |         |          |        |        |        |          |          |                           |      |             |     |  |
|             |         |          |        |        |        |          |          |                           |      |             |     |  |
|             |         |          |        |        |        |          |          |                           |      |             |     |  |
|             |         |          |        |        |        |          |          |                           |      |             |     |  |

indexidady
$$\frac{R[rd] = R[rs]*4 + R[rt]}{R[$ra] = PC + 4, PC = JTA}$$

## 2 Solution schématique du processeur MIPS multicycles

## 2.1 Chemin de données



Mexical 
$$R[rd] = R[rs]*4 + R[rt]$$

[salar R[\$ra] = PC + 4, PC = JTA

## 2.2 Contrôleur



#### 3 Code Testbench

#### 3.1 MIPS Assembly

Voici le code qui a été utilisé pour le testbench écrit en MIPS Assembly :

```
addi
                     $v0,
                             $0,
                                                  # $v0(2)=5
        addi
                     $v1,
                             $0.
                                          12
                                                  # $v1(3)=12
        addi
                     $a3,
                             $v1,
                                          -9
                                                  # $a3(7)=$v1(3)(12)-9=3
                                                  # $a0(4)=$a3(7) or $v0(2)=3 or 5=7
                    $a0,
                             $a3.
                                          $v0
        or
        and
                    $a1,
                             $v1,
                                          $a0
                                                  \# \$a1(5)=\$v1(3) and \$a0(4)=12 and 7=4
        add
                    $a1,
                             $a1,
                                          $a0
                                                  # $a1(5)=$a1(5)+$a0(4)=4+7=11
        beq
                     $a1,
                             $a3,
                                          end
                                                  # $a1(5)==$a3(7) ? end: PC=PC+4; 11==3 ? PC=PC+4
        slt
                     $a0,
                             $v1,
                                          $a0
                                                  \# v1(3) < a0(4) ? a0=1 : a0=0; 12 < 7 => a0=0
                    $a0,
                             $0,
                                                  # $a0(4)==0 ? ar1 : PC=PC+4; 0==0 goto ar1
        beq
                                          ar1
        addi
                             $0,
                    $a1,
                                                  # $a3(7) < $v0(2) ? $a0(4)=1 : $a0=0; 3 < 5, $a0=1
ar1:
        slt
                    $a0,
                             $a3,
                                          $v0
                                                  # $a3(7)=$a0(4)+$a1(5); 1+11=12
        add
                     $a3,
                             $a0,
                                          $a1
        sub
                    $a3,
                             $a3,
                                          $v0
                                                  # $a3(7)=$a3(7)-$v0(2); 12-5=7
                             68($v1)
                                                  \# $a3(7) \rightarrow M[68+$v1(3)]; 7 \rightarrow M[68+12=80]
                    $a3,
                                                                                                             # Test 1
        SW
                    $v0,
                             80($0)
                                                  # $v0(2)=M[80+0]; $v0=7
                    end
                                                  # goto end
        addi
                     $v0,
                             $0,
end:
        sw
                    $v0,
                             60($0)
                                                  # $v0(2) write M[60]; M[60]=7;
                                                                                                             # Test 2
                                                  # Jump to testJal
        jal
                    tag
                     $v0,
                             40($0)
                                                  # This should not be executed if jump is ok
                                                  # $ra=19 -> M[40]
                             40($0)
                                                                                                             # Test 3
                    $ra,
tag:
        SW
        addi
                     $t0,
                             $0,
                                                  # $t0=3
                                          5
                                                  # $t1=5
        addi
                    $t1,
                             $0,
        index2Adr
                    $t0,
                             $t0,
                                          $t1
                                                  # $t0=4*$t0+$t1=4*3+5=17
                    $t0,
                             20($0)
                                                  # $t0=17 -> M[20]
                                                                                                             # Test 4
```

#### 3.2 MIPS Hexadécimal

Voici le code précédent traduit en hexadécimal :

0x20020005

0x2003000c

0x2067fff7

0x00e22025

0x00642824

0x00a42820

0x10a7000a

0x0064202a

UXUUU42U2a

0x10800001

0x20050000

0x00e2202a

0x00853820

0x00e23822

0xac670044

0x8c020050

0x08000011

0x20020001

0xac02003C

0x0C000014

0xAC020028 0xAC1F0028

0x20080003

0x20090005

0x0109403F

0xAC080014