

# UNIVERSIDADE ESTADUAL DE MARINGÁ CENTRO DE TECNOLOGIA - DEPARTAMENTO DE INFORMÁTICA GRADUAÇÃO EM CIÊNCIA DA COMPUTAÇÃO

Prof. Anderson Faustino da Silva

6895 - Arquitetura e Organização de Computadores II Segunda Prova

Ricardo Henrique Brunetto

RA: 94182

Maringá

Agosto - 2017

#### Introdução

O presente documento contém as questões respondidas da segunda prova aplicada pelo Prof. Anderson Faustino da Silva na disciplina de Arquitetura e Organização de Computadores II para a turma de Bacharelado em Ciência da Computação de 2015. Tal documento fora desenvolvido unicamente e explicitamente para o propósito avaliativo.

O conteúdo aqui citado é advindo, além das anotações em aula e materiais disponibilizados pelo professor, da gama de referências bibliográficas por ele recomendadas e encontradas pelo autor. Recomenda-se Monteiro, Tanenbaum e Stallings em caso de dúvidas quanto à nomenclatura utilizada.

#### Questão 01

Para a resolução da questão foi desenvolvido um código em assembly para MIPS32 que realiza a cópia de um subvetor em outro vetor. São argumentados à função copy os seguintes dados:

- \$a0 Endereço do primeiro vetor
- \$a1 Endereço do segundo vetor
- \$a2 Índice inicial
- \$a3 Índice final

O programa, então, copiará os elementos entre, e inclusive, \$a2 e \$a3 do vetor cujo endereço inicial está em \$a0 para o vetor cujo endereço inicial está em \$a1. O detalhamento do código será omitido aqui, uma vez que o mesmo o faz com comentários.

```
. data
  exit_val: .int
3 . text
 # Copia um subvetor de v1 para v2
 # Recebe como parametros
6 # a0 - endereco do primeiro vetor (primeiro elemento do vetor)
 # a1 - endereco do segundo vetor (primeiro elemento do vetor)
 # a2 - indice inicial
 # a3 - indice final
10 # Copia o subvetor a0[a2 ... a3] para a1[0 ... a3-a2]
  copiar_subvetor:
    sub $v0, $a3, $a2
                               # $v0 sera o contador
    1i $at, 4
                           # carrega 4 em $at
13
    mul $a2, $a2, $at
                           \# faz a2 * 4
    add $a0, $a0, $a2
                               # coloca $a0 em $a0[$a2]
    looping:
16
      1w  $at, 0($a0)
                               # carrega o elemento do subvetor para $at
17
      sw $at, 0($a1)
                               # armazena o elemento no vetor
18
      addiu $a0, $a0, 4
                           # avanca 4 bytes em a0
1.9
      addiu $a1, $a1, 4
                           # avanca 4 bytes em a1
20
      addi $v0, $v0, -1
                           # $v0---
21
      bgez $v0, looping
                           # if (\$v0 > 0) looping
  fim:
2.3
    lw $v0, exit_val
24
    syscall
```

../copiar subvetor.s

#### Questão 02

Para tal questão, serão propostas convenções a respeito de detalhes da execução do algoritmo por um simulador hipotético que aplica o algoritmo de Tomasulo com especulação. Convencionase o seguinte:

- O algoritmo de predição de desvios acerta todas as previsões de desvios.
- São emitidas, por ciclo, quantas instruções as Estações de Reserva comportarem, respeitando às seguintes restrições:

Política de emissão *In-Order Issue and Out-of-Order Completion*, o que implica que a emissão respeitará a fila de instruções;

Conflitos de Recursos, onde a emissão cessará;

A execução (despacho para a Unidade Funcional) se iniciará apenas quando não houver mais dependências verdadeiras.

 A quantidade de ciclos de cada instrução do código obedece ao especificado pela arquitetura MIPS32, a saber:

```
add, sub, addi, addiu e li custam 2 ciclos de clock;
```

1w e sw custam 4 ciclos de clock;

bgez custa 2 ciclos de clock;

mul custa 5 ciclos de clock.

- A chamada de sistema (syscall) para pôr fim à execução aguarda até que todas as outras
   Estações de Reserva tenham finalizado o processamento.
- Quanto às Estações de Reserva (cada qual com uma única Unidade Funcional acoplada):
  - 3 Estações de Reserva para operações lógicas e aritméticas;
  - 2 Estações de Reserva para operações de multiplicação e divisão;
  - 5 Estações de Reserva para carregamento de dados (*load*);
  - 5 Estações de Reserva para armazenamento de dados (*store*).

A cada ciclo passado, informar-se-á quais instruções foram despachadas (inciaram a execução, de fato) e quais estão executando naquele ciclo, através do índice (nome) da Estação de Reserva que a comporta. Além disso, serão omitidos registradores não-utilizados do Banco de Registradores. A nomenclatura dos campos das Estações de Reserva e do Banco de Registradores obecede à estabelecida por Hennessy and Patterson (2008).

Supõe-se a execução do código da Questão 01 com os seguintes parâmetros:

- \$a0 = &src (Endereço do primeiro vetor)
- \$a1 = &dst (Endereço do segundo vetor)

- \$a2 = 1 (Índice inicial)
- \$a3 = 3 (Índice final)

```
onde src = \{45, 23, 12, 29, 10\} e dst = \{0, 0, 0, 14, 23\}.
```

Dessa forma, a execução deve resultar em dst = {23, 12, 29, 14, 23}. A execução passo-a-passo encontra-se nos Apêndices deste documento.<sup>1</sup>

#### Questão 03

Para tal, utilizar-se-á da prova por meio da demonstração da quantidade de ciclos de clock.

Percebe-se que executar o algoritmo da Questão 01 em um pipeline escalar sem a especulação não garante a prova formal de tal afirmação, uma vez que utilizar-se-ía de um exemplo em particular na tentativa de demonstrar uma propriedade global, de modo que não se pode garantir a generalização, ainda que intuitivamente isso seja evidenciado.

Supõe-se k o número de ciclos necessários para executar um determinado algoritmo com as especificações de simulação da Questão 02 (Tomasulo com especulação). Dessa forma, para o caso específico tratado na Questão 02 (parâmetros dados) e envolvendo o algoritmo da Questão 01, por exemplo, tem-se k=23.

Seja c a quantidade máxima de ciclos necessária para se resolver a condição de qualquer desvio implementado pela arquitetura em questão (sem especificamente tratar da MIPS32, onde c=2). É importante salientar que, em todos os casos, as comparações são dadas entre os desempenhos supondo entradas idênticas para ambas as configurações de simulação (com especulação e sem especulação). Note que, c pode variar muito além, na prática, por limitações da ILP, como **dependências verdadeiras**. No entanto, ambas as configurações consideradas estão sujeitas à tal variação e, portanto, ela **não** será considerada na análise a seguir.

Nota-se que, ao seguir a política de emissão *In-Order Issue and Out-of-Order Completion* sem a implementação de algoritmos de predição de desvios ou de execução especulativa, deve-se **cessar a emissão** a cada vez que um desvio condicional for emitido. Isso porque o Processador

<sup>&</sup>lt;sup>1</sup>Os filetes preenchidos de cor mais escura denotam que, no ciclo em questão, não houve nenhuma emissão e nenhuma alteração no vetor de destino.

não tem mecanismos para controlar as emissões enquanto não houver o cômputo da condição.

Seja x o número de desvios condicionais espalhados pelo código que devem ser executados pelo Processador. Dessa forma, ter-se-á, ao menos  $x \times c$  ciclos de clock em que as emissões serão suspendidas. Logicamente, estes  $x \times c$  ciclos de clock estão contidos nos k ciclos totais de uma configuração com especulação, visto que, de qualquer forma, as condições dos desvios devem ser computadas. No entanto, durante estes ciclos em que as condições estão sendo computadas **podem** haver outras instruções na Fila de Instruções com condições necessárias atendidas para serem emitidas. Assim, a eficiência da especulação se dá pelas instruções que se emite e computa enquanto a condição do desvio está sendo calculada (quando possível, visto que há casos de limitação de recursos em que não se pode realizar emissões ou execuções).

No melhor caso, o algoritmo de predição terá acertado e as instruções que foram processadas enquanto a condição não havia sido completa deveriam, de fato, ter sido executadas e não perdeu-se c ciclos aguardando para enviar as instruções à execução (evitou-se um stall de c ciclos no pipeline). Por outro lado, no pior caso, o algoritmo de predição de desvios terá feito uma suposição errada quanto à tomada do salto e o processamento das outras instruções, realizado durante os c ciclos que a condição levou, terá sido "despediçado", visto que elas não serão efetivadas. No entanto, caso não houvesse especulação, estes c ciclos teriam, de fato, servido **apenas** para o cálculo da condição (desconsiderando o que já estava em execução na emissão do desvio).

Assim, no pior dos casos da execução especulativa, tem-se o mesmo caso da execução sem especulação (com *stall* no pipeline). Isso implica que:

$$k \le k + (x \times c) \ \forall x, c \ge 0$$

Para fins de exemplo, assume-se que deseja-se executar a mesma sequência de código da Questão 01 (copiar\_subvetor) em uma máquina onde não haja implementação de especulação, bem como nenhum algoritmo de predição de desvios. Nesse caso, para a máquina sem predição, como foi suposto, ter-se-ia de cessar a emissão a cada emissão da instrução bgez do código copiar\_subvetor, na arquitetura MIPS32. Como bgez é emitido 3 vezes e o processamento de sua condição se dá em 2 ciclos, haveria, ao menos 6 ciclos onde nenhuma instrução é emitida.

Isso implica que o total de ciclos para a execução do algoritmo seria **em torno de**<sup>2</sup> 29 ciclos. No entanto, o mínimo seria de 26 ciclos.

#### Questão 04

Para tal questão, propõe-se dois códigos a serem executados em paralelo. Tais códigos manipulam as variáveis globais inteiras a, b e c.

```
void foo(){
                                     void bar() {
  write(b);
                                       read(a);
  read(a);
                                       write(c);
                                       read(c);
  write(c);
  write(a);
                                       read(b);
  read(b);
                                       write(a);
                                       write(b);
  read(a);
   ../paralelo 1.c
                                        ../paralelo 2.c
```

As funções read e write implicam em uma leitura e uma escrita, respectivamente, da variável passada como parâmetro. Tal função exemplifica, de maneira abstrata, uma leitura de um valor da memória e sua correspondente escrita.

Dessa forma, aplicar-se-á os Protocolos de Coerência de Cache de Invalidação de Dados MSI, MESI e MOESI. Para todos os casos, supõe-se que as três variáveis encontram-se em linhas diferentes da Cache. No decorrer da execução, supõe-se que cada um dos fluxos é executado por um processador diferente ( $P_0$  executará paralelo\_1 enquanto  $P_1$  executará paralelo\_2). Serão desprezados efeitos externos de outras questões de projeto no que tange ao Paralelismo à Nível de Fluxo (*Thread Level Parallelism - TLP*), bem como efeitos internos de questões relativas ao Paralelismo à Nível de Instrução (*Instruction Level Parallelism - ILP*), uma vez que há interesse apenas no comportamento dos Controladores de Cache em relação ao protocolo (e às requisições).

<sup>&</sup>lt;sup>2</sup>Isso se deve ao fato de que uma emissão tardia poderia evitar dependências verdadeiras com instruções que já estão em execução, ou, ainda causá-las em consequência de não terem ainda saído do pipeline (efeito cascata).

Para todos os protocolos, a execução é realizada em **passos** (ou momentos), de modo que não se considera a unidade de tempo em ciclos de clock. Isso serve para simplificar a execução e abstrair detalhes não relevantes à aplicação do protocolo em questão. Cada passo possui um **indicador** para explicitar a ordem em que tais requisições ocorreram (ex: 2.1 significa que tal requisição foi a primeira a ocorrer no passo 2), visto que uma requisição interna do Processadodr pode gerar uma requisição externa para outro Controlador de Cache (que, no caso, seria denotado por 2.2).

Quanto à notação, utiliza-se a seguinte:

[Passo.Indicador]: requisição | Estado\_Antigo  $\rightarrow$  Estado\_Novo |  $L_{variavel}$ 

onde  $L_{variavel}$  indica a Linha da Cache em que a variavel está armazenada.

#### Protocolo MSI

Para tal protocolo, tem-se:

#### Vantagens

Custo e complexidade baixos.

Alto desempenho.

#### Desvantagens

Alto tráfego no baramento causado por leituras seguidas de escritas gerando duas requisições externas seguidas.

Alto tráfego no baramento e alto custo causado pelo *flush* (*write-back*) de blocos que são lidos por outras caches.

Aplicação do protocolo:

| ${ m P_0}({ m paralelo\_1})$                  | ${ m P_1}({ m paralelo\_2})$                        |
|-----------------------------------------------|-----------------------------------------------------|
| [1.1]: write_miss   I $\rightarrow$ M   $L_b$ |                                                     |
|                                               | [2.1]: read_miss   I $\rightarrow$ S   $L_a$        |
| [3.1]: read_miss $  I \rightarrow S   L_a$    | [3.2]: REQ_read   S $\rightarrow$ S   $L_a$         |
|                                               | [4.1]: write_miss   I $\rightarrow$ M   $L_c$       |
| [5.1]: write_miss   I $\rightarrow$ M   $L_c$ | [5.2]: REQ_write   M $\rightarrow$ I   $L_c$        |
| [6.2]: REQ_read   M $\rightarrow$ S   $L_c$   | [6.1]: read_miss   I $\rightarrow$ S   $L_c$        |
| [7.1]: write_hit   $S \rightarrow M \mid L_a$ | [7.2]: REQ_write   $S \rightarrow I   L_a$          |
| [8.2]: REQ_read   M $\rightarrow$ S   $L_b$   | [8.1]: read_miss   I $\rightarrow$ S   $L_b$        |
| [9.1]: read_hit   $S \rightarrow S   L_b$     |                                                     |
| [10.2]: REQ_write   M $\rightarrow$ I   $L_a$ | [10.1]: write_miss   I $\rightarrow$ M   $L_a$      |
| [11.1]: read_miss   I $\rightarrow$ S   $L_a$ | [11.2]: REQ_read   M $\rightarrow$ S   $L_a$        |
| [12.2]: REQ_write   S $\rightarrow$ I   $L_b$ | [12.1]: write_hit $\mid$ $S \rightarrow M \mid L_b$ |

#### Protocolo MESI

Para tal protocolo, tem-se:

#### • Vantagens

Custo e complexidade relativamente baixos.

Soluciona o problema do alto tráfego no baramento causado por leituras seguidas de escritas gerando duas requisições externas seguidas. ISso porque se o Controlador da Cache necessitar modificar uma linha de cache que está no estado exclusivo, nenhuma comunicação via barramento é necessitada.

#### Desvantagens

Mantém o problema de alto tráfego no baramento e alto custo causado pelo *flush* (*write-back*) de blocos que são lidos por outras caches.

Torna o estado compartilhado "impreciso", uma vez que caso uma linha esteja no estado compartilhado e, posteriormente, os demais Controladores de Cache a removam de suas respectivas caches, então aquele dado será único no sistema, mas não será promovido.

Aplicação do protocolo:

| ${ m P_0}({ m paralelo\_1})$                      | P <sub>1</sub> (paralelo_2)                       |
|---------------------------------------------------|---------------------------------------------------|
| [1.1]: write_miss   I $\rightarrow$ M   $L_b$     |                                                   |
|                                                   | [2.1]: read_miss   I $\rightarrow$ E   $L_a$      |
| [3.1]: read_miss $  I \rightarrow S   L_a$        | [3.2]: REQ_read   E $\rightarrow$ S   $L_a$       |
|                                                   | [4.1]: write_miss   I $\rightarrow$ M   $L_c$     |
| [5.1]: write_miss   I $\rightarrow$ M   $L_c$     | [5.2]: REQ_write   M $\rightarrow$ I   $L_c$      |
| [6.2]: REQ_read   M $\rightarrow$ S   $L_c$       | [6.1]: read_miss   I $\rightarrow$ S   $L_c$      |
| [7.1]: write_hit   $S \rightarrow M \mid L_a$     | [7.2]: REQ_write   S $\rightarrow$ I   $L_a$      |
| [8.2]: REQ_read   M $\rightarrow$ S   $L_b$       | [8.1]: read_miss   I $\rightarrow$ S   $L_b$      |
| [9.1]: read_hit   $S \rightarrow S   L_b$         |                                                   |
| [10.2]: REQ_write   M $\rightarrow$ I   $L_a$     | [10.1]: write_miss $  I \rightarrow M   L_a$      |
| [11.1]: read_miss   I $\rightarrow$ S   $L_a$     | [11.2]: REQ_read   M $\rightarrow$ S   $L_a$      |
| [12.2]: REQ_write $\mid S \rightarrow I \mid L_b$ | [12.1]: write_hit $\mid S \rightarrow M \mid L_b$ |

#### Protocolo MOESI

Para tal protocolo, tem-se:

#### • Vantagens

Não há alto tráfego no baramento causado por leituras seguidas de escritas gerando duas requisições externas seguidas.

Não há alto tráfego no baramento e alto custo causado pelo *flush* (*write-back*) de blocos que são lidos por outras caches.

Fornece melhor desempenho em multiprocessadores.

#### • Desvantagens

Alta complexidade.

Incorpora o conceito de linha suja na cache.

Aplicação do protocolo:

| ${ m P_0}({ m paralelo\_1})$                            | P <sub>1</sub> (paralelo_2)                       |
|---------------------------------------------------------|---------------------------------------------------|
| [1.1]: write_miss   I $\rightarrow$ M   $L_b$           |                                                   |
|                                                         | [2.1]: read_miss   I $\rightarrow$ E   $L_a$      |
| [3.1]: read_miss $  I \rightarrow S   L_a$              | [3.2]: REQ_read   E $\rightarrow$ S   $L_a$       |
|                                                         | [4.1]: write_miss   I $\rightarrow$ M   $L_c$     |
| [5.1]: write_miss   I $\rightarrow$ M   $L_c$           | [5.2]: REQ_write   M $\rightarrow$ I   $L_c$      |
| [6.2]: REQ_read   M $\rightarrow$ O   $L_c$             | [6.1]: read_miss   I $\rightarrow$ S   $L_c$      |
| [7.1]: write_hit   $S \rightarrow M \mid L_a$           | [7.2]: REQ_write   S $\rightarrow$ I   $L_a$      |
| [8.2]: REQ_read   M $\rightarrow$ O   $L_b$             | [8.1]: read_miss   I $\rightarrow$ S   $L_b$      |
| [9.1]: read_hit   O $\rightarrow$ O   $L_b$             |                                                   |
| [10.2]: REQ_write   M $\rightarrow$ I   $L_a$           | [10.1]: write_miss   I $\rightarrow$ M   $L_a$    |
| [11.1]: read_miss   I $\rightarrow$ S   $L_a$           | [11.2]: REQ_read   M $\rightarrow$ O   $L_a$      |
| [12.2]: REQ_write $\mid$ O $\rightarrow$ I $\mid$ $L_b$ | [12.1]: write_hit $\mid S \rightarrow M \mid L_b$ |

#### Questão 05

Para tal questão toma-se como base a ideia de que a Barreira deve impor dependência (sequência ordenada obrigatória) entre trechos de código (fases do programa) paralelos.

A implementação de uma Barreira ocorre via um **Contador**. No entanto, incrementa-se uma variável compartilhada e, portanto, tal incremento deve ser **atômico**. É importante considerar que, em MIPS32, os parâmetros são enviados pelos registradores (inciando de \$a0). O código desenvolvido é o exposto abaixo:

```
. data
 shared_count: .int 0
3 . text
 inicializar_barreira:
   move $a0, $a1 # a0 = endereco da variavel da barreira / a1 = numero de
       threads
7 jr $ra
  executar_barreira:
    fi shared_count # fetch_and_increment shared_count (atomico)
    looping:
     lw $v0, shared_count
12
     bne $v0, $a0, looping # segura enquanto shared_count for differente do
13
         numero de threads
14 jr $ra
```

../barreira.s

#### Referências

John L. Hennessy and David A. Patterson. *Arquitetura de Computadores*, volume 1. Elsevier, 4 edition, 2008.

Mario A. Monteiro. Introdução à Organização de Computadores, volume 1. LTC, 5 edition, 2010.

William Stallings. Computer Organization and Architecture, volume 5. Prentice Hall, 1999.

Andrew S. Tanenbaum. *Organização Estruturada de Computadores*, volume 1. Pearson, 5 edition, 2007.

## Apêndices

|        |      |     |      |      |       |             | Ciclo 1    |           |             |       |                    |
|--------|------|-----|------|------|-------|-------------|------------|-----------|-------------|-------|--------------------|
| ER     | Busy | 0p  | Qj   | Vj   | Qk    | Vk          | Α          | Reg       | Qi          | Valor | Fila de Instruções |
| add1   | 1    | sub | 0    | 3    | 0     | 1           |            | a0        | add3        | &src  | addiu              |
| add2   | 1    | li  |      |      |       |             | 4          | a1        | 0           | &dst  | addiu              |
| add3   | 1    | add | 0    | &src | mul1  |             |            | a2        | mul1        | 1     | addi               |
| mul1   | 1    | mul | 0    | 1    | add2  |             |            | a3        | 0           | 3     | bgez               |
| mul2   | 0    |     |      |      |       |             |            | v0        | add1        | 0     |                    |
| load1  | 1    | lw  | add3 |      |       |             | 0          | at        | load1       | 0     |                    |
| load2  | 0    |     |      |      |       |             |            |           |             |       |                    |
| load3  | 0    |     |      |      |       |             |            |           | Despachadas |       |                    |
| load4  | 0    |     |      |      |       |             |            | add1      | add2        |       |                    |
| load5  | 0    |     |      |      |       |             |            |           |             |       |                    |
| store1 | 1    | SW  | 0    | &dst | load1 |             | 0          |           |             |       |                    |
| store2 | 0    |     |      |      |       |             |            |           | Executando  |       |                    |
| store3 | 0    |     |      |      |       |             |            | add1(1/2) | add2(1/2)   |       |                    |
| store4 | 0    |     |      |      |       |             |            |           |             |       |                    |
| store5 | 0    |     |      |      |       |             |            |           |             |       |                    |
|        |      |     |      |      |       | $dst = \{0$ | , 0, 0, 14 | 4, 23}    |             |       |                    |

|        |      |     |      |      |       |          | Ciclo 2    |           |             |       |                    |
|--------|------|-----|------|------|-------|----------|------------|-----------|-------------|-------|--------------------|
| ER     | Busy | Ор  | Qj   | Vj   | Qk    | Vk       | Α          | Reg       | Qi          | Valor | Fila de Instruções |
| add1   | 1    | sub | 0    | 3    | 0     | 1        |            | a0        | add3        | &src  | addiu              |
| add2   | 1    | li  |      |      |       |          | 4          | a1        | 0           | &dst  | addiu              |
| add3   | 1    | add | 0    | &src | mul1  |          |            | a2        | mul1        | 1     | addi               |
| mul1   | 1    | mul | 0    | 1    | add2  |          |            | a3        | 0           | 3     | bgez               |
| mul2   | 0    |     |      |      |       |          |            | v0        | add1        | 0     |                    |
| load1  | 1    | lw  | add3 |      |       |          | 0          | at        | load1       | 0     |                    |
| load2  | 0    |     |      |      |       |          |            |           |             |       |                    |
| load3  | 0    |     |      |      |       |          |            |           | Despachadas |       |                    |
| load4  | 0    |     |      |      |       |          |            |           |             |       |                    |
| load5  | 0    |     |      |      |       |          |            |           |             |       |                    |
| store1 | 1    | SW  | 0    | &dst | load1 |          | 0          |           |             |       |                    |
| store2 | 0    |     |      |      |       |          |            |           | Executando  |       |                    |
| store3 | 0    |     |      |      |       |          |            | add1(2/2) | add2(2/2)   |       |                    |
| store4 | 0    |     |      |      |       |          |            |           |             |       |                    |
| store5 | 0    |     |      |      |       |          |            |           |             |       |                    |
|        |      |     |      |      |       | dst = {0 | , 0, 0, 14 | 1, 23}    |             |       |                    |

|        |      |       |      |      |       |          | Ciclo 3    |           |             |       |                    |
|--------|------|-------|------|------|-------|----------|------------|-----------|-------------|-------|--------------------|
| ER     | Busy | 0p    | Qj   | Vj   | Qk    | Vk       | Α          | Reg       | Qi          | Valor | Fila de Instruções |
| add1   | 1    | addiu | add3 |      |       |          | 4          | a0        | add1        | &src  | addi               |
| add2   | 1    | addiu | 0    | &dst |       |          | 4          | a1        | add2        | &dst  | bgez               |
| add3   | 1    | add   | 0    | &src | mul1  |          |            | a2        | mul1        | 1     |                    |
| mul1   | 1    | mul   | 0    | 1    | 0     | 4        |            | a3        | 0           | 3     |                    |
| mul2   | 0    |       |      |      |       |          |            | v0        | 0           | 2     |                    |
| load1  | 1    | lw    | add3 |      |       |          | 0          | at        | load1       | 0     |                    |
| load2  | 0    |       |      |      |       |          |            |           |             |       |                    |
| load3  | 0    |       |      |      |       |          |            |           | Despachadas |       |                    |
| load4  | 0    |       |      |      |       |          |            | mul1      | add2        |       |                    |
| load5  | 0    |       |      |      |       |          |            |           |             |       |                    |
| store1 | 1    | SW    | 0    | &dst | load1 |          | 0          |           |             |       |                    |
| store2 | 0    |       |      |      |       |          |            |           | Executando  |       |                    |
| store3 | 0    |       |      |      |       |          |            | mul1(1/5) | add2(1/2)   |       |                    |
| store4 | 0    |       |      |      |       |          |            |           |             |       |                    |
| store5 | 0    |       |      |      |       |          |            |           |             |       |                    |
|        |      |       |      | •    |       | dst = {0 | , 0, 0, 14 | 4, 23}    |             |       |                    |

|        | Ciclo 4 |       |      |      |       |    |   |           |             |        |                    |  |  |  |
|--------|---------|-------|------|------|-------|----|---|-----------|-------------|--------|--------------------|--|--|--|
| ER     | Durant  | 0     | 0-:  | \/-  | Ole   | Vk |   | Dog       | 0:          | Valor  | Fila de Instruções |  |  |  |
| EK     | Busy    | 0p    | Qj   | Vj   | Qk    | VK | Α | Reg       | Qi          | Agrot. | riia de instruções |  |  |  |
| add1   | 1       | addiu | add3 |      |       |    | 4 | a0        | add1        | &src   | addi               |  |  |  |
| add2   | 1       | addiu | 0    | &dst |       |    | 4 | a1        | add2        | &dst   | bgez               |  |  |  |
| add3   | 1       | add   | 0    | &src | mul1  |    |   | a2        | mul1        | 1      |                    |  |  |  |
| mul1   | 1       | mul   | 0    | 1    | 0     | 4  |   | a3        | 0           | 3      |                    |  |  |  |
| mul2   | 0       |       |      |      |       |    |   | v0        | 0           | 2      |                    |  |  |  |
| load1  | 1       | lw    | add3 |      |       |    | 0 | at        | load1       | 0      |                    |  |  |  |
| load2  | 0       |       |      |      |       |    |   |           |             |        |                    |  |  |  |
| load3  | 0       |       |      |      |       |    |   |           | Despachadas |        |                    |  |  |  |
| load4  | 0       |       |      |      |       |    |   |           |             |        |                    |  |  |  |
| load5  | 0       |       |      |      |       |    |   |           |             |        |                    |  |  |  |
| store1 | 1       | SW    | 0    | &dst | load1 |    | 0 |           |             |        |                    |  |  |  |
| store2 | 0       |       |      |      |       |    |   |           | Executando  |        |                    |  |  |  |
| store3 | 0       |       |      |      |       |    |   | mul1(2/5) | add2(2/2)   |        |                    |  |  |  |

| store4 | 0 |  |  |          |            |        |  |  |  |
|--------|---|--|--|----------|------------|--------|--|--|--|
| store5 | 0 |  |  |          |            |        |  |  |  |
|        |   |  |  | dst = {0 | , 0, 0, 14 | 1, 23} |  |  |  |

|        |      |       |      |      |       |          | Ciclo 5   |           |             |        |                    |
|--------|------|-------|------|------|-------|----------|-----------|-----------|-------------|--------|--------------------|
| ER     | Busy | 0p    | Qj   | Vj   | Qk    | Vk       | Α         | Reg       | Qi          | Valor  | Fila de Instruções |
| add1   | 1    | addiu | add3 |      |       |          | 4         | a0        | add1        | &src   | bgez               |
| add2   | 1    | addi  | 0    | 2    |       |          | -1        | a1        | 0           | &dst+4 |                    |
| add3   | 1    | add   | 0    | &src | mul1  |          |           | a2        | mul1        | 1      |                    |
| mul1   | 1    | mul   | 0    | 1    | 0     | 4        |           | a3        | 0           | 3      |                    |
| mul2   | 0    |       |      |      |       |          |           | v0        | add2        | 2      |                    |
| load1  | 1    | lw    | add3 |      |       |          | 0         | at        | load1       | 0      |                    |
| load2  | 0    |       |      |      |       |          |           |           |             |        |                    |
| load3  | 0    |       |      |      |       |          |           |           | Despachadas |        |                    |
| load4  | 0    |       |      |      |       |          |           | add2      |             |        |                    |
| load5  | 0    |       |      |      |       |          |           |           |             |        |                    |
| store1 | 1    | SW    | 0    | &dst | load1 |          | 0         |           |             |        |                    |
| store2 | 0    |       |      |      |       |          |           |           | Executando  |        |                    |
| store3 | 0    |       |      |      |       |          |           | mul1(3/5) | add2(1/2)   |        |                    |
| store4 | 0    |       |      |      |       |          |           |           |             |        |                    |
| store5 | 0    |       |      |      |       |          |           |           |             |        |                    |
|        |      |       |      |      |       | dst = {0 | , 0, 0, 1 | 4, 23}    |             |        |                    |

|        |      |       |      |      |       |          | Ciclo 6   |           |             |        |                    |
|--------|------|-------|------|------|-------|----------|-----------|-----------|-------------|--------|--------------------|
| ER     | Busy | 0p    | Qj   | Vj   | Qk    | Vk       | Α         | Reg       | Qi          | Valor  | Fila de Instruções |
| add1   | 1    | addiu | add3 |      |       |          | 4         | a0        | add1        | &src   | bgez               |
| add2   | 1    | addi  | 0    | 2    |       |          | -1        | a1        | 0           | &dst+4 |                    |
| add3   | 1    | add   | 0    | &src | mul1  |          |           | a2        | mul1        | 1      |                    |
| mul1   | 1    | mul   | 0    | 1    | 0     | 4        |           | a3        | 0           | 3      |                    |
| mul2   | 0    |       |      |      |       |          |           | v0        | add2        | 2      |                    |
| load1  | 1    | lw    | add3 |      |       |          | 0         | at        | load1       | 0      |                    |
| load2  | 0    |       |      |      |       |          |           |           |             |        |                    |
| load3  | 0    |       |      |      |       |          |           |           | Despachadas |        |                    |
| load4  | 0    |       |      |      |       |          |           |           |             |        |                    |
| load5  | 0    |       |      |      |       |          |           |           |             |        |                    |
| store1 | 1    | SW    | 0    | &dst | load1 |          | 0         |           |             |        |                    |
| store2 | 0    |       |      |      |       |          |           |           | Executando  |        |                    |
| store3 | 0    |       |      |      |       |          |           | mul1(4/5) | add2(2/2)   |        |                    |
| store4 | 0    |       |      |      |       |          |           |           |             |        |                    |
| store5 | 0    |       |      |      |       |          |           |           |             |        |                    |
|        |      |       |      |      |       | dst = {0 | , 0, 0, 1 | 4, 23}    |             |        |                    |

|        |      |       |      |        |       |          | Ciclo 7   |           |             |        |                    |
|--------|------|-------|------|--------|-------|----------|-----------|-----------|-------------|--------|--------------------|
| ER     | Busy | 0p    | Qj   | Vj     | Qk    | Vk       | Α         | Reg       | Qi          | Valor  | Fila de Instruções |
| add1   | 1    | addiu | add3 |        |       |          | 4         | a0        | add1        | &src   | addiu              |
| add2   | 1    | bgez  | 0    | 1      |       |          |           | a1        | 0           | &dst+4 | addiu              |
| add3   | 1    | add   | 0    | &src   | mul1  |          |           | a2        | mul1        | 1      | addi               |
| mul1   | 1    | mul   | 0    | 1      | 0     | 4        |           | a3        | 0           | 3      | bgez               |
| mul2   | 0    |       |      |        |       |          |           | v0        | 0           | 1      |                    |
| load1  | 1    | lw    | add3 |        |       |          | 0         | at        | load2       | 0      |                    |
| load2  | 1    | lw    | add1 |        |       |          | 0         |           |             |        |                    |
| load3  | 0    |       |      |        |       |          |           |           | Despachadas |        |                    |
| load4  | 0    |       |      |        |       |          |           | add2      |             |        |                    |
| load5  | 0    |       |      |        |       |          |           |           |             |        |                    |
| store1 | 1    | SW    | 0    | &dst   | load1 |          | 0         |           |             |        |                    |
| store2 | 1    | SW    | 0    | &dst+4 | load2 |          | 0         |           | Executando  |        |                    |
| store3 | 0    |       |      |        |       |          |           | mul1(5/5) | add2(1/2)   | ·      |                    |
| store4 | 0    |       |      |        |       |          |           |           |             |        |                    |
| store5 | 0    |       |      |        |       |          |           |           |             |        |                    |
|        | ,    |       |      |        |       | dst = {0 | , 0, 0, 1 | 4, 23}    | •           |        |                    |

|       | Ciclo 8 |       |      |      |    |    |   |      |       |        |                    |  |  |  |
|-------|---------|-------|------|------|----|----|---|------|-------|--------|--------------------|--|--|--|
| ER    | Busy    | Ор    | Qj   | Vj   | Qk | Vk | Α | Reg  | Qi    | Valor  | Fila de Instruções |  |  |  |
| add1  | 1       | addiu | add3 |      |    |    | 4 | a0   | add1  | &src   | addiu              |  |  |  |
| add2  | 1       | bgez  | 0    | 1    |    |    |   | a1   | 0     | &dst+4 | addiu              |  |  |  |
| add3  | 1       | add   | 0    | &src | 0  | 4  |   | a2   | 0     | 4      | addi               |  |  |  |
| mul1  | 0       |       |      |      |    |    |   | a3   | 0     | 3      | bgez               |  |  |  |
| mul2  | 0       |       |      |      |    |    |   | v0   | 0     | 1      |                    |  |  |  |
| load1 | 1       | lw    | add3 |      |    |    | 0 | at   | load2 | 0      |                    |  |  |  |
| load2 | 1       | lw    | add1 |      |    |    | 0 |      |       |        |                    |  |  |  |
| load3 | 0       |       |      |      |    |    |   |      |       |        |                    |  |  |  |
| load4 | 0       |       |      |      |    |    |   | add3 |       |        |                    |  |  |  |

|        |                         |    |   |        |       |  |   |           |            | _ |  |  |  |
|--------|-------------------------|----|---|--------|-------|--|---|-----------|------------|---|--|--|--|
| load5  | 0                       |    |   |        |       |  |   |           |            |   |  |  |  |
| store1 | 1                       | SW | 0 | &dst   | load1 |  | 0 |           |            |   |  |  |  |
| store2 | 1                       | SW | 0 | &dst+4 | load2 |  | 0 |           | Executando |   |  |  |  |
| store3 | 0                       |    |   |        |       |  |   | add2(2/2) | add3(1/2)  |   |  |  |  |
| store4 | 0                       |    |   |        |       |  |   |           |            |   |  |  |  |
| store5 | 0                       |    |   |        |       |  |   |           |            |   |  |  |  |
|        | dst = {0, 0, 0, 14, 23} |    |   |        |       |  |   |           |            |   |  |  |  |

|        |      |       |      |        |       |    | Ciclo 9 |           |             |        |                   |
|--------|------|-------|------|--------|-------|----|---------|-----------|-------------|--------|-------------------|
| ER     | Busy | 0p    | Qj   | Vj     | Qk    | Vk | Α       | Reg       | Qi          | Valor  | Fila de Instruçõe |
| add1   | 1    | addiu | add3 |        |       |    | 4       | a0        | add2        | &src   | addiu             |
| add2   | 1    | addiu | add1 |        |       |    | 4       | a1        | 0           | &dst+4 | addi              |
| add3   | 1    | add   | 0    | &src   | 0     | 4  |         | a2        | 0           | 4      | bgez              |
| mul1   | 0    |       |      |        |       |    |         | a3        | 0           | 3      |                   |
| mul2   | 0    |       |      |        |       |    |         | v0        | 0           | 1      |                   |
| load1  | 1    | lw    | add3 |        |       |    | 0       | at        | load2       | 0      |                   |
| load2  | 1    | lw    | add1 |        |       |    | 0       |           |             |        |                   |
| load3  | 0    |       |      |        |       |    |         |           | Despachadas |        |                   |
| load4  | 0    |       |      |        |       |    |         |           |             |        |                   |
| load5  | 0    |       |      |        |       |    |         |           |             |        |                   |
| store1 | 1    | SW    | 0    | &dst   | load1 |    | 0       |           |             |        |                   |
| store2 | 1    | SW    | 0    | &dst+4 | load2 |    | 0       |           | Executando  |        |                   |
| store3 | 0    |       |      |        |       |    |         | add3(2/2) | •           | •      |                   |
| store4 | 0    |       |      |        |       |    |         | ][        |             |        |                   |
| store5 | 0    |       |      |        |       |    |         | 11        |             |        |                   |

|        |      |       |      |                         |       | (  | Ciclo 10 |           |             |           |                    |  |  |  |  |
|--------|------|-------|------|-------------------------|-------|----|----------|-----------|-------------|-----------|--------------------|--|--|--|--|
| ER     | Busy | 0p    | Qj   | Vj                      | Qk    | Vk | Α        | Reg       | Qi          | Valor     | Fila de Instruções |  |  |  |  |
| add1   | 1    | addiu | 0    | &src+4                  |       |    | 4        | a0        | add2        | &src      | addi               |  |  |  |  |
| add2   | 1    | addiu | add1 |                         |       |    | 4        | a1        | add3        | &dst+4    | bgez               |  |  |  |  |
| add3   | 1    | addiu | 0    | &dst+4                  |       |    | 4        | a2        | 0           | 4         |                    |  |  |  |  |
| mul1   | 0    |       |      |                         |       |    |          | a3        | 0           | 3         |                    |  |  |  |  |
| mul2   | 0    |       |      |                         |       |    |          | v0        | 0           | 1         |                    |  |  |  |  |
| load1  | 1    | lw    | 0    | &src+4                  |       |    | 0        | at        | load2       | 0         |                    |  |  |  |  |
| load2  | 1    | lw    | add1 |                         |       |    | 0        |           |             |           |                    |  |  |  |  |
| load3  | 0    |       |      |                         |       |    |          |           | Despachadas |           |                    |  |  |  |  |
| load4  | 0    |       |      |                         |       |    |          | add1      | load1       | add3      |                    |  |  |  |  |
| load5  | 0    |       |      |                         |       |    |          |           |             |           |                    |  |  |  |  |
| store1 | 1    | SW    | 0    | &dst                    | load1 |    | 0        |           |             |           |                    |  |  |  |  |
| store2 | 1    | SW    | 0    | &dst+4                  | load2 |    | 0        |           | Executando  |           |                    |  |  |  |  |
| store3 | 0    |       |      |                         |       |    |          | add1(1/2) | load1(1/4)  | add3(1/2) |                    |  |  |  |  |
| store4 | 0    |       |      |                         |       |    |          |           |             |           |                    |  |  |  |  |
| store5 | 0    |       |      |                         |       |    |          |           |             |           |                    |  |  |  |  |
|        |      |       |      | dst = {0, 0, 0, 14, 23} |       |    |          |           |             |           |                    |  |  |  |  |

|        |      |       |      |        |       | (        | Ciclo 11  |           |             |           |                    |
|--------|------|-------|------|--------|-------|----------|-----------|-----------|-------------|-----------|--------------------|
| ER     | Busy | 0p    | Qj   | Vj     | Qk    | Vk       | Α         | Reg       | Qi          | Valor     | Fila de Instruções |
| add1   | 1    | addiu | 0    | &src+4 |       |          | 4         | a0        | add2        | &src      | addi               |
| add2   | 1    | addiu | add1 |        |       |          | 4         | a1        | add3        | &dst+4    | bgez               |
| add3   | 1    | addiu | 0    | &dst+4 |       |          | 4         | a2        | 0           | 4         |                    |
| mul1   | 0    |       |      |        |       |          |           | a3        | 0           | 3         |                    |
| mul2   | 0    |       |      |        |       |          |           | v0        | 0           | 1         |                    |
| load1  | 1    | lw    | 0    | &src+4 |       |          | 0         | at        | load2       | 0         |                    |
| load2  | 1    | lw    | add1 |        |       |          | 0         |           |             |           |                    |
| load3  | 0    |       |      |        |       |          |           |           | Despachadas |           |                    |
| load4  | 0    |       |      |        |       |          |           |           |             |           |                    |
| load5  | 0    |       |      |        |       |          |           |           |             |           |                    |
| store1 | 1    | SW    | 0    | &dst   | load1 |          | 0         |           |             |           |                    |
| store2 | 1    | SW    | 0    | &dst+4 | load2 |          | 0         |           | Executando  |           |                    |
| store3 | 0    |       |      |        |       |          |           | add1(2/2) | load1(2/4)  | add3(2/2) |                    |
| store4 | 0    |       |      |        |       |          |           |           |             |           |                    |
| store5 | 0    |       |      |        |       |          |           |           |             |           |                    |
|        | ,    | ,     |      | ,      |       | dst = {0 | , 0, 0, 1 | 4, 23}    | •           | •         | •                  |

|      |      |       |      |        |    | (  | Ciclo 12 |     |      |        |                    |
|------|------|-------|------|--------|----|----|----------|-----|------|--------|--------------------|
| ER   | Busy | Ор    | Qj   | Vj     | Qk | Vk | Α        | Reg | Qi   | Valor  | Fila de Instruções |
| add1 | 1    | addi  | 0    | 1      |    |    | -1       | a0  | add2 | &src   | addiu              |
| add2 | 1    | addiu | 0    | &src+8 |    |    | 4        | a1  | 0    | &dst+8 | addiu              |
| add3 | 1    | bgez  | add1 |        |    |    |          | a2  | 0    | 4      | addi               |
| mul1 | 0    |       |      |        |    |    |          | a3  | 0    | 3      | bgez               |
| mul2 | 0    |       |      |        |    |    |          | v0  | add1 | 1      |                    |

| load1  | 1 | lw | 0    | &src+4 |       |          | &src+4    | at         | load3       | 0          |
|--------|---|----|------|--------|-------|----------|-----------|------------|-------------|------------|
| load2  | 1 | lw | 0    | &src+8 |       |          | 0         |            |             |            |
| load3  | 1 | lw | add2 |        |       |          | 0         |            | Despachadas |            |
| load4  | 0 |    |      |        |       |          |           | add2       | load2       | add1       |
| load5  | 0 |    |      |        |       |          |           |            |             |            |
| store1 | 1 | SW | 0    | &dst   | load1 |          | 0         |            |             |            |
| store2 | 1 | SW | 0    | &dst+4 | load2 |          | 0         |            | Executando  |            |
| store3 | 1 | SW | 0    | &dst+8 | load3 |          | 0         | load1(3/4) | add2(1/2)   | load2(1/4) |
| store4 | 0 |    |      |        |       |          |           | add1(1/2)  |             |            |
| store5 | 0 |    |      |        |       |          |           |            |             |            |
|        |   |    |      |        |       | dst = {0 | , 0, 0, 1 | 4, 23}     |             |            |

|        |      |       |      |        |       | 1        | Ciclo 13    |            |             |            |                    |
|--------|------|-------|------|--------|-------|----------|-------------|------------|-------------|------------|--------------------|
| ER     | Busy | 0p    | Qj   | Vj     | Qk    | Vk       | Α           | Reg        | Qi          | Valor      | Fila de Instruções |
| add1   | 1    | addi  | 0    | 1      |       |          | -1          | a0         | add2        | &src       | addiu              |
| add2   | 1    | addiu | 0    | &src+8 |       |          | 4           | a1         | 0           | &dst+8     | addiu              |
| add3   | 1    | bgez  | add1 |        |       |          |             | a2         | 0           | 4          | addi               |
| mul1   | 0    |       |      |        |       |          |             | a3         | 0           | 3          | bgez               |
| mul2   | 0    |       |      |        |       |          |             | v0         | add1        | 1          |                    |
| load1  | 1    | lw    | 0    | &src+4 |       |          | &src+4      | at         | load3       | 0          |                    |
| load2  | 1    | lw    | 0    | &src+8 |       |          | 0           |            |             |            |                    |
| load3  | 1    | lw    | add2 |        |       |          | 0           |            | Despachadas |            |                    |
| load4  | 0    |       |      |        |       |          |             |            |             |            |                    |
| load5  | 0    |       |      |        |       |          |             |            |             |            |                    |
| store1 | 1    | SW    | 0    | &dst   | load1 |          | 0           |            |             |            |                    |
| store2 | 1    | SW    | 0    | &dst+4 | load2 |          | 0           |            | Executando  |            |                    |
| store3 | 1    | SW    | 0    | &dst+8 | load3 |          | 0           | load1(4/4) | add2(2/2)   | load2(2/4) |                    |
| store4 | 0    |       |      |        |       |          |             | add1(2/2)  |             |            |                    |
| store5 | 0    |       |      |        |       |          |             |            |             |            |                    |
|        |      |       |      |        |       | dst = {0 | 0, 0, 0, 14 | 1, 23}     |             |            |                    |

|        |      |       |    |         |       |          | Ciclo 14    |            |             |             |                    |
|--------|------|-------|----|---------|-------|----------|-------------|------------|-------------|-------------|--------------------|
| ER     | Busy | 0p    | Qj | Vj      | Qk    | Vk       | Α           | Reg        | Qi          | Valor       | Fila de Instruções |
| add1   | 1    | addiu | 0  | &src+12 |       |          | 4           | a0         | add1        | &src+12     | addi               |
| add2   | 1    | addiu | 0  | &dst+8  |       |          | 4           | a1         | add2        | &dst+8      | bgez               |
| add3   | 1    | bgez  | 0  | 0       |       |          |             | a2         | 0           | 4           |                    |
| mul1   | 0    |       |    |         |       |          |             | a3         | 0           | 3           |                    |
| mul2   | 0    |       |    |         |       |          |             | v0         | 0           | 0           |                    |
| load1  | 0    |       |    |         |       |          |             | at         | load3       | 0           |                    |
| load2  | 1    | lw    | 0  | &src+8  |       |          | &src+8      |            |             |             |                    |
| load3  | 1    | lw    | 0  | &src+12 |       |          | 0           |            | Despachadas |             |                    |
| load4  | 0    |       |    |         |       |          |             | add3       | load3       | add1        |                    |
| load5  | 0    |       |    |         |       |          |             | add2       | store1      |             |                    |
| store1 | 1    | SW    | 0  | &dst    | 0     | 23       | 0           |            |             |             |                    |
| store2 | 1    | SW    | 0  | &dst+4  | load2 |          | 0           |            | Executando  |             |                    |
| store3 | 1    | SW    | 0  | &dst+8  | load3 |          | 0           | load2(3/4) | load3(1/4)  | add3(1/2)   |                    |
| store4 | 0    |       | •  |         |       |          |             | add1(1/2)  | add2(1/2)   | store1(1/4) |                    |
| store5 | 0    | ,     |    |         |       |          |             |            |             |             |                    |
|        |      |       |    |         |       | dst = {0 | 0, 0, 0, 14 | 1, 23}     |             |             |                    |

|        |      |       |    |         |       |    | Ciclo 15 |            |             |             |                    |
|--------|------|-------|----|---------|-------|----|----------|------------|-------------|-------------|--------------------|
| ER     | Busy | 0p    | Qj | Vj      | Qk    | Vk | Α        | Reg        | Qi          | Valor       | Fila de Instruções |
| add1   | 1    | addiu | 0  | &src+12 |       |    | 4        | a0         | add1        | &src+12     | addi               |
| add2   | 1    | addiu | 0  | &dst+8  |       |    | 4        | a1         | add2        | &dst+8      | bgez               |
| add3   | 1    | bgez  | 0  | 0       |       |    |          | a2         | 0           | 4           |                    |
| mul1   | 0    |       |    |         |       |    |          | a3         | 0           | 3           |                    |
| mul2   | 0    |       |    |         |       |    |          | v0         | 0           | 0           |                    |
| load1  | 0    |       |    |         |       |    |          | at         | load3       | 0           |                    |
| load2  | 1    | lw    | 0  | &src+8  |       |    | &src+8   |            |             |             |                    |
| load3  | 1    | lw    | 0  | &src+12 |       |    | 0        |            | Despachadas |             |                    |
| load4  | 0    |       |    |         |       |    |          |            |             |             |                    |
| load5  | 0    |       |    |         |       |    |          |            |             |             |                    |
| store1 | 1    | SW    | 0  | &dst    | 0     | 23 | 0        |            |             |             |                    |
| store2 | 1    | SW    | 0  | &dst+4  | load2 |    | 0        |            | Executando  |             |                    |
| store3 | 1    | SW    | 0  | &dst+8  | load3 |    | 0        | load2(4/4) | load3(2/4)  | add3(2/2)   |                    |
| store4 | 0    |       |    |         |       |    |          | add1(2/2)  | add2(2/2)   | store1(2/4) |                    |
| store5 | 0    |       |    |         |       |    |          |            |             |             |                    |

|      |      |      |    |    |    | (  | Ciclo 16 |     |    |         |                    |
|------|------|------|----|----|----|----|----------|-----|----|---------|--------------------|
| ER   | Busy | 0p   | Qj | Vj | Qk | Vk | Α        | Reg | Qi | Valor   | Fila de Instruções |
| add1 | 1    | addi | 0  | 0  |    |    | -1       | a0  | 0  | &src+16 |                    |

| add2   | 1 | bgez    | add1  |         |       |          |             | a1         | 0           | &dst+12     |
|--------|---|---------|-------|---------|-------|----------|-------------|------------|-------------|-------------|
| add3   | 1 | syscall | load1 |         |       |          |             | a2         | 0           | 4           |
| mul1   | 0 |         |       |         |       |          |             | a3         | 0           | 3           |
| mul2   | 0 |         |       |         |       |          |             | v0         | load1       | 0           |
| load1  | 1 | lw      |       |         |       |          | exit_val    | at         | load3       | 0           |
| load2  | 0 |         |       |         |       |          |             |            |             |             |
| load3  | 1 | lw      | 0     | &src+12 |       |          | &src+12     |            | Despachadas |             |
| load4  | 0 |         |       |         |       |          |             | store2     | add1        | load1       |
| load5  | 0 |         |       |         |       |          |             |            |             |             |
| store1 | 1 | SW      | 0     | &dst    | 0     | 23       | &dst        |            |             |             |
| store2 | 1 | SW      | 0     | &dst+4  | 0     | 12       | 0           |            | Executando  |             |
| store3 | 1 | SW      | 0     | &dst+8  | load3 |          | 0           | load3(3/4) | store1(3/4) | store2(1/4) |
| store4 | 0 |         |       |         |       |          |             | add1(1/2)  | load1(1/4)  |             |
| store5 | 0 |         |       |         |       |          |             |            |             |             |
|        |   |         |       |         |       | dst = {6 | 0, 0, 0, 14 | 1, 23}     |             |             |

|        | Ciclo 17 |         |       |         |       |          |             |            |             |             |                    |  |  |  |
|--------|----------|---------|-------|---------|-------|----------|-------------|------------|-------------|-------------|--------------------|--|--|--|
| ER     | Busy     | 0p      | Qj    | Vj      | Qk    | Vk       | Α           | Reg        | Qi          | Valor       | Fila de Instruções |  |  |  |
| add1   | 1        | addi    | 0     | 0       |       |          | -1          | a0         | 0           | &src+16     |                    |  |  |  |
| add2   | 1        | bgez    | add1  |         |       |          |             | a1         | 0           | &dst+12     |                    |  |  |  |
| add3   | 1        | syscall | load1 |         |       |          |             | a2         | 0           | 4           |                    |  |  |  |
| mul1   | 0        |         |       |         |       |          |             | a3         | 0           | 3           |                    |  |  |  |
| mul2   | 0        |         |       |         |       |          |             | v0         | load1       | 0           |                    |  |  |  |
| load1  | 1        | lw      |       |         |       |          | exit_val    | at         | load3       | 0           |                    |  |  |  |
| load2  | 0        |         |       |         |       |          |             |            |             |             |                    |  |  |  |
| load3  | 1        | lw      | 0     | &src+12 |       |          | &src+12     |            | Despachadas |             |                    |  |  |  |
| load4  | 0        |         |       |         |       |          |             |            |             |             |                    |  |  |  |
| load5  | 0        |         |       |         |       |          |             |            |             |             |                    |  |  |  |
| store1 | 1        | SW      | 0     | &dst    | 0     | 23       | &dst        |            |             |             |                    |  |  |  |
| store2 | 1        | SW      | 0     | &dst+4  | 0     | 12       | 0           |            | Executando  |             |                    |  |  |  |
| store3 | 1        | SW      | 0     | &dst+8  | load3 |          | 0           | load3(4/4) | store1(4/4) | store2(2/4) |                    |  |  |  |
| store4 | 0        |         |       |         |       |          |             | add1(2/2)  | load1(2/4)  |             |                    |  |  |  |
| store5 | 0        |         |       |         |       |          |             |            |             |             |                    |  |  |  |
|        |          |         |       |         |       | dst = {0 | 0, 0, 0, 14 | , 23}      |             |             |                    |  |  |  |

|        |      |         |       |        |    |    | Ciclo 18 |             |             |             |                    |
|--------|------|---------|-------|--------|----|----|----------|-------------|-------------|-------------|--------------------|
| ER     | Busy | 0p      | Qj    | Vj     | Qk | Vk | Α        | Reg         | Qi          | Valor       | Fila de Instruções |
| add1   | 0    |         |       |        |    |    |          | a0          | 0           | &src+16     |                    |
| add2   | 1    | bgez    | 0     | -1     |    |    |          | a1          | 0           | &dst+12     |                    |
| add3   | 1    | syscall | load1 |        |    |    |          | a2          | 0           | 4           |                    |
| mul1   | 0    |         |       |        |    |    |          | a3          | 0           | 3           |                    |
| mul2   | 0    |         |       |        |    |    |          | v0          | load1       | 0           |                    |
| load1  | 1    | lw      |       |        |    |    | exit_val | at          | 0           | 29          |                    |
| load2  | 0    |         |       |        |    |    |          |             |             |             |                    |
| load3  | 0    |         |       |        |    |    |          |             | Despachadas |             |                    |
| load4  | 0    |         |       |        |    |    |          | store3      | add2        |             |                    |
| load5  | 0    |         |       |        |    |    |          |             |             |             |                    |
| store1 | 0    |         |       |        |    |    |          |             |             |             |                    |
| store2 | 1    | SW      | 0     | &dst+4 | 0  | 12 | &dst+4   |             | Executando  |             |                    |
| store3 | 1    | SW      | 0     | &dst+8 | 0  | 29 | 0        | store3(1/4) | load1(3/4)  | store2(3/4) |                    |
| store4 | 0    |         |       |        |    |    |          | add2(1/2)   |             |             |                    |
| store5 | 0    |         |       |        |    |    |          |             |             |             |                    |

|        |      |         |       |        |    |             | Ciclo 19    |             |             |             |                    |
|--------|------|---------|-------|--------|----|-------------|-------------|-------------|-------------|-------------|--------------------|
| ER     | Busy | Ор      | Qj    | Vj     | Qk | Vk          | Α           | Reg         | Qi          | Valor       | Fila de Instruções |
| add1   | 0    |         |       |        |    |             |             | a0          | 0           | &src+16     |                    |
| add2   | 1    | bgez    | 0     | -1     |    |             |             | a1          | 0           | &dst+12     |                    |
| add3   | 1    | syscall | load1 |        |    |             |             | a2          | 0           | 4           |                    |
| mul1   | 0    |         |       |        |    |             |             | a3          | 0           | 3           |                    |
| mul2   | 0    |         |       |        |    |             |             | v0          | load1       | 0           |                    |
| load1  | 1    | lw      |       |        |    |             | exit_val    | at          | 0           | 29          |                    |
| load2  | 0    |         |       |        |    |             |             |             |             |             |                    |
| load3  | 0    |         |       |        |    |             |             |             | Despachadas |             |                    |
| load4  | 0    |         |       |        |    |             |             |             |             |             |                    |
| load5  | 0    |         |       |        |    |             |             |             |             |             |                    |
| store1 | 0    |         |       |        |    |             |             |             |             |             |                    |
| store2 | 1    | SW      | 0     | &dst+4 | 0  | 12          | &dst+4      |             | Executando  |             |                    |
| store3 | 1    | SW      | 0     | &dst+8 | 0  | 29          | 0           | store3(2/4) | load1(4/4)  | store2(4/4) |                    |
| store4 | 0    |         |       |        |    |             |             | add2(2/2)   |             |             |                    |
| store5 | 0    |         |       |        |    |             |             |             |             |             |                    |
|        |      |         |       |        |    | $dst = {2}$ | 23, 0, 0, 1 | 4, 23}      |             |             |                    |

|        |      |         |    |        |    | (         | Ciclo 20 |             |             |         |                    |
|--------|------|---------|----|--------|----|-----------|----------|-------------|-------------|---------|--------------------|
| ER     | Busy | 0p      | Qj | Vj     | Qk | Vk        | Α        | Reg         | Qi          | Valor   | Fila de Instruções |
| add1   | 0    |         |    |        |    |           |          | a0          | 0           | &src+16 |                    |
| add2   | 0    |         |    |        |    |           |          | a1          | 0           | &dst+12 |                    |
| add3   | 1    | syscall | 0  | 10     |    |           |          | a2          | 0           | 4       |                    |
| mul1   | 0    |         |    |        |    |           |          | a3          | 0           | 3       |                    |
| mul2   | 0    |         |    |        |    |           |          | v0          | 0           | 10      |                    |
| load1  | 0    |         |    |        |    |           |          | at          | 0           | 29      |                    |
| load2  | 0    |         |    |        |    |           |          |             |             |         |                    |
| load3  | 0    |         |    |        |    |           |          |             | Despachadas |         |                    |
| load4  | 0    |         |    |        |    |           |          | add3        |             |         |                    |
| load5  | 0    |         |    |        |    |           |          |             |             |         |                    |
| store1 | 0    |         |    |        |    |           |          |             |             |         |                    |
| store2 | 0    |         |    |        |    |           |          |             | Executando  |         |                    |
| store3 | 1    | SW      | 0  | &dst+8 | 0  | 29        | 0        | store3(2/4) | add3(1/2)   |         |                    |
| store4 | 0    |         |    |        |    |           |          | ]           |             |         |                    |
| store5 | 0    |         |    |        |    |           |          |             |             |         |                    |
|        |      |         |    |        | (  | dst = {23 | , 12, 0, | 14, 23}     |             |         |                    |

|        |      |         |    |        |    | (         | Ciclo 21   |             |             |         |                    |
|--------|------|---------|----|--------|----|-----------|------------|-------------|-------------|---------|--------------------|
| ER     | Busy | Ор      | Qj | Vj     | Qk | Vk        | Α          | Reg         | Qi          | Valor   | Fila de Instruções |
| add1   | 0    |         |    |        |    |           |            | a0          | 0           | &src+16 |                    |
| add2   | 0    |         |    |        |    |           |            | a1          | 0           | &dst+12 |                    |
| add3   | 1    | syscall | 0  | 10     |    |           |            | a2          | 0           | 4       |                    |
| mul1   | 0    |         |    |        |    |           |            | a3          | 0           | 3       |                    |
| mul2   | 0    |         |    |        |    |           |            | v0          | 0           | 10      |                    |
| load1  | 0    |         |    |        |    |           |            | at          | 0           | 29      |                    |
| load2  | 0    |         |    |        |    |           |            |             |             |         |                    |
| load3  | 0    |         |    |        |    |           |            |             | Despachadas |         |                    |
| load4  | 0    |         |    |        |    |           |            |             |             |         |                    |
| load5  | 0    |         |    |        |    |           |            |             |             |         |                    |
| store1 | 0    |         |    |        |    |           |            |             |             |         |                    |
| store2 | 0    |         |    |        |    |           |            |             | Executando  |         |                    |
| store3 | 1    | SW      | 0  | &dst+8 | 0  | 29        | &dst+8     | store3(3/4) | add3(2/2)   |         |                    |
| store4 | 0    |         | •  |        | •  |           |            |             |             |         |                    |
| store5 | 0    |         |    |        |    |           |            |             |             |         |                    |
|        |      |         |    |        | -  | dst = {23 | , 12, 0, 1 | 14, 23}     |             | ·       |                    |

|        |      |         |    |        |    | (         | Ciclo 22   |             |             |         |                    |
|--------|------|---------|----|--------|----|-----------|------------|-------------|-------------|---------|--------------------|
| ER     | Busy | 0p      | Qj | Vj     | Qk | Vk        | Α          | Reg         | Qi          | Valor   | Fila de Instruções |
| add1   | 0    |         |    |        |    |           |            | a0          | 0           | &src+16 |                    |
| add2   | 0    |         |    |        |    |           |            | a1          | 0           | &dst+12 |                    |
| add3   | 1    | syscall | 0  | 10     |    |           |            | a2          | 0           | 4       |                    |
| mul1   | 0    |         |    |        |    |           |            | a3          | 0           | 3       |                    |
| mul2   | 0    |         |    |        |    |           |            | v0          | 0           | 10      |                    |
| load1  | 0    |         |    |        |    |           |            | at          | 0           | 29      |                    |
| load2  | 0    |         |    |        |    |           |            |             |             |         |                    |
| load3  | 0    |         |    |        |    |           |            |             | Despachadas |         |                    |
| load4  | 0    |         |    |        |    |           |            |             |             |         |                    |
| load5  | 0    |         |    |        |    |           |            |             |             |         |                    |
| store1 | 0    |         |    |        |    |           |            |             |             |         |                    |
| store2 | 0    |         |    |        |    |           |            |             | Executando  |         |                    |
| store3 | 1    | SW      | 0  | &dst+8 | 0  | 29        | &dst+8     | store3(4/4) | add3(2/2)   |         |                    |
| store4 | 0    |         | •  |        |    |           |            |             |             |         |                    |
| store5 | 0    |         | •  |        |    |           |            |             |             |         |                    |
|        |      |         |    |        | (  | lst = {23 | , 12, 0, 1 | 14, 23}     |             |         |                    |

|        |      |    |    |    |    |    | Ciclo 23 |     |             |         |                    |
|--------|------|----|----|----|----|----|----------|-----|-------------|---------|--------------------|
|        |      |    |    |    |    |    |          | ,   |             |         |                    |
| ER     | Busy | 0p | Qj | Vj | Qk | Vk | Α        | Reg | Qi          | Valor   | Fila de Instruções |
| add1   | 0    |    |    |    |    |    |          | a0  | 0           | &src+16 |                    |
| add2   | 0    |    |    |    |    |    |          | a1  | 0           | &dst+12 |                    |
| add3   | 0    |    |    |    |    |    |          | a2  | 0           | 4       |                    |
| mul1   | 0    |    |    |    |    |    |          | a3  | 0           | 3       |                    |
| mul2   | 0    |    |    |    |    |    |          | v0  | 0           | 10      |                    |
| load1  | 0    |    |    |    |    |    |          | at  | 0           | 29      |                    |
| load2  | 0    |    |    |    |    |    |          |     |             |         |                    |
| load3  | 0    |    |    |    |    |    |          |     | Despachadas |         |                    |
| load4  | 0    |    |    |    |    |    |          |     |             |         |                    |
| load5  | 0    |    |    |    |    |    |          |     |             |         |                    |
| store1 | 0    |    |    |    |    |    |          |     |             |         |                    |
| store2 | 0    |    |    |    |    |    |          |     | Executando  |         |                    |
| store3 | 0    |    |    |    |    |    |          |     |             |         |                    |

|        | _                          |  | _ | • |  |  |  |   |  |  |  |
|--------|----------------------------|--|---|---|--|--|--|---|--|--|--|
| store4 | 0                          |  |   |   |  |  |  |   |  |  |  |
| store5 | 0                          |  |   |   |  |  |  | 7 |  |  |  |
|        | dst = {23, 12, 29, 14, 23} |  |   |   |  |  |  |   |  |  |  |