TrabalhosGratuitos.com - Trabalhos, Monografias, Artigos, Exames, Resumos de livros, Dissertações
Pesquisar

PIPELINE DO MIPS 32

Por:   •  9/12/2018  •  Trabalho acadêmico  •  1.389 Palavras (6 Páginas)  •  203 Visualizações

Página 1 de 6

UNIVERSIDADE FEDERAL DE VIÇOSA

Campus de Rio Paranaíba

Sistemas de Informação

PIPELINE DO MIPS 32

Trabalho

Disciplina: Arquitetura de Computadores (SIN 131)

Professor: João Fernando Mari

Alunos:

Eliane A.

David M.

Denilson L, C.

1.0 INTRODUÇÃO

Este trabalho, tem por objetivo apresentar a simulação de três algoritmos no Simulador Assembly online ‘MIPS Five Stage Pipeline’ da Universidade de Massachusetts, e apresentar as descrições dos hazards de dados e de controle.

2.0 CÓDIGO A

Abaixo segue a simulação, identificação e descrição dos hazards no Código A, com resolução tanto por bolha, quanto por encaminhamento.

Código A

0 - add $1, $2, $3

1 - add $4, $1, $2

2 - sub $3, $3, $1

3 - sw $4, 12($0)

4 - lw $1, 8($3)

2.1 Solução por Bolha

Na solução por bolha, perdeu-se 3 ciclos de processador por causa dos hazards que ocorreram e foram solucionados por bolha, conforme a figura 1.

Na linha 1 ocorreu um hazard de dados do tipo read before write, em que a instrução 1 (add) precisou de um dado (no registrador F1) que a instrução anterior, ainda não havia gravado.

Na linha 2 também ocorreu o mesmo tipo de hazard, onde a instrução 2 (sub) precisou do mesmo dado (registrador F1) que ainda não havia sido gravado.

Na linha 3 ocorreu um hazard de dados do tipo read before write, em que a instrução 3 (sw) precisou de um dado (registrador f4) que a instrução 1 (add) ainda não havia gravado.

Na linha 4 ocorreu o mesmo tipo de hazard, onde a instrução lw, precisou de um dado (do registrador F3), que a instrução 2 ainda não havia gravado.

Figura1: Código A, com solução por bolha

2.2 Solução por Encaminhamento

Na versão usando encaminhamento, os hazards foram resolvidos de forma mais eficiente, em que o processador não precisou ficar nenhum ciclo ocioso, conforme a figura 2.

Na instrução 1 ocorreu um hazard do tipo read before write, em que a instrução precisou dos dados do registrador F1, que a instrução anterior ainda não havia gravado, para isso, os dados foram encaminhados da saída para entrada da ULA para resolver o hazard.

Na instrução 2 ocorreu um hazard do tipo read before write, em que a instrução precisou dos dados contidos no registrador F1, que a instrução 0 ainda não havia gravado no registrador. Para resolver o problema, os dados foram encaminhados da instrução 0 para a entrada da ULA da instrução 2.

Na instrução 3 ocorreu um hazard do tipo read before write, em que a instrução precisou dos dados do registrador F4 para gravar na memória, mas a instrução 1 ainda não havia gravado no registrador, precisou fazer o encaminhamento para solucionar o hazard.

Na instrução 4 ocorreu um hazard do tipo read before write, em que a instrução precisou dos dados do registrador F3, para calcular o endereço, entretanto a instrução 2 não havia concluído a gravação, logo precisou encaminhar da saída da ULA da instrução 2 para a entrada da ULA da instrução 4.

Figura 2: Código A, com solução por encaminhamento

3.0 CÓDIGO B

Abaixo segue a simulação, identificação e descrição dos hazards no Código B, com resolução tanto por bolha, quanto por encaminhamento.

Código B

0 - lw $2, 64($0)

1 - add $3, $1, $2

2 - sub $4, $3, $2

3 - sw $3, 12($4)

4 - lw $3, 128($1)

5 - add $3, $2, $4

6 - sub $2, $0, $3

3.1 Solução por Bolha

O código B com solução sem encaminhamento, precisou de seis ciclos a mais para solucionar os hazards, conforme a figura 3.

Na instrução 1, ocorreu um hazard do tipo load use data, onde a instrução add precisou dos dados que estaria no registrador F2, porém a instrução load ainda não havia terminado de carregar os dados, sendo necessário dois stall para resolver o hazard.

Na instrução 2, ocorreu um hazard do tipo read before write, onde a instrução 2 (sub), precisou de um dado que a instrução 1 não havia gravado no registrador, por isso gastou-se mais dois stall para resolver o hazard. A instrução também precisaria dos dados da instrução 1(lw).

Na instrução 3, ocorreu um duplo hazard do tipo read before write, onde a instrução 3 (sw), precisou dos dados dos registradores F3 e F4, que as instruções 2 e 3 ainda não haviam disponibilizados.

Na instrução 3, ocorreu dois hazards, um do tipo read before write e outro load use data, pois a instrução 4 (lw) não havia carregado os dados e nem a instrução 5 (add) salvo os dados.

Figura 3: Código B, com solução por bolha

3.2 Solução por Encaminhamento

A solução do Código B por encaminhamento, conforme pode ser observado na Figura 4, foi bem mais otimizada a ponto de perder apenas um ciclo de clock para resolver o hazard.

Na instrução 1, ocorreu um hazard do tipo load use data, em que a instrução add precisou dos dados que a instrução anterior ainda não havia carregado para o registrador F2, como

...

Baixar como (para membros premium)  txt (8.6 Kb)   pdf (52.3 Kb)   docx (14.9 Kb)  
Continuar por mais 5 páginas »
Disponível apenas no TrabalhosGratuitos.com