



Organização de Computadores 2018/2

Prof. Dra. Débora Matos

Projeto: Arquitetura MIPS Multiciclo de 10 instruções

Alunos: Giovanni Brancher e Wellington Luz

Guaíba, 12 de novembro de 2018.

## Configuração do MIPS definida:

- Implementação Multiciclo;
- Conjunto de 10 instruções (add, sub, and, or, lw, sw, beq, bne, jmp, sll);
- Instruções e Dados de 16 bits (2 bytes);
- 9 Registradores (\$zero, \$s0-\$s7);
- Única memória para Dados e Instruções;
- Memória com 128 posições;
- Tamanho da memória de 256 bytes;

## Conjunto de instruções

| Categoría                 | Instrução | Exemplo                 | Significado                          |
|---------------------------|-----------|-------------------------|--------------------------------------|
| Aritmética                | add       | add \$s0, \$s1, \$s2    | $\$s0 = \$s1 + \$s2$                 |
|                           | sub       | sub \$s0, \$s1, \$s2    | $\$s0 = \$s1 - \$s2$                 |
|                           | and       | and \$s0, \$s1, \$s2    | $\$s0 = \$s1 \text{ and } \$s2$      |
|                           | or        | or \$s0, \$s1, \$s2     | $\$s0 = \$s1 \text{ or } \$s2$       |
| Transferência<br>de dados | lw        | lw \$s0, \$s1           | $\$s0 = \text{memória}(\$s1)$        |
|                           | sw        | sw \$s0, \$s1           | $\text{memória}(\$s1) = \$s0$        |
| Branch<br>condicional     | beq       | beq \$s0, \$s1, end     | Se $\$s0 = \$s1$ , logo pc=end       |
|                           | bne       | bne \$s0, \$s1, end     | Se $\$s0 \neq \$s1$ , logo<br>pc=end |
| Jump<br>incondicional     | jmp       | jmp end                 | pc=end                               |
| Shift Left<br>Logical     | sll       | sll \$s0, \$s1, desloc. | $\$s1 = \$s0 \ll \text{desloc.}$     |

## Formato das instruções

- Instruções add, sub, and e or

| <b>Opcode</b> | <b>Reg 1</b> | <b>Reg 2</b> | <b>Reg Dst</b> | <b>Don't care</b> | <b>Funct</b> |
|---------------|--------------|--------------|----------------|-------------------|--------------|
| 3 bits        | 3 bits       | 3 bits       | 3 bits         | 2 bits            | 2 bits       |

- Instrução sll

| <b>Opcode</b> | <b>Reg 1</b> | <b>Don't care</b> | <b>Reg Dst</b> | <b>Shamt</b> | <b>Don't care</b> |
|---------------|--------------|-------------------|----------------|--------------|-------------------|
| 3 bits        | 3 bits       | 3 bits            | 3 bits         | 2 bits       | 2 bits            |

- Instruções de Transferência de Dados

| <b>Opcode</b> | <b>Don't care</b> | <b>Reg end</b> | <b>Reg Dst</b> | <b>Don't care</b> |
|---------------|-------------------|----------------|----------------|-------------------|
| 3 bits        | 3 bits            | 3 bits         | 3 bits         | 4 bits            |

- Instruções de Branch condicional

| <b>Opcode</b> | <b>Reg 1</b> | <b>Reg 2</b> | <b>Endereço</b> |
|---------------|--------------|--------------|-----------------|
| 3 bits        | 3 bits       | 3 bits       | 7 bits          |

- Instruções de Jump Incondicional

| <b>Opcode</b> | <b>Don't care</b> | <b>Endereço</b> |
|---------------|-------------------|-----------------|
| 3 bits        | 6 bits            | 7 bits          |

**Tabela de códigos de operação**

| Instrução  | Opcode | Funct |
|------------|--------|-------|
| <b>nop</b> | 000    | --    |
| <b>add</b> |        | 00    |
| <b>sub</b> |        | 01    |
| <b>and</b> |        | 10    |
| <b>or</b>  |        | 11    |
| <b>lw</b>  | 010    | --    |
| <b>sw</b>  | 011    | --    |
| <b>jmp</b> | 100    | --    |
| <b>beq</b> | 101    | --    |
| <b>bne</b> | 110    | --    |
| <b>sll</b> | 111    | --    |

**Tabela de códigos de operação da ULA**

| Operações  | Opcode |
|------------|--------|
| <b>add</b> | 00     |
| <b>sub</b> | 01     |
| <b>and</b> | 10     |
| <b>or</b>  | 11     |

## Máquina de estados do MIPS



## Diagrama de blocos do MIPS



Unidade de Controle