1 / 21

ESMIPS

ESMIPS. Projeto de Engenharia de Software e Sistemas. Equipe:. Anderson Gomes Bruno Marques Diego Riff Guilherme Dantas Vinícius Kursancew Rodolfo Pereira. Roteiro. VISÃO GERAL PLANO DE PROJETO CRONOGRAMA CASOS DE USO DIAGRAMA DE CLASSES DIAGRAMA DE SEQUÊNCIA ARQUITETURA TESTES.

Download Presentation

ESMIPS

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. ESMIPS Projeto de Engenharia de Software e Sistemas

  2. Equipe: • Anderson Gomes • Bruno Marques • Diego Riff • Guilherme Dantas • Vinícius Kursancew • Rodolfo Pereira

  3. Roteiro • VISÃO GERAL • PLANO DE PROJETO • CRONOGRAMA • CASOS DE USO • DIAGRAMA DE CLASSES • DIAGRAMA DE SEQUÊNCIA • ARQUITETURA • TESTES

  4. Visão Geral • Utilização de técnicas de Engenharia de Software para o desenvolvimento de IP Cores. • Importância da documentação em projetos de Hardware. • Importância da Verificação Funcional

  5. O Modelo de Referência • Utilizado para verificar se o chip desenvolvido está correto. • Geralmente desenvolvidos em linguagens de mais alto nível que as HDLs comuns. • Suas saídas são consideradas corretas pelos designers. • Por isso ele deve ser exaustivamente testado.

  6. ESMIPS • Modelo de Referência para um processador MIPS como o desenvolvido na disciplina de Infra-Estrutura de Hardware. • Implementação em pipeline de 3 estágios

  7. Plano de Projeto • 1ª Fase: Concepção • Período: 23/05/2007 à 04/06/2007 • Definição do que seria desenvolvido • Desenvolvimento do documento de plano de projeto • Marco Principal: Versão final do documento de plano de projeto.

  8. Plano de Projeto • 2ª Fase: Arquitetura • Período: 06/06/2007 à 12/07/2007 • Definição da arquitetura que seria seguida. • Elaboração do documento de arquitetura, casos de testes e plano de verificação. • Marco Principal: Documento de arquitetura do modelo de software, documento de caso de testes, plano de verificação.

  9. Plano de Projeto • 3ª Fase: Design Comportamental • Período: 16/07/2007 à 03/08/2007 • Implementação de alguns casos de uso em SystemC RTL. • Implementação dos testes. • Teste do projeto. • Marco Principal: Modelo implementado em SystemC com os casos de teste validados.

  10. Cronograma • http://www.cin.ufpe.br/~vak/es/crono.html

  11. Casos de Uso

  12. Evento (clock) causa execução de uma instrução Processador executa instrução nop Processador executa instrução sw Processador executa instrução lw Processador executa instrução mfhi Processador executa instrução mflo Processador executa instrução add Processador executa instrução addi Processador executa instrução addu Processador executa instrução addiu Processador executa instrução and Processador executa instrução xori Processador executa instrução sra Processador executa instrução srav Processador executa instrução sll Processador executa instrução beq Processador executa instrução slt Processador executa instrução j Processador executa instrução jal Processador executa instrução div Casos de uso implementados

  13. Casos de uso [CU01] Evento (clock) causa execução de uma instrução • A instrução do programa armazenada no endereço de memória apontado pelo contador de programa ( MEM[PC] ) é carregado para a CPU • Separa os argumentos do OpCode (seis bits mais significativos) • Verifica validade do opcode, se for inválido marca flag de exceção por instrução inválida <<include FS01>>.

  14. Casos de uso • [CU36] Processador executa instrução div (tipo R) • 1. <<include CU01>> • 2. Se $rt for ‘0’ marca a flag de exceção de divisão por Zero e este caso de uso termina aqui <<include FS01>> • 3. $LO ← $rs / $rt • 4. $HI ← $rs % $rt • 5. Este caso de uso termina aqui.

  15. Diagrama de classes

  16. Diagrama de seqüência

  17. Arquitetura

  18. Arquitetura

  19. Máquinas de estado MemArbiter

  20. Testes • Teste de caixa preta (integração) • Teste de Testbench/DUV (threads) • Teste de unidade (instruções)

  21. Testes • Teste do modelo da memória • Verifique se é possível escrever um dado na memória; • Verifique se é possível ler um dado da memória; • Escreva um padrão de dados na memória e em seguida leia e compare para verificar a corretude. Memória

More Related