## Modo de Uso do Teste do Mips Pipeline

Grupo 4: Raphael Costa Frederico Curti Elisa Malzoni Bruna Kimura

## Como utilizar o projeto

Para ser possível ver o projeto em seu correto funcionamento foram feitas algumas alterações para mostrar no display de 7 segmentos os valores em alguns sinais no circuito.

A figura abaixo mostra como se configura as chaves (switches) e botões (keys) utilizados.



figura 1 - SW e KEYS utilizadas da FPGA

## Tabela Switches vs Display

A tabela 1 abaixo mostra a relação entre os números gerados pelos switches de 3 à 0, com os valores mostrados pelos displays de 7 segmentos.

Por exemplo, caso queira checar o valor da saída ULA, basta fazer o número três em binário com os switches de 3 à 0 (0011), ou seja, SW0 e SW1 em alta e SW2 e SW3 em baixa. Os valores mostrados pelos display são os 32 bits da saída da ULA escritas em hexadecimal.

| valor<br>do SW<br>(3~0) | HEX<br>0                    | HEX<br>1                       | HEX<br>2                     | HEX<br>3                      | HEX<br>4                      | UX HEX<br>5                   | HEX<br>6                      | HEX<br>7                      |
|-------------------------|-----------------------------|--------------------------------|------------------------------|-------------------------------|-------------------------------|-------------------------------|-------------------------------|-------------------------------|
| 0                       | INST<br>(3~0)               | INST<br>(7~4)                  | INST<br>(11~8)               | INST<br>(15~12)               | INST<br>(19~16)               | INST<br>(23~20)               | INST<br>(27~24)               | INST<br>(31~28)               |
| 1                       | DADO LIDO<br>REG 1<br>(3~0) | DADO<br>LIDO<br>REG 1<br>(7~4) | DADO LIDO<br>REG 1<br>(11~8) | DADO LIDO<br>REG 1<br>(15~12) | DADO LIDO<br>REG 1<br>(19~16) | DADO LIDO<br>REG 1<br>(23~20) | DADO LIDO<br>REG 1<br>(27~24) | DADO LIDO<br>REG 1<br>(31~28) |
| 2                       | DADO LIDO<br>REG 2<br>(3~0) | DADO<br>LIDO<br>REG 2<br>(7~4) | DADO LIDO<br>REG 2<br>(11~8) | DADO LIDO<br>REG 2<br>(15~12) | DADO LIDO<br>REG 2<br>(19~16) | DADO LIDO<br>REG 2<br>(23~20) | DADO LIDO<br>REG 2<br>(27~24) | DADO LIDO<br>REG 2<br>(31~28) |
| 3                       | ULA OUT (3~0)               | ULA OUT<br>(7~4)               | ULA OUT<br>(11~8)            | ULA OUT<br>(15~12)            | ULA OUT<br>(19~16)            | ULA OUT<br>(23~20)            | ULA OUT<br>(27~24)            | ULA OUT<br>(31~28)            |
| 4                       | ULACtrl                     | HAB<br>MEM                     | ZERO                         | BEQ                           | MUX PC<br>BEQ JMP             | HAB<br>ESCRITA<br>REG         | SEL<br>MUX<br>ULA/MEM         | -                             |
| 5                       | MEM W (3~0)                 | MEM W<br>(7~4)                 | MEM W<br>(11~8)              | MEM W<br>(15~12)              | MEM W<br>(19~16)              | MEM W<br>(23~20)              | MEM W<br>(27~24)              | MEM W<br>(31~28)              |
| 6                       | MEM R (3~0)                 | MEM R<br>(7~4)                 | MEM R<br>(11~8)              | MEM R<br>(15~12)              | MEM R<br>(19~16)              | MEM R<br>(23~20)              | MEM R<br>(27~24)              | MEM R<br>(31~28)              |
| 7                       | ENDEREÇO<br>(3~0)           | ENDEREÇ<br>O<br>(7~4)          | ENDEREÇO<br>(11~8)           | ENDEREÇO<br>(15~12)           | ENDEREÇO<br>(19~16)           | ENDEREÇO<br>(23~20)           | ENDEREÇO<br>(27~24)           | ENDEREÇO<br>(31~28)           |
| 8                       | PC OUT (3~0)                | PC OUT<br>(7~4)                | PC OUT<br>(11~8)             | PC OUT<br>(15~12)             | PC OUT<br>(19~16)             | PC OUT<br>(23~20)             | PC OUT<br>(27~24)             | PC OUT<br>(31~28)             |
| 9                       | PC+4<br>+Badd (3~0)         | PC+4<br>+Badd<br>(7~4)         | PC+4<br>+Badd<br>(11~8)      | PC+4<br>+Badd<br>(15~12)      | PC+4<br>+Badd<br>(19~16)      | PC+4<br>+Badd<br>(23~20)      | PC+4<br>+Badd<br>(27~24)      | PC+4<br>+Badd<br>(31~28)      |

| 11 | WRITE<br>REGISTER<br>(QUAL REG)<br>(3~0)        | WRITE<br>REGISTER<br>(4) | -                       | -                        | -                        | -                        |                          |                          |
|----|-------------------------------------------------|--------------------------|-------------------------|--------------------------|--------------------------|--------------------------|--------------------------|--------------------------|
| 13 | WRITE DATA (VALOR ENTRANDO BANCO DE REGS) (3~0) | WRITE<br>DATA<br>(7~4)   | WRITE<br>DATA<br>(11~8) | WRITE<br>DATA<br>(15~12) | WRITE<br>DATA<br>(19~16) | WRITE<br>DATA<br>(23~20) | WRITE<br>DATA<br>(27~24) | WRITE<br>DATA<br>(31~28) |

A imagem abaixo mostra os pontos de debug no diagrama numerados:

