

# PROCESORUL MIPS 32

## CICLU UNIC

TAR IVETT - DORA  
UNIVERSITATEA TEHNICĂ CLUJ NAPOCA  
Facultatea de Automatică și Calculatoare

## Contents

|                                   |    |
|-----------------------------------|----|
| Instrucțiuni pentru MIPS32 .....  | 2  |
| Formatul instrucțiunii .....      | 2  |
| Setul de instrucțiuni ales .....  | 3  |
| Function codes.....               | 3  |
| Opcodes .....                     | 3  |
| Semnale de control MIPS32.....    | 4  |
| Trasarea execuției .....          | 5  |
| Schema procesorului MIPS 32 ..... | 6  |
| RTL schematic .....               | 7  |
| Problema aleasă .....             | 8  |
| Codul în C++ .....                | 8  |
| Codul în VHDL.....                | 8  |
| Exemplu.....                      | 9  |
| Descrierea operațiilor.....       | 11 |

## Instrucțiuni pentru MIPS32

| <b>Tipul instrucțiunii</b> | <b>Denumirea instrucțiunii</b>          | <b>Prescurtare</b> |
|----------------------------|-----------------------------------------|--------------------|
| <b>Tip R</b>               | Addition                                | add                |
|                            | Substraction                            | sub                |
|                            | Shift Left Logical                      | sll                |
|                            | Shift Right Logical                     | srl                |
|                            | Logical AND                             | and                |
|                            | Logical OR                              | or                 |
|                            | Logical XOR                             | xor                |
|                            | Shift Left Logical Variable             | sllv               |
|                            |                                         |                    |
| <b>Tip I</b>               | Add Immediate                           | addi               |
|                            | Load Word                               | lw                 |
|                            | Store Word                              | sw                 |
|                            | Branch on Equal                         | beq                |
|                            | Branch on Greater than or Equal to Zero | bgez               |
| <b>Tip J</b>               | Set on Less Than Immediate(signed)      | slti               |
|                            | Jump                                    | j                  |

### Formatul instrucțiunii

Tip R

| 6           | 5           | 5           | 5           | 5          | 5         | 6 |
|-------------|-------------|-------------|-------------|------------|-----------|---|
| opcode = 0  | rs          | rt          | rd          | sa         | function  |   |
| 31 . . . 26 | 25 . . . 21 | 20 . . . 16 | 15 . . . 11 | 10 . . . 6 | 5 . . . 0 |   |

Tip I

| 6           | 5           | 5           | 16               |
|-------------|-------------|-------------|------------------|
| opcode      | rs          | rt          | immediate/offset |
| 31 . . . 26 | 25 . . . 21 | 20 . . . 16 | 15 . . . 0       |

Tip J

| 6           | 26         |
|-------------|------------|
| opcode      | address    |
| 31 . . . 26 | 25 . . . 0 |

## Setul de instrucțiuni ales

| Instruction | Type | Assembly                  | RTL Abstract                                                                      |
|-------------|------|---------------------------|-----------------------------------------------------------------------------------|
| <b>add</b>  | R    | add \$rd, \$rs, \$rt      | $RF[rd] \leq RF[rs] + RF[rt]$ ; $PC \leq PC + 4$                                  |
| <b>sub</b>  | R    | sub \$rd, \$rs, \$rt      | $RF[rd] \leq RF[rs] - RF[rt]$ ; $PC \leq PC + 4$                                  |
| <b>and</b>  | R    | and \$rd, \$rs, \$rt      | $RF[rd] \leq RF[rs] \& RF[rt]$ ; $PC \leq PC + 4$                                 |
| <b>or</b>   | R    | or \$rd, \$rs, \$rt       | $RF[rd] \leq RF[rs]   RF[rt]$ ; $PC \leq PC + 4$                                  |
| <b>xor</b>  | R    | xor \$rd, \$rs, \$rt      | $RF[rd] \leq RF[rs] ^ RF[rt]$ ; $PC \leq PC + 4$                                  |
| <b>sll</b>  | R    | sll \$rd, \$rt, sa        | $RF[rd] \leq RF[rt] \ll sa$ ; $PC \leq PC + 4$                                    |
| <b>srl</b>  | R    | srl \$rd, \$rt, sa        | $RF[rd] \leq RF[rt] \gg sa$ ; $PC \leq PC + 4$                                    |
| <b>sllv</b> | R    | sllv \$rd, \$rt, \$rs     | $RF[rd] \leq RF[rt] \ll RF[rs]$ ; $PC \leq PC + 4$                                |
| <b>addi</b> | I    | addi \$rt, \$rs, imm      | $RF[rt] \leq RF[rs] + S\_Ext(imm)$ ; $PC \leq PC + 4$                             |
| <b>lw</b>   | I    | lw \$rt, offset(\$rs)     | $RF[rt] \leq Mem[RF[rs] + S\_Ext(offset)]$ ;<br>$PC \leq PC + 4$                  |
| <b>sw</b>   | I    | sw \$rt, offset(\$rs)     | $Mem[RF[rs] + S\_Ext(offset)] \leq RF[rt]$ ;<br>$PC \leq PC + 4$                  |
| <b>beq</b>  | I    | beq \$rs, \$rt,<br>offset | If $RF[rs] = RF[rt]$ then<br>$PC \leq PC + 4 + S\_Ext(offset) \ll 2$              |
| <b>bgez</b> | I    | bgez \$rs, offset         | If $RF[rs] \geq 0$ then<br>$PC \leq PC + 4 + S\_Ext(offset) \ll 2$                |
| <b>slti</b> | I    | slti \$rt, \$rs, imm      | If $RF[rs] < imm$ then $RF[rt] \leq 1$<br>Else $RF[rd] \leq 0$ ; $PC \leq PC + 4$ |
| <b>j</b>    | J    | j address                 | $PC \leq (PC + 4)[31:28] \parallel address \parallel 00$                          |

### Function codes

| Function    | Code   |
|-------------|--------|
| <b>add</b>  | 100000 |
| <b>sub</b>  | 100001 |
| <b>and</b>  | 010001 |
| <b>or</b>   | 010010 |
| <b>xor</b>  | 010011 |
| <b>sll</b>  | 001010 |
| <b>srl</b>  | 001100 |
| <b>sllv</b> | 001110 |

### Opcodes

| Operation   | Code   |
|-------------|--------|
| <b>addi</b> | 000001 |
| <b>lw</b>   | 110000 |
| <b>sw</b>   | 110001 |
| <b>beq</b>  | 011000 |
| <b>bgez</b> | 011001 |
| <b>slti</b> | 001000 |
| <b>j</b>    | 111111 |

## Semnale de control MIPS32

| Instrucție | Opcode | Reg Dst | Ext Op | ALU Src | Branch | Br_gez | Jump | Mem Write | Memto Reg | Reg Write | ALU Op[1:0] | function | Instr[5-0] | ALUCtrl[3:0] |
|------------|--------|---------|--------|---------|--------|--------|------|-----------|-----------|-----------|-------------|----------|------------|--------------|
| ADD        | 000000 | 1       | 0      | 0       | 0      | 0      | 0    | 0         | 0         | 1         | 10(R)       | 100000   | 0000(+)    |              |
| SUB        | 000000 | 1       | 0      | 0       | 0      | 0      | 0    | 0         | 0         | 1         | 10(R)       | 100001   | 1000(-)    |              |
| SLL        | 000000 | 1       | 0      | 0       | 0      | 0      | 0    | 0         | 0         | 1         | 10(R)       | 001010   | 0100(<<l)  |              |
| SRL        | 000000 | 1       | 0      | 0       | 0      | 0      | 0    | 0         | 0         | 1         | 10(R)       | 001100   | 0101(>>l)  |              |
| SLLV       | 000000 | 1       | 0      | 0       | 0      | 0      | 0    | 0         | 0         | 1         | 10(R)       | 001110   | 0111(<<lv) |              |
| AND        | 000000 | 1       | 0      | 0       | 0      | 0      | 0    | 0         | 0         | 1         | 10(R)       | 010001   | 0001(&)    |              |
| OR         | 000000 | 1       | 0      | 0       | 0      | 0      | 0    | 0         | 0         | 1         | 10(R)       | 010010   | 0010( )    |              |
| XOR        | 000000 | 1       | 0      | 0       | 0      | 0      | 0    | 0         | 0         | 1         | 10(R)       | 010011   | 0011(x)    |              |
| ADDI       | 000001 | 0       | 1      | 1       | 0      | 0      | 0    | 0         | 0         | 1         | 00(+)       | xxxxxx   | 0000(+)    |              |
| SLTI       | 001000 | 0       | 1      | 1       | 0      | 0      | 0    | 0         | 0         | 1         | 11          | xxxxxx   | 1011       |              |
| LW         | 110000 | 0       | 1      | 1       | 0      | 0      | 0    | 0         | 1         | 1         | 00(+)       | xxxxxx   | 0000(+)    |              |
| SW         | 110001 | x       | 1      | 1       | 0      | 0      | 0    | 1         | x         | 0         | 00(+)       | xxxxxx   | 0000(+)    |              |
| BEQ        | 011000 | x       | 1      | 0       | 1      | 0      | 0    | 0         | x         | 0         | 01(-)       | xxxxxx   | 1000(-)    |              |
| BGEZ       | 011001 | x       | 1      | 0       | 0      | 1      | 0    | 0         | x         | 0         | 01(-)       | xxxxxx   | 1000(-)    |              |
| J          | 111111 | x       | x      | x       | x      | x      | 1    | 0         | x         | 0         | xx          | xxxxxx   | 1011       |              |

## Trasarea execuției

| Pas | SW(7:5)              | "000"        | "001"        | "010"       | "011"       | "100"       | "101"       | "110"       | "111"       | De completat numai pentru instrucțiuni de salt |             |
|-----|----------------------|--------------|--------------|-------------|-------------|-------------|-------------|-------------|-------------|------------------------------------------------|-------------|
|     | Instr (în asamblare) | Instr (hexa) | PC+4         | RD1         | RD2         | Ext_Imm     | ALURes      | MemData     | WD          | BranchAddr                                     | JumpAddr    |
| 0   | LW \$1, 0[\$0]       | X"C0010000"  | X"00000004"  | X"00000000" | X"00000000" | X"00000000" | X"00000000" | X"00000018" | X"00000018" |                                                |             |
| 1   | LW \$2, 4[\$0]       | X"C0020004"  | X"00000008"  | X"00000000" | X"0000000C" | X"00000010" | X"00000000" | X"00000010" | X"00000024" |                                                |             |
| 2   | SW \$1, 8[\$0]       | X"C4010008"  | X"0000000C"  | X"00000000" | X"00000018" | X"0000000C" | X"0000000C" | X"00000018" | X"0000000C" |                                                |             |
| 3   | SW \$2, 12[\$0]      | X"C402000C"  | X"00000010"  | X"00000000" | X"00000024" | X"00000010" | X"00000010" | X"00000024" | X"00000010" |                                                |             |
| 4   | ADDI \$3, 16[\$0]    | X"04030010"  | X"00000014"  | X"00000000" | X"00000024" | X"00000014" | X"00000014" | X"0000000C" | X"00000014" |                                                |             |
| 5   | ADDI \$8, 1[\$0]     | X"04080001"  | X"00000018"  | X"00000000" | X"00000001" | X"00000001" | X"00000001" | X"00000018" | X"00000001" |                                                |             |
| 6   | SUB \$4, \$1, \$2    | X"00222021"  | X"00000001C" | X"00000018" | X"00000024" | X"00000021" | X"FFFFFFF4" | X"00000000" | X"FFFFFFF4" |                                                |             |
| 7   | SLTI \$5, \$4, 0     | X"20850000"  | X"00000020"  | X"FFFFFFF4" | X"00000000" | X"00003020" | X"00000024" | X"00000000" | X"00000024" |                                                |             |
| 8   | BEQ \$5, \$8, 7      | X"60A80007"  | X"00000024"  | X"00000001" | X"00000001" | X"00000007" | X"00000000" | X"00000018" | X"00000000" | X"00000040"                                    |             |
| 9   | ADD \$6, \$2, \$0    | X"00403020"  | X"00000044"  | X"00000024" | X"00000000" | X"00003020" | X"00000000" | X"00000018" | X"00000018" |                                                |             |
| 10  | ADD \$2, \$1, \$0    | X"00201020"  | X"00000048"  | X"00000018" | X"00000000" | X"00001020" | X"00000018" | X"00000018" | X"00000018" |                                                |             |
| 11  | ADD \$1, \$5, \$0    | X"00C00820"  | X"0000004C"  | X"00000024" | X"00000000" | X"00000820" | X"00000024" | X"00000000" | X"00000024" |                                                |             |
| 12  | J 09                 | X"FC000009"  | X"00000050"  | X"00000000" | X"00000000" | X"00000009" | X"00000000" | X"00000018" | X"00000000" |                                                | X"00000024" |
| 13  | SUB \$1, \$1, \$2    | X"00220821"  | X"00000028"  | X"00000024" | X"00000018" | X"00000821" | X"0000000C" | X"00000018" | X"0000000C" |                                                |             |
| 14  | SW \$1, 0[\$3]       | X"C4610000"  | X"00000002C" | X"00000014" | X"0000000C" | X"00000000" | X"00000014" | X"00000005" | X"00000014" |                                                |             |
| 15  | SW \$2, 4[\$3]       | X"C4620004"  | X"00000030"  | X"00000014" | X"00000018" | X"00000004" | X"00000018" | X"00000006" | X"00000018" |                                                |             |
| 16  | ADDI \$3, \$3, 8     | X"04630008"  | X"00000034"  | X"00000014" | X"00000014" | X"00000008" | X"0000001C" | X"00000007" | X"0000001C" |                                                |             |
| 17  | SUB \$4, \$1, \$2    | X"00222021"  | X"00000038"  | X"0000000C" | X"00000018" | X"00002021" | X"FFFFFFF4" | X"00000000" | X"FFFFFFF4" |                                                |             |
| 18  | BEQ \$4, \$0, 5      | X"60800005"  | X"0000003C"  | X"FFFFFFF4" | X"00000000" | X"00000005" | X"FFFFFFF4" | X"00000000" | X"FFFFFFF4" | X"00000050"                                    |             |
| 19  | J 06                 | X"FC000006"  | X"00000040"  | X"00000000" | X"00000000" | X"00000006" | X"00000000" | X"00000018" | X"00000000" |                                                | X"00000018" |
| 20  | SW \$1, 0[\$3]       | X"C4610000"  | X"00000054"  | X"00000024" | X"0000000C" | X"00000000" | X"00000024" | X"0000000C" | X"00000024" |                                                |             |

## Schema procesorului MIPS 32



## RTL schematic



## Problema aleasă

Să se determine cel mai mare divizor comun a 2 numere  $X$  și  $Y$  citite din memorie de la adresa 0, respectiv 4. Se va implementa algoritmul lui Euclid cu scăderi. Se vor scrie în memorie, la locații consecutive pe 32 de biți, începând cu adresa 8, valorile  $X$ ,  $Y$ , urmate de cele intermediare generate de algoritmul lui Euclid. Ultimul număr scris va fi cel mai mare divizor comun.

### Codul în C++

```
int main()
{
    int n , m;
    std :: cin >> n >> m;
    while(n != m)
        if(n > m)
            n -= m;
        else
            m -= n;
    std :: cout << n << std :: endl;
    return 0;
}
```

### Codul în VHDL

```
signal instruction_memory : rom := (
    B"110000_00000_00001_00000000000000000000",
    B"110000_00000_00010_00000000000000001000",
    B"110001_00000_00001_00000000000000001000",
    B"110001_00000_00010_00000000000000001100",
    B"000001_00000_00011_000000000000000010000",
    B"000001_00000_01000_00000000000000000001",
    B"000000_00001_00010_00100_00000_100001",
    B"001000_00100_00101_00000000000000000000",
    B"011000_00101_01000_00000000000000000111",
    B"000000_00001_00010_00001_00000_100001",
    B"110001_00011_00001_00000000000000000000",
    B"110001_00011_00010_00000000000000001000",
    B"000001_00011_00011_00000000000000001000",
    B"000000_00001_00010_00100_00000_100001",
    B"011000_00100_00000_00000000000000000101",
    B"111111_00000000000000000000000000000000110",
    B"000000_00010_00000_00110_00000_100000",
    B"000000_00001_00000_00010_00000_100000",
    B"000000_00110_00000_00001_00000_100000",
    B"111111_000000000000000000000000000000001001",
    B"110001_00011_00001_00000000000000000000",
    others => X"00000000");
```

Acest program rezolvă în totalitate cerințele problemei, fiind testat atât în simulare, cât și pe placă. Problemele care au apărut au fost rezolvate.

## Exemplu

Vom considera în acest exemplu ca la adresa 0 vom avea valoarea 24(18 hexa) și la adresa 4 vom avea valoarea 36(24 hexa) și vom urmări cum calculează programul cel mai mare divizor comun al acestor numere.

**00: 110000\_00000\_00001\_0000000000000000 ⇔ lw \$1, 0[\$0]**

- În R1 se scrie cuvântul de la adresa 0, iar în exemplul nostru x18
- La acest pas sunt utile : WD=18, WA=1, RD2=0, RD1=0, RA2=1, RA1=0, Address=0

**01: 110000\_00000\_00010\_000000000000100 ⇔ lw \$2, 4[\$0]**

- În R2 se scrie cuvântul de la adresa 4, iar în exemplul nostru x24
- La acest pas sunt utile : WD=24, WA=2, RD2=0, RD1=0, RA2=2, RA1=0, Address=4

**02: 110001\_00000\_00001\_0000000000001000 ⇔ sw \$1, 8[\$0]**

- La adresa 8 din memorie se scrie valoarea din R1, la adresa 8 va fi x18
- La acest pas sunt utile : MemData=18, Address=8, RD2=18, RD1=0, RA2=1, RA1=0

**03: 110001\_00000\_00010\_0000000000001100 ⇔ sw \$2, 12[\$0]**

- La adresa 12 din memorie se scrie valoarea din R2, la adresa 12 va fi x24
- La acest pas sunt utile : MemData=24, Address=12, RD2=24, RD1=0, RA2=2, RA1=0, Imm=C

**04: 000001\_00000\_00011\_00000000000010000 ⇔ addi \$3, 16[\$0]**

- În R3 se adună valoarea lui R0 cu valoarea imediatului, adică 16
- La acest pas sunt utile : WD=16, WA=3, RD1=0, RA1=0

**05: 000001\_00000\_01000\_0000000000000001 ⇔ addi \$8, 1[\$0]**

- În R8 se adună valoarea lui R0 cu valoarea imediatului, adică 1
- La acest pas sunt utile : WD=1, WA=8, RD1=0, RA1=0

**06: 000000\_00001\_00010\_00100\_00000\_100001 ⇔ sub \$4,\$1,\$2**

- În R4 se pune diferența dintre R1 și R2, va fi -12
- La acest pas sunt utile : WD=1, WA=4, RD2=24, RA2=2, RD1=18, RA1=1

**07: 001000\_00100\_00101\_0000000000000000 ↔ slti \$5, \$4, 0**

- Compară valoarea lui R4 cu valoarea imediatului și inițiează R5 cu 1 sau 0 în funcție de valoarea lui R4 ; aici va fi -12 comparat cu 0, deci R5=1
- La acest pas sunt utile : WD=1, WA=5, RD2=0, RA2=5, RD1=-8, RA1=4, imm=0

**08: 011000\_00101\_01000\_000000000000111 ↔ beq \$5, \$8, 7**

- Compară valoarea din R5 și R8, iar dacă sunt egale sa sări, iar dacă nu se execută în continuare ; R5=1, R8=1, se va sări
- La acest pas sunt utile : RD2=1, RA2=5, RD1=1, RA1=8, imm=7

**09: 000000\_00001\_00010\_00001\_00000\_100001 ↔ sub \$1, \$1, \$2**

- În R1 se scrie diferența dintre R1 și R2, în R1 va fi 12
- La acest pas sunt utile : WD=C, WA=1, RD2=18, RA2=2, RD1=24, RA1=1

**0A: 110001\_00011\_00001\_0000000000000000 ↔ sw \$1, 0[\$3]**

- Scriem în memorie se scrie valoarea din R1, la adresa indicată de R3
- La acest pas sunt utile : MemData=C, RD1=10, RA1=3, RD2=C, RA2=1, Address=16(x10)

**0B: 110001\_00011\_00010\_000000000000100 ↔ sw \$2, 4[\$3]**

- Scriem în memorie se scrie valoarea din R2, la adresa indicată de R3+4
- La acest pas sunt utile : MemData=18, RD1=14, RA1=3, RD2=18, RA2=2, Address=16+4=20(x14)

**0C: 000001\_00011\_00011\_0000000000001000 ↔ addi \$3, \$3, 8**

- Adunăm 8 la R3 pentru a ajunge la adresa încă necompletată
- La acest pas sunt utile : WD=18, RD2=10, RA2=3, RD1=10, RA1=3, Imm=8

**0D: 000000\_00001\_00010\_00100\_00000\_100001 ↔ sub \$4,\$1,\$2**

- Se pune R4 valoarea scăderii R1-R2 pentru a putea verifica ulterior dacă cele două sunt egale, aici R4=12-24=-12
- La acest pas sunt utile : WD=FFFFFFF4, WA=4, RD2=18, RA2=2, RD1=C, RA1=1

**0E: 011000\_00100\_00000\_000000000000101 ↔ beq \$4, \$0, 5**

- Dacă în R4 este 0 atunci se sare la sfârșitul codului
- La acest pas sunt utile : RD2=0, RA2=0, RD1= FFFFFFFF4, RA1=4, Imm=5

**0F: 111111\_00000000000000000000000000000000110 ⇔ j 06**

- Dacă nu s-a efectuat saltul precedent atunci mai este nevoie de o iterare și se sare înapoi la început
- La acest pas sunt utile : Imm=6

**10: 000000\_00010\_00000\_00110\_00000\_100000 ⇔ add \$6, \$2, \$0**

**11: 000000\_00001\_00000\_00010\_00000\_100000 ⇔ add \$2, \$1, \$0**

**12: 000000\_00110\_00000\_00001\_00000\_100000 ⇔ add \$1, \$5, \$0**

- Aceasta este partea la care se sare de la începutul codului dacă valoarea din R1 este mai mică decât R2, și se efectuează o interschimare între R1 și R2
- Adica R6 <= R2, R2 <= R1, R1 <= R6

**13: 111111\_0000000000000000000000001001 ⇔ j 09**

- S-a efectuat interschimbarea și se sare înapoi pentru a continua execuția
- La acest pas sunt utile : Imm=9

**14: 110001\_00011\_00001\_0000000000000000 ⇔ sw \$1, 0[\$3]**

- Scriem în memorie se scrie valoarea din R1, la adresa indicată de R3
- La acest pas sunt utile : MemData=C, RD2=X, RA2=3, RD1=C, RA1=1, Address=X
- Adresa și valoarea lui R3 nu se cunosc, deoarece depinde de numărul de bucle pe care îl efectuează

## Descrierea operațiilor

În continuare se vor prezenta schițele detaliate pentru fiecare instrucțiune.

### ADD - ADD

|           |                                                            |
|-----------|------------------------------------------------------------|
| Descriere | Adună două registre și memorează rezultatul în al treilea  |
| RTL       | $\$d \leftarrow \$s + \$t; PC \leftarrow PC + 4$           |
| Syntaxă   | add \$d, \$s, \$t                                          |
| Format    | 000000 ssss tttt dddd 00000 100000                         |
| Exemplu   | add \$2, \$3, \$4 => 000000_00011_00100_00010_00000_100000 |



### SUB - SUBSTRACT

|           |                                                            |
|-----------|------------------------------------------------------------|
| Descriere | Scade două registre și memorează rezultatul în al treilea  |
| RTL       | $\$d \leftarrow \$s - \$t; PC \leftarrow PC + 4$           |
| Sintaxă   | sub \$d, \$s, \$t                                          |
| Format    | 000000 ssss tttt dddd 00000 100001                         |
| Exemplu   | sub \$3, \$4, \$5 => 000000_00100_00101_00011_00000_100001 |



### AND - AND Immediate

|           |                                                                      |
|-----------|----------------------------------------------------------------------|
| Descriere | ŞI logic între două registre cu memorarea rezultatului în al treilea |
| RTL       | $\$d \leftarrow \$s \& \$t; PC \leftarrow PC + 4$                    |
| Syntaxă   | and \$d, \$s, \$t                                                    |
| Format    | 000000 ssss tttt dddd 00000 010001                                   |
| Exemplu   | and \$4, \$5, \$6 => 000000_00101_00110_00100_00000 010001           |



### OR - bitwise OR

|           |                                                                     |
|-----------|---------------------------------------------------------------------|
| Descriere | SAU logic între două registre și memorează rezultatul în al treilea |
| RTL       | $\$d \leftarrow \$s \mid \$t; PC \leftarrow PC + 4$                 |
| Sintaxă   | or \$d, \$s, \$t                                                    |
| Format    | 000000 ssss tttt dddd 00000 010010                                  |
| Exemplu   | or \$5, \$6, \$7 => 000000_00110_00111_00101_00000 010010           |



### XOR - bitwise eXclusive-OR

|           |                                                                              |
|-----------|------------------------------------------------------------------------------|
| Descriere | SAU-Exclusiv logic intre doua registre, memoreaza rezultatul in alt registru |
| RTL       | $\$d \leftarrow \$s \wedge \$t; PC \leftarrow PC + 4$                        |
| Sintaxă   | xor \$d, \$s, \$t                                                            |
| Format    | 000000 sssss tttt ddddd 00000 010011                                         |
| Exemplu   | xor \$6, \$7, \$8 => 000000_00111_01000_00110_00000_010011                   |



### SLL - Shift-Left Logical

|           |                                                                                                             |
|-----------|-------------------------------------------------------------------------------------------------------------|
| Descriere | Deplasare logica la stanga pentru un regisztr, rezultatul este memorat in alt regisztr, se introduc zerouri |
| RTL       | $\$d \leftarrow \$t \ll h; PC \leftarrow PC + 4$                                                            |
| Sintaxă   | sll \$d, \$t, h                                                                                             |
| Format    | 000000 00000 tttt dddd hh hh hh 001010                                                                      |
| Exemplu   | sll \$7, \$8, 5 => 000000_00000_01000_00111_00101_001010                                                    |



### SRL - Shift-Right Logical

|           |                                                                                                       |
|-----------|-------------------------------------------------------------------------------------------------------|
| Descriere | Deplasare logica la dreapta pentru un registru, rezultatul este memorat in altul, se introduc zerouri |
| RTL       | $\$d \leftarrow \$t >> h; PC \leftarrow PC + 4$                                                       |
| Sintaxă   | srl \$d, \$t, h                                                                                       |
| Format    | 000000 00000 tttt dddd hh hh 001100                                                                   |
| Exemplu   | srl \$8, \$9, 3 => 000000_00000_01001_01000_00011_001100                                              |



### SLLV - Shift-Left Logical Variable

|           |                                                                                                                                               |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| Descriere | Deplasare logică la stanga pentru un registru, cu un număr de pozitii indicat de alt registru, iar rezultatul este memorat într-un al treilea |
| RTL       | $\$d \leftarrow \$t \ll \$s; PC \leftarrow PC + 4$                                                                                            |
| Sintaxă   | sllv \$d, \$t, \$s                                                                                                                            |
| Format    | 000000 sssss tttt dddd 00000 001110                                                                                                           |
| Exemplu   | sllv \$9, \$10, \$11 $\Rightarrow$ 000000_01011_01010_01001_0000_001110                                                                       |



### **ADDI - ADD Immediate**

|           |                                                                                 |
|-----------|---------------------------------------------------------------------------------|
| Descriere | Adună un registru cu o valoare imediată și memorează rezultatul în alt registru |
| RTL       | $\$t \leftarrow \$s + SE(imm); PC \leftarrow PC + 4$                            |
| Sintaxă   | addi \$t, \$s, imm                                                              |
| Format    | 000001 ssss tttt iiiiiiiiiiiiiii                                                |
| Exemplu   | addi \$10, \$3, 32 => 000001_00011_01010_0000000000100000                       |



### SLTI - Set on Less Than Immediate (signed)

|           |                                                                                          |
|-----------|------------------------------------------------------------------------------------------|
| Descriere | Dacă \$s este mai mic decât un imediat, \$t este initializat cu 1, altfel cu 0           |
| RTL       | $PC \leftarrow PC + 4;$ if $$s < SE(imm)$ then $$t \leftarrow 1$ else $$t \leftarrow 0;$ |
| Sintaxă   | slti \$t, \$s, imm                                                                       |
| Format    | 001000 ssss tttt ii <sub>15</sub> iiiiiiiiiiiiii                                         |
| Exemplu   | slti \$16, \$5, 127 => 001000_00101_10000_0000000001111111                               |



### LW - Load Word

|           |                                                                                                 |
|-----------|-------------------------------------------------------------------------------------------------|
| Descriere | Un cuvânt din memorie este încărcat într-un registru                                            |
| RTL       | $\$t \leftarrow \text{MEM}[\$s + \text{SE}(\text{offset})]; \text{PC} \leftarrow \text{PC} + 4$ |
| Syntaxă   | lw \$t, offset(\$s)                                                                             |
| Format    | 110000 ssss tttt oooooooooooooooo                                                               |
| Exemplu   | lw \$7, 1(\$5) => 110000_00101_00111_0000000000000000                                           |



### SW - Store Word

|           |                                                                                                 |
|-----------|-------------------------------------------------------------------------------------------------|
| Descriere | Valoarea unui registru este stocată în memorie la o anumită adresă                              |
| RTL       | $\text{MEM}[\$s + \text{SE}(\text{offset})] \leftarrow \$t; \text{PC} \leftarrow \text{PC} + 4$ |
| Sintaxă   | <code>sw \$t, offset(\$s)</code>                                                                |
| Format    | 110001 ssss tttt oooooooooooooooo                                                               |
| Exemplu   | <code>sw \$10, -1(\$6) =&gt; 110001_00110_01010_1111111111111111</code>                         |



### BEQ - Branch on EQual

|           |                                                                                                |
|-----------|------------------------------------------------------------------------------------------------|
| Descriere | Salt conditionat dacă este egalitate între două registre                                       |
| RTL       | if \$s = \$t then PC $\leftarrow$ (PC + 4) + (SE(offset) $\ll$ 2) else PC $\leftarrow$ PC + 4; |
| Sintaxă   | beq \$s, \$t, offset                                                                           |
| Format    | 011000 ssss tttt oooooooooooooooo                                                              |
| Exemplu   | beq \$2, \$3, -1 => 011000_00011_00010_1111111111111111                                        |



### BGEZ - Branch on Greater than or Equal to Zero

|           |                                                                                                 |
|-----------|-------------------------------------------------------------------------------------------------|
| Descriere | Salt conditionat dacă un registru este mai mare sau egal cu 0                                   |
| RTL       | if $\$s \geq 0$ then $PC \leftarrow (PC + 4) + (SE(offset) \ll 2)$ else $PC \leftarrow PC + 4;$ |
| Sintaxă   | bgez \$s, offset                                                                                |
| Format    | 011001 sssss 00000 oooooooooooooooo                                                             |
| Exemplu   | bgez \$5, 4 => 011001_00101_00000_0000000000000000100                                           |



**J - Jump**

|           |                                                         |
|-----------|---------------------------------------------------------|
| Descriere | Salt la adresă absolută                                 |
| RTL       | $PC \leftarrow (PC + 4)[31:28] \parallel (addr \ll 2);$ |
| Sintaxă   | j addr                                                  |
| Format    | 111111 aaaaaaaaaaaaaaaaaaaaaaaa                         |
| Exemplu   | j 10 => 111111_0000000000000000000000000000001010       |

