





# ESCOLA POLITÉCNICA DA UNIVERSIDADE DE SÃO PAULO Departamento de Engenharia de Computação e Sistemas Digitais

## PCS3635 – LABORATÓRIO DIGITAL I

# EXPERIÊNCIA 4 – Desenvolvimento de Projeto de Circuitos Digitais em FPGA

Planejamento da Bancada 07 – Turma 1 – Prof. Edson Midorikawa

Data de Emissão: 26 de Janeiro de 2024.

| Nome: Gabriel Chaves Lopes Silva    | Número USP: 12555839 |
|-------------------------------------|----------------------|
| Nome: Luiz Mariano dos Santos Silva | Número USP: 13684467 |
| Nome: Luca Bompiani                 | Número USP: 12552760 |

### 1 Introdução

Esta experiência tem como objetivo desenvolver e implementar um sistema digital sequencial em FPGA, integrando um fluxo de dados e uma unidade de controle, para processar entradas externas acionadas por chaves e compará-las com dados armazenados em memória. Além disso, o projeto visa consolidar práticas de síntese em FPGA usando o Intel Quartus Prime e validação funcional por meio de simulações no ModelSim e testes físicos na placa DE0-CV.

O trabalho dá continuidade ao projeto desenvolvido na experiência anterior, introduzindo adaptações críticas, como a detecção de bordas para tratamento de sinais de entrada de longa duração e a inclusão de estados de controle para gerenciar ciclos de comparação e finalização do jogo.

### 2 DESCRIÇÃO DO PROJETO

O sistema digital desenvolvido consiste em um circuito sequencial que opera com um sinal de *clock* periódico, integrando um fluxo de dados que executa operações físicas como contagem, armazenamento e comparação, e uma unidade de controle para gerenciamento de estados.

O funcionamento do sistema pode ser representado pelo pseudocódigo a seguir:

```
    2. while (verdadeiro) {
        3. espera acionamento do sinal iniciar
        4. inicia circuito com condições iniciais
        5. while (acertou dado E não atingiu o último dado) {
            6. espera acionamento das chaves (fazer uma jogada)
            7. registra entrada da jogada realizada
            8. compara jogada realizada com dados armazenados
            9. incrementa contador interno
            10. }
            11. ativa acertou se acertou todos os dados da memória
            12. ativa errou se errou um dado
            13. ativa saída pronto (até reiniciar)
            14. }
```

O núcleo do projeto é uma memória interna de 16 dados de 4 bits, acessada por um contador que percorre seus endereços. Após o acionamento do sinal *iniciar*, o sistema aguarda a entrada de jogadas via chaves, compara esses valores com os dados armazenados na memória e atualiza saídas de depuração (como db\_igual, db\_contagem e db\_estado) para monitoramento em displays de sete segmentos e LEDs

### 3 DETALHAMENTO DO PROJETO LÓGICO

### 3.1 Projeto do Fluxo de Dados

O fluxo de dados é composto por quatro componentes principais, sendo eles um Contador de 4 bits, que gera endereços para a memória interna, um Registrador de 4 bits, que armazena temporariamente as jogadas acionadas pelas chaves, uma Memória ROM síncrona 16x4, que armazena os 16 dados de referência para comparação, e um Comparador 4 bits, que verifica a igualdade entre o valor das chaves e o dado da memória, gerando o sinal db\_igual.

A figura abaixo apresenta a estrutura do fluxo de dados:



fig 1. Fluxo de Dados

Dentre as saídas de depuração, destacam-se os sinais db\_contagem (endereço atual da memória), db\_memoria (dado lido da memória), db\_jogadafeita (jogada registrada) e db\_estado (código do estado atual da unidade de controle).

A principal adaptação em relação à experiência anterior foi a adição de um detector de borda (edge detector) para tratar pulsos longos das chaves, convertendo-os em sinais de 1 período de clock. Isso evita múltiplas leituras acidentais devido à natureza mecânica das chaves. Além disso, para o sinal de reset do edge detector, foi utilizado o princípio que sempre que o circuito comeca (inicializa\_elementos) ou quando transicional para proxima jogada (proxima\_jogada) o sinal é ativado permitindo que uma nova detecção seja feita.

A instanciação dos componentes em Verilog é apresentada no código a seguir:

1- Criação dos sinais intermediários para as novas funções e novas condições

```
wire sig_jogada_feita;
wire sig_db_tem_jogada;
assign sig_db_tem_jogada = |chaves;
wire reset_detector;
assign reset_detector = zeraC;
```

2- Instanciamento do novo componente

```
//Detector de jogadas
edge_detector detector (
    .clock ( clock ),
    .reset ( reset_detector ),
    .sinal ( sig_db_tem_jogada ),
    .pulso ( sig_jogada_feita )
);
```

### 3.2 Projeto da Unidade de Controle

A unidade de controle é projetada como uma máquina de estados finita que gerencia a transição entre os diferentes estados do sistema e gera os sinais de controle necessários para o fluxo de dados. O diagrama de transição de estados da unidade de controle é apresentado a seguir:



fig 2. Diagrama de estados da Unidade de Controle

Algumas mudanças pontuais foram feitas no arquivo VERILOG da UC, visto que compartilha de muitas semelhanças com o projeto anterior.

1 - Adicionado o sinal que captura a jogada para saber se houve alguma interação do jogador com o sistema.

```
input jogada,
```

2- Novos estados respectivos a nova FSM foram adicionados e que são melhores descritos na tabela que se segue logo abaixo. Além de mudar para uma abordagem que segue os princípios de Moore.

```
// Define estados

parameter inicial = 4'b0000; // 0

parameter inicializa_elementos = 4'b0001; // 1
```

```
parameter espera_jogada = 4'b0011; // 3

parameter registra_jogada = 4'b0100; // 4

parameter proxima_jogada = 4'b0101; // 5

parameter compara_jogada = 4'b0110; // 6

parameter final_acertou = 4'b0111; // 7

parameter final_errou = 4'b1000; // 8
```

Tabela 1 – Descrição da Unidade de Controle do Sistema

| Nome do Estado       | Descrição do Estado                                                                                                    | Próximo Estado       | Condições e<br>Justificativas<br>para a<br>Transição<br>entre Estados |
|----------------------|------------------------------------------------------------------------------------------------------------------------|----------------------|-----------------------------------------------------------------------|
| Inicial              | estado inicial do jogo                                                                                                 | inicializa_elementos | iniciar = 1                                                           |
| inicializa_elementos | faz a inicialização dos<br>elementos, preparando<br>para jogada                                                        | espera_jogada        |                                                                       |
| espera_jogada        | enquanto o jogador não<br>fizer uma jogada nao<br>inicia                                                               | registra_jogada      | jogada=1                                                              |
| registra_jogada      | armazena no registrador<br>a jogada                                                                                    | compara_jogada       |                                                                       |
| compara_jogada       | faz a comparação entre a<br>jogada e o valor da<br>memória ROM e continua<br>enquanto não errar e não<br>chegar ao fim | proxima_jogada       | igual=0 e fim=0                                                       |
| compara_jogada       | ao chegar no final se<br>todas as jogadas foram<br>iguais transiciona para o<br>estado de acerto                       | final_acertou        | igual=1 e fim=1                                                       |
| compara_jogada       | ao errar uma jogada<br>transiciona para o estado<br>de erro                                                            | final_errou          | igual=0                                                               |
| proxima_jogada       | faz o loop para a próxima<br>jogada                                                                                    | espera_jogada        |                                                                       |
| final_acertou        | final do jogo com acerto                                                                                               | inicializa_elementos | iniciar=0                                                             |
| final_errou          | final do jogo com erro                                                                                                 | inicializa_elementos | iniciar=0                                                             |

Para fins de validação, é realizado a partir da vista do FSM no Quartus, uma comparação entre o proposto acima e o gerado. Demonstra-se então correto funcionamento do circuito, conformando-se com o previsto:



fig 3. FSM Unidade de Controle

## 3.3 PROJETO DO SISTEMA DIGITAL

A integração entre fluxo de dados e unidade de controle é realizada por sinais de controle e status:

- Sinais de controle da UC para o FD: registraR, contaC, zeraC, zeraR.
- Sinais de status do FD para a UC: igual, jogada, fim (fim da contagem).

Além disso, os sinais db\_temjogada (que indica detecção de uma jogada) e db\_clock (cópia do sinal de *clock* para verificação externa) podem ser utilizados para depuração adicional caso necessário

A figura abaixo ilustra a integração do sistema digital:



fig 4. RTL Viewer

Como na experiência anterior, a interação entre os dois componentes permite que o sistema funcione de maneira sincronizada, pois a unidade de controle gerencia a execução do fluxo de dados em cada ciclo de clock.

## 4 PLANO DE TESTES DO SISTEMA E SIMULAÇÕES

Este capítulo tem o objetivo de documentar a estratégia dos testes do sistema desenvolvido e documentado no capítulo 3 e apresentar os resultados das respectivas simulações realizadas.

# 4.1 Cenário de Teste 1 – Teste do Circuito Completo Com Todas as Jogadas Acertadas

Nessa seção, tomasse como objetivo validar que ao acertar todas as sequências propostas pela memória ROM o jogador termina no estado de acertou com todos os devidos sinais ativados corretamente, onde tais detalhes podem ser consultados a partir da tabela abaixo, que lista todos os sinais e o comportamento observado.

Tabela 2 – Plano de Teste para Acertar

| Descrição do<br>Estado | Sinais de Entrada                | Saída Esperada                                                         | Observações |
|------------------------|----------------------------------|------------------------------------------------------------------------|-------------|
| Condições Iniciais     | iniciar=0 reset=0<br>chaves=0000 | acertou=0 errou=0 pronto=0<br>db_igual=0 db_temjogada=0<br>db_estado=0 | ok          |

| Descrição do<br>Estado                                                                                 | Sinais de Entrada                | Saída Esperada                                                                                                              | Observações |
|--------------------------------------------------------------------------------------------------------|----------------------------------|-----------------------------------------------------------------------------------------------------------------------------|-------------|
|                                                                                                        |                                  | db_jogadafeita=0<br>db_memoria=0<br>db_contagem=0 leds=0                                                                    |             |
| Acionar o Reset<br>para ir ao estado de<br>início                                                      | iniciar=0 reset=1<br>chaves=0000 | zeraC=1 zeraR=1                                                                                                             | ok          |
| Aguardar alguns segundos                                                                               |                                  |                                                                                                                             |             |
| Acionar o Iniciar                                                                                      | iniciar=1 reset=0<br>chaves=0000 | zeraC=1 db_estado=0001                                                                                                      | ok          |
| Acionar primeira<br>entrada (jogada 1)<br>Aguardar ate o fim<br>da operação quando<br>db_estado = 0110 | iniciar=0 reset=0<br>chaves=0001 | db_igual=1 db_temjogada=1<br>db_jogadafeita=0001<br>db_memoria=0001<br>db_contagem=1 leds=0001<br>db_estado=(0011 ate 0110) | ok          |
| Acionar primeira<br>entrada (jogada 2)<br>Aguardar ate o fim<br>da operação quando<br>db_estado = 0110 | iniciar=0 reset=0<br>chaves=0010 | db_igual=1 db_temjogada=1<br>db_jogadafeita=0010<br>db_memoria=0010<br>db_contagem=1 leds=0010<br>db_estado=(0011 ate 0110) | erro        |
| Acionar primeira<br>entrada (jogada 3)<br>Aguardar ate o fim<br>da operacao quando<br>db_estado = 0110 | iniciar=0 reset=0<br>chaves=0100 | db_igual=1 db_temjogada=1<br>db_jogadafeita=0100<br>db_memoria=0100<br>db_contagem=1 leds=0100<br>db_estado=(0011 ate 0110) |             |
| Acionar primeira<br>entrada (jogada 4)<br>Aguardar ate o fim<br>da operacao quando<br>db_estado = 0110 | iniciar=0 reset=0<br>chaves=1000 | db_igual=1 db_temjogada=1<br>db_jogadafeita=1000<br>db_memoria=1000<br>db_contagem=1 leds=1000<br>db_estado=(0011 ate 0110) |             |
| Acionar primeira<br>entrada (jogada 5)<br>Aguardar ate o fim<br>da operacao quando<br>db_estado = 0110 | iniciar=0 reset=0<br>chaves=0100 | db_igual=1 db_temjogada=1<br>db_jogadafeita=0100<br>db_memoria=0100<br>db_contagem=1 leds=0100<br>db_estado=(0011 ate 0110) |             |
| Acionar primeira<br>entrada (jogada 6)<br>Aguardar ate o fim<br>da operacao quando<br>db_estado = 0110 | iniciar=0 reset=0<br>chaves=0010 | db_igual=1 db_temjogada=1<br>db_jogadafeita=0010<br>db_memoria=0010<br>db_contagem=1 leds=0010<br>db_estado=(0011 ate 0110) |             |
| Acionar primeira entrada (jogada 7)                                                                    | iniciar=0 reset=0<br>chaves=0001 | db_igual=1 db_temjogada=1<br>db_jogadafeita=0001                                                                            |             |

| Descrição do<br>Estado                                                                                  | Sinais de Entrada                | Saída Esperada                                                                                                              | Observações |
|---------------------------------------------------------------------------------------------------------|----------------------------------|-----------------------------------------------------------------------------------------------------------------------------|-------------|
| Aguardar ate o fim da operacao quando db_estado = 0110                                                  |                                  | db_memoria=0001<br>db_contagem=1 leds=0001<br>db_estado=(0011 ate 0110)                                                     |             |
| Acionar primeira entrada (jogada 8) Aguardar ate o fim da operacao quando db_estado = 0110              | iniciar=0 reset=0<br>chaves=0001 | db_igual=1 db_temjogada=1<br>db_jogadafeita=0001<br>db_memoria=0001<br>db_contagem=1 leds=0001<br>db_estado=(0011 ate 0110) |             |
| Acionar primeira<br>entrada (jogada 9)<br>Aguardar ate o fim<br>da operacao quando<br>db_estado = 0110  | iniciar=0 reset=0<br>chaves=0010 | db_igual=1 db_temjogada=1 db_jogadafeita=0010 db_memoria=0010 db_contagem=1 leds=0010 db_estado=(0011 ate 0110)             |             |
| Acionar primeira<br>entrada (jogada 10)<br>Aguardar ate o fim<br>da operacao quando<br>db_estado = 0110 | iniciar=0 reset=0<br>chaves=0010 | db_igual=1 db_temjogada=1<br>db_jogadafeita=0010<br>db_memoria=0010<br>db_contagem=1 leds=0010<br>db_estado=(0011 ate 0110) |             |
| Acionar primeira<br>entrada (jogada 11)<br>Aguardar ate o fim<br>da operacao quando<br>db_estado = 0110 | iniciar=0 reset=0<br>chaves=0100 | db_igual=1 db_temjogada=1<br>db_jogadafeita=0100<br>db_memoria=0100<br>db_contagem=1 leds=0100<br>db_estado=(0011 ate 0110) |             |
| Acionar primeira<br>entrada (jogada 12)<br>Aguardar ate o fim<br>da operacao quando<br>db_estado = 0110 | iniciar=0 reset=0<br>chaves=0100 | db_igual=1 db_temjogada=1<br>db_jogadafeita=0100<br>db_memoria=0100<br>db_contagem=1 leds=0100<br>db_estado=(0011 ate 0110) |             |
| Acionar primeira<br>entrada (jogada 13)<br>Aguardar ate o fim<br>da operacao quando<br>db_estado = 0110 | iniciar=0 reset=0<br>chaves=1000 | db_igual=1 db_temjogada=1<br>db_jogadafeita=1000<br>db_memoria=1000<br>db_contagem=1 leds=1000<br>db_estado=(0011 ate 0110) |             |
| Acionar primeira entrada (jogada 14) Aguardar ate o fim da operacao quando db_estado = 0110             | iniciar=0 reset=0<br>chaves=1000 | db_igual=1 db_temjogada=1<br>db_jogadafeita=1000<br>db_memoria=1000<br>db_contagem=1 leds=1000<br>db_estado=(0011 ate 0110) |             |
| Acionar primeira<br>entrada (jogada 15)<br>Aguardar ate o fim<br>da operacao quando<br>db_estado = 0110 | iniciar=0 reset=0<br>chaves=0001 | db_igual=1 db_temjogada=1<br>db_jogadafeita=0001<br>db_memoria=0001<br>db_contagem=1 leds=0001<br>db_estado=(0011 ate 0110) |             |

| Descrição do<br>Estado                                                                                  | Sinais de Entrada                | Saída Esperada                                                                                    | Observações |
|---------------------------------------------------------------------------------------------------------|----------------------------------|---------------------------------------------------------------------------------------------------|-------------|
| Acionar primeira<br>entrada (jogada 16)<br>Aguardar ate o fim<br>da operacao quando<br>db_estado = 0110 | iniciar=0 reset=0<br>chaves=0100 | acertou=1 pronto=1<br>db_igual=1 db_estado=0111<br>db_jogada=0100<br>db_memoria=0100<br>leds=0100 |             |

A validação foi realizada a partir da carta de tempo gerada no *ModelSim*, e pode ser observada logo a baixo com suas devidas observações.



fig 6. Carta de tempo do primeiro teste

Como é possível notar, a partir da segunda jogada o circuito começou a apresentar um comportamento anômalo, então para uma verificação mais visual foi montado o mesmo utilizando o *Digital* e replicando os testes para observar onde estaria o problema.



fig 6. Condições Iniciais



fig 7. Sinal de iniciar Ativado



fig 8. Erro ao se iniciar a segunda jogada

Foi possível observar, que ao se realizar a segunda interação, o circuito detecta que uma jogada já foi realizada, utilizando a jogada anterior, o que faz parecer que o usuário errou, quando na verdade ele ainda não adicionou sua jogada.

Depois de feita a depuração, foi identificado um erro no sinal que reseta a jogada, onde a cada nova contagem ele era zerado e o que não deveria acontecer, apenas quando os elementos forem inicializados. Com as devidas alterações feitas no fluxo de dados, novamente o circuito foi posto a teste.

- Antes

```
assign reset_detector = zeraC | contaC;
- Depois
assign reset detector = zeraC;
```



fig 9. Estado de Acerto Digital

Tabela 3 – Plano de Teste para Acertar segundo teste

| Descrição do<br>Estado                                                                                 | Sinais de Entrada                | Saída Esperada                                                                                                              | Observações |
|--------------------------------------------------------------------------------------------------------|----------------------------------|-----------------------------------------------------------------------------------------------------------------------------|-------------|
| Condições Iniciais                                                                                     | iniciar=0 reset=0<br>chaves=0000 | acertou=0 errou=0 pronto=0 db_igual=0 db_temjogada=0 db_estado=0 db_jogadafeita=0 db_memoria=0 db_contagem=0 leds=0         | ok          |
| Acionar o Reset<br>para ir ao estado de<br>início                                                      | iniciar=0 reset=1<br>chaves=0000 | zeraC=1 zeraR=1                                                                                                             | ok          |
| Aguardar alguns segundos                                                                               |                                  |                                                                                                                             |             |
| Acionar o Iniciar                                                                                      | iniciar=1 reset=0<br>chaves=0000 | zeraC=1 db_estado=0001                                                                                                      | ok          |
| Acionar primeira<br>entrada (jogada 1)<br>Aguardar ate o fim<br>da operação quando<br>db_estado = 0110 | iniciar=0 reset=0<br>chaves=0001 | db_igual=1 db_temjogada=1 db_jogadafeita=0001 db_memoria=0001 db_contagem=1 leds=0001 db_estado=(0011 ate 0110)             | ok          |
| Acionar primeira<br>entrada (jogada 2)<br>Aguardar ate o fim<br>da operação quando<br>db_estado = 0110 | iniciar=0 reset=0<br>chaves=0010 | db_igual=1 db_temjogada=1<br>db_jogadafeita=0010<br>db_memoria=0010<br>db_contagem=1 leds=0010<br>db_estado=(0011 ate 0110) | ok          |
| Acionar primeira<br>entrada (jogada 3)<br>Aguardar ate o fim<br>da operacao quando                     | iniciar=0 reset=0<br>chaves=0100 | db_igual=1 db_temjogada=1<br>db_jogadafeita=0100<br>db_memoria=0100<br>db_contagem=1 leds=0100                              | ok          |

| Descrição do<br>Estado                                                                                  | Sinais de Entrada                | Saída Esperada                                                                                                              | Observações |
|---------------------------------------------------------------------------------------------------------|----------------------------------|-----------------------------------------------------------------------------------------------------------------------------|-------------|
| db_estado = 0110                                                                                        |                                  | db_estado=(0011 ate 0110)                                                                                                   |             |
| Acionar primeira entrada (jogada 4) Aguardar ate o fim da operacao quando db_estado = 0110              | iniciar=0 reset=0<br>chaves=1000 | db_igual=1 db_temjogada=1<br>db_jogadafeita=1000<br>db_memoria=1000<br>db_contagem=1 leds=1000<br>db_estado=(0011 ate 0110) | ok          |
| Acionar primeira entrada (jogada 5) Aguardar ate o fim da operacao quando db_estado = 0110              | iniciar=0 reset=0<br>chaves=0100 | db_igual=1 db_temjogada=1<br>db_jogadafeita=0100<br>db_memoria=0100<br>db_contagem=1 leds=0100<br>db_estado=(0011 ate 0110) | ok          |
| Acionar primeira entrada (jogada 6) Aguardar ate o fim da operacao quando db_estado = 0110              | iniciar=0 reset=0<br>chaves=0010 | db_igual=1 db_temjogada=1<br>db_jogadafeita=0010<br>db_memoria=0010<br>db_contagem=1 leds=0010<br>db_estado=(0011 ate 0110) | ok          |
| Acionar primeira<br>entrada (jogada 7)<br>Aguardar ate o fim<br>da operacao quando<br>db_estado = 0110  | iniciar=0 reset=0<br>chaves=0001 | db_igual=1 db_temjogada=1<br>db_jogadafeita=0001<br>db_memoria=0001<br>db_contagem=1 leds=0001<br>db_estado=(0011 ate 0110) | ok          |
| Acionar primeira<br>entrada (jogada 8)<br>Aguardar ate o fim<br>da operacao quando<br>db_estado = 0110  | iniciar=0 reset=0<br>chaves=0001 | db_igual=1 db_temjogada=1<br>db_jogadafeita=0001<br>db_memoria=0001<br>db_contagem=1 leds=0001<br>db_estado=(0011 ate 0110) | ok          |
| Acionar primeira<br>entrada (jogada 9)<br>Aguardar ate o fim<br>da operacao quando<br>db_estado = 0110  | iniciar=0 reset=0<br>chaves=0010 | db_igual=1 db_temjogada=1 db_jogadafeita=0010 db_memoria=0010 db_contagem=1 leds=0010 db_estado=(0011 ate 0110)             | ok          |
| Acionar primeira<br>entrada (jogada 10)<br>Aguardar ate o fim<br>da operacao quando<br>db_estado = 0110 | iniciar=0 reset=0<br>chaves=0010 | db_igual=1 db_temjogada=1<br>db_jogadafeita=0010<br>db_memoria=0010<br>db_contagem=1 leds=0010<br>db_estado=(0011 ate 0110) | ok          |
| Acionar primeira<br>entrada (jogada 11)<br>Aguardar ate o fim<br>da operacao quando<br>db_estado = 0110 | iniciar=0 reset=0<br>chaves=0100 | db_igual=1 db_temjogada=1<br>db_jogadafeita=0100<br>db_memoria=0100<br>db_contagem=1 leds=0100<br>db_estado=(0011 ate 0110) | ok          |
| Acionar primeira<br>entrada (jogada 12)<br>Aguardar ate o fim                                           | iniciar=0 reset=0<br>chaves=0100 | db_igual=1 db_temjogada=1<br>db_jogadafeita=0100<br>db_memoria=0100                                                         | ok          |

| Descrição do<br>Estado                                                                                  | Sinais de Entrada                | Saída Esperada                                                                                                              | Observações |
|---------------------------------------------------------------------------------------------------------|----------------------------------|-----------------------------------------------------------------------------------------------------------------------------|-------------|
| da operacao quando<br>db_estado = 0110                                                                  |                                  | db_contagem=1 leds=0100<br>db_estado=(0011 ate 0110)                                                                        |             |
| Acionar primeira<br>entrada (jogada 13)<br>Aguardar ate o fim<br>da operacao quando<br>db_estado = 0110 | iniciar=0 reset=0<br>chaves=1000 | db_igual=1 db_temjogada=1<br>db_jogadafeita=1000<br>db_memoria=1000<br>db_contagem=1 leds=1000<br>db_estado=(0011 ate 0110) | ok          |
| Acionar primeira<br>entrada (jogada 14)<br>Aguardar ate o fim<br>da operacao quando<br>db_estado = 0110 | iniciar=0 reset=0<br>chaves=1000 | db_igual=1 db_temjogada=1<br>db_jogadafeita=1000<br>db_memoria=1000<br>db_contagem=1 leds=1000<br>db_estado=(0011 ate 0110) | ok          |
| Acionar primeira<br>entrada (jogada 15)<br>Aguardar ate o fim<br>da operacao quando<br>db_estado = 0110 | iniciar=0 reset=0<br>chaves=0001 | db_igual=1 db_temjogada=1<br>db_jogadafeita=0001<br>db_memoria=0001<br>db_contagem=1 leds=0001<br>db_estado=(0011 ate 0110) | ok          |
| Acionar primeira<br>entrada (jogada 16)<br>Aguardar ate o fim<br>da operacao quando<br>db_estado = 0110 | iniciar=0 reset=0<br>chaves=0100 | acertou=1 pronto=1<br>db_igual=1 db_estado=0111<br>db_jogada=0100<br>db_memoria=0100<br>leds=0100                           | ok          |

## 4.2 CENÁRIO DE TESTE 2 - TESTE DO CIRCUITO COMPLETO COM ERRO NA QUARTA JOGADA

Após testar o Primeiro Cenário, um teste similar foi elaborado para testar quando o jogador erra uma jogada.

Tabela 4 – Plano de Teste para Errar na quarta jogada

| Descrição do<br>Estado                      | Sinais de Entrada                | Saída Esperada                                                                                                      | Observações |
|---------------------------------------------|----------------------------------|---------------------------------------------------------------------------------------------------------------------|-------------|
| Condições Iniciais                          | iniciar=0 reset=0<br>chaves=0000 | acertou=0 errou=0 pronto=0 db_igual=0 db_temjogada=0 db_estado=0 db_jogadafeita=0 db_memoria=0 db_contagem=0 leds=0 | ok          |
| Acionar o Reset para ir ao estado de inicio | iniciar=0 reset=1<br>chaves=0000 | zeraC=1 zeraR=1                                                                                                     | ok          |
| Aguardar alguns segundos                    |                                  |                                                                                                                     | ok          |

| Descrição do<br>Estado                                                                                 | Sinais de Entrada                | Saída Esperada                                                                                                              | Observações |
|--------------------------------------------------------------------------------------------------------|----------------------------------|-----------------------------------------------------------------------------------------------------------------------------|-------------|
| Acionar o Iniciar                                                                                      | iniciar=1 reset=0<br>chaves=0000 | zeraC=1 db_estado=0001                                                                                                      | ok          |
| Acionar primeira entrada (jogada 1) Aguardar ate o fim da operacao quando db_estado = 0110             | iniciar=0 reset=0<br>chaves=0001 | db_igual=1 db_temjogada=1<br>db_jogadafeita=0001<br>db_memoria=0001<br>db_contagem=1 leds=0001<br>db_estado=(0011 ate 0110) | ok          |
| Acionar primeira entrada (jogada 2) Aguardar ate o fim da operacao quando db_estado = 0110             | iniciar=0 reset=0<br>chaves=0010 | db_igual=1 db_temjogada=1 db_jogadafeita=0010 db_memoria=0010 db_contagem=1 leds=0010 db_estado=(0011 ate 0110)             | ok          |
| Acionar primeira entrada (jogada 3) Aguardar ate o fim da operacao quando db_estado = 0110             | iniciar=0 reset=0<br>chaves=0100 | db_igual=1 db_temjogada=1<br>db_jogadafeita=0100<br>db_memoria=0100<br>db_contagem=1 leds=0100<br>db_estado=(0011 ate 0110) | ok          |
| Acionar primeira entrada<br>(jogada 4) Aguardar ate<br>o fim da operacao<br>quando db_estado =<br>0110 | iniciar=0 reset=0<br>chaves=0001 | errou=1 pronto=1 db_igual=0<br>db_estado=1000 db_jogada=0001<br>db_memoria=1000 leds=0001                                   | ok          |



fig 10. Carta de Tempo Errou quarta jogada



fig 11. Simulação do Sistema Digital

## 5 IMPLANTAÇÃO DO PROJETO

Este capítulo tem o objetivo de documentar as atividades práticas de execução do projeto desenvolvido e documentado no capítulo 3 no ambiente do Laboratório Digital.

(imagem da placa FPGA no lab)

## 5.1 PINAGEM DA PLACA FPGA

A pinagem foi definida no Intel Quartus Prime utilizando o *Pin Planner*, associando os sinais do projeto aos pinos físicos da FPGA Cyclone V (placa DE0-CV). A figura abaixo apresenta o plano de pinagem detalhado:



fig 12. Pin planner

#### 5.2 Estratégia de Montagem

A implementação física do projeto segue três etapas principais. Em primeiro lugar, a programação da FPGA é realizada no Intel Quartus Prime, onde o projeto é compilado para gerar o arquivo .sof, transferido posteriormente para a placa DE0-CV por meio do *Programmer* via cabo USB.

Em seguida, as conexões físicas são estabelecidas: o dispositivo Analog Discovery é conectado aos pinos GPIO da FPGA para gerar os sinais de *clock* (canal DI00) e *reset* (canal DI01), enquanto as chaves da placa (SW0 a SW3) são mapeadas para as entradas CHAVES[0] a CHAVES[3]. Os LEDs (LEDR0 a LEDR9) e os displays de sete segmentos (HEX0 a HEX5) são configurados para exibir as saídas de depuração, como db\_contagem e db\_estado. Por fim, o sinal de *clock* é configurado na ferramenta *Patterns* do Waveforms (Analog Discovery) para operar em 1 kHz, garantindo a sincronização adequada das operações.

## 5.3 ESTRATÉGIA DE DEPURAÇÃO

A depuração do projeto deve seguir uma abordagem sistemática para identificar e resolver problemas, assegurando o correto funcionamento do sistema. Os LEDs são utilizados para verificar sinais críticos como pronto, acertou e errou, enquanto os displays de sete segmentos permitem a leitura em tempo real de db\_contagem (endereço da memória), db\_estado (código do estado da UC) e db\_jogadafeita (valor das chaves registrado)

No laboratório, não é necessário o uso de equipamentos especiais além dos já citados, pois a análise dos sinais diretamente nos displays e LEDs é suficiente para a depuração física do projeto. Se forem detectados problemas no circuito lógico, são feitos ajustes no código Verilog, e a FPGA é recompilada. Para questões de montagem, as conexões físicas são verificadas e corrigidas, se necessário. Após cada modificação, testes específicos são realizados para assegurar que as funcionalidades já validadas não foram afetadas, garantindo a integridade e o funcionamento completo do sistema.

## 5.4 Execução Prática do Cenário de Teste 1 – Integração com a FPGA

Este plano de testes busca avaliar o funcionamento do circuito construído anteriormente na placa FPGA. A ordem de execução e as entradas de cada etapa de teste são as mesmas realizadas na simulação digital deste. Desse modo, no caso da aparição de algum erro, é possível identificar com maior facilidade seus motivos.

Tabela 3 - Plano de Teste para Acertar

| Descrição do<br>Estado                      | Sinais de Entrada                | Saída Esperada                                                                                                      | Observações |
|---------------------------------------------|----------------------------------|---------------------------------------------------------------------------------------------------------------------|-------------|
| Condições Iniciais                          | iniciar=0 reset=0<br>chaves=0000 | acertou=0 errou=0 pronto=0 db_igual=0 db_temjogada=0 db_estado=0 db_jogadafeita=0 db_memoria=0 db_contagem=0 leds=0 |             |
| Acionar o Reset para ir ao estado de início | iniciar=0 reset=1<br>chaves=0000 | zeraC=1 zeraR=1                                                                                                     |             |
| Aguardar alguns segundos                    |                                  |                                                                                                                     |             |

| Descrição do<br>Estado                                                                                 | Sinais de Entrada                | Saída Esperada                                                                                                              | Observações |
|--------------------------------------------------------------------------------------------------------|----------------------------------|-----------------------------------------------------------------------------------------------------------------------------|-------------|
| Acionar o Iniciar                                                                                      | iniciar=1 reset=0<br>chaves=0000 | zeraC=1 db_estado=0001                                                                                                      |             |
| Acionar primeira<br>entrada (jogada 1)<br>Aguardar ate o fim<br>da operação quando<br>db_estado = 0110 | iniciar=0 reset=0<br>chaves=0001 | db_igual=1 db_temjogada=1<br>db_jogadafeita=0001<br>db_memoria=0001<br>db_contagem=1 leds=0001<br>db_estado=(0011 ate 0110) |             |
| Acionar primeira<br>entrada (jogada 2)<br>Aguardar ate o fim<br>da operação quando<br>db_estado = 0110 | iniciar=0 reset=0<br>chaves=0010 | db_igual=1 db_temjogada=1<br>db_jogadafeita=0010<br>db_memoria=0010<br>db_contagem=1 leds=0010<br>db_estado=(0011 ate 0110) |             |
| Acionar primeira entrada (jogada 3) Aguardar ate o fim da operacao quando db_estado = 0110             | iniciar=0 reset=0<br>chaves=0100 | db_igual=1 db_temjogada=1<br>db_jogadafeita=0100<br>db_memoria=0100<br>db_contagem=1 leds=0100<br>db_estado=(0011 ate 0110) |             |
| Acionar primeira entrada (jogada 4) Aguardar ate o fim da operacao quando db_estado = 0110             | iniciar=0 reset=0<br>chaves=1000 | db_igual=1 db_temjogada=1 db_jogadafeita=1000 db_memoria=1000 db_contagem=1 leds=1000 db_estado=(0011 ate 0110)             |             |
| Acionar primeira entrada (jogada 5) Aguardar ate o fim da operacao quando db_estado = 0110             | iniciar=0 reset=0<br>chaves=0100 | db_igual=1 db_temjogada=1<br>db_jogadafeita=0100<br>db_memoria=0100<br>db_contagem=1 leds=0100<br>db_estado=(0011 ate 0110) |             |
| Acionar primeira entrada (jogada 6) Aguardar ate o fim da operacao quando db_estado = 0110             | iniciar=0 reset=0<br>chaves=0010 | db_igual=1 db_temjogada=1<br>db_jogadafeita=0010<br>db_memoria=0010<br>db_contagem=1 leds=0010<br>db_estado=(0011 ate 0110) |             |
| Acionar primeira entrada (jogada 7) Aguardar ate o fim da operacao quando db_estado = 0110             | iniciar=0 reset=0<br>chaves=0001 | db_igual=1 db_temjogada=1<br>db_jogadafeita=0001<br>db_memoria=0001<br>db_contagem=1 leds=0001<br>db_estado=(0011 ate 0110) |             |
| Acionar primeira entrada (jogada 8) Aguardar ate o fim da operacao quando db_estado = 0110             | iniciar=0 reset=0<br>chaves=0001 | db_igual=1 db_temjogada=1<br>db_jogadafeita=0001<br>db_memoria=0001<br>db_contagem=1 leds=0001<br>db_estado=(0011 ate 0110) |             |

| Descrição do<br>Estado                                                                                  | Sinais de Entrada                | Saída Esperada                                                                                                              | Observações |
|---------------------------------------------------------------------------------------------------------|----------------------------------|-----------------------------------------------------------------------------------------------------------------------------|-------------|
| Acionar primeira<br>entrada (jogada 9)<br>Aguardar ate o fim<br>da operacao quando<br>db_estado = 0110  | iniciar=0 reset=0<br>chaves=0010 | db_igual=1 db_temjogada=1 db_jogadafeita=0010 db_memoria=0010 db_contagem=1 leds=0010 db_estado=(0011 ate 0110)             |             |
| Acionar primeira<br>entrada (jogada 10)<br>Aguardar ate o fim<br>da operacao quando<br>db_estado = 0110 | iniciar=0 reset=0<br>chaves=0010 | db_igual=1 db_temjogada=1<br>db_jogadafeita=0010<br>db_memoria=0010<br>db_contagem=1 leds=0010<br>db_estado=(0011 ate 0110) |             |
| Acionar primeira<br>entrada (jogada 11)<br>Aguardar ate o fim<br>da operacao quando<br>db_estado = 0110 | iniciar=0 reset=0<br>chaves=0100 | db_igual=1 db_temjogada=1<br>db_jogadafeita=0100<br>db_memoria=0100<br>db_contagem=1 leds=0100<br>db_estado=(0011 ate 0110) |             |
| Acionar primeira<br>entrada (jogada 12)<br>Aguardar ate o fim<br>da operacao quando<br>db_estado = 0110 | iniciar=0 reset=0<br>chaves=0100 | db_igual=1 db_temjogada=1<br>db_jogadafeita=0100<br>db_memoria=0100<br>db_contagem=1 leds=0100<br>db_estado=(0011 ate 0110) |             |
| Acionar primeira<br>entrada (jogada 13)<br>Aguardar ate o fim<br>da operacao quando<br>db_estado = 0110 | iniciar=0 reset=0<br>chaves=1000 | db_igual=1 db_temjogada=1<br>db_jogadafeita=1000<br>db_memoria=1000<br>db_contagem=1 leds=1000<br>db_estado=(0011 ate 0110) |             |
| Acionar primeira<br>entrada (jogada 14)<br>Aguardar ate o fim<br>da operacao quando<br>db_estado = 0110 | iniciar=0 reset=0<br>chaves=1000 | db_igual=1 db_temjogada=1<br>db_jogadafeita=1000<br>db_memoria=1000<br>db_contagem=1 leds=1000<br>db_estado=(0011 ate 0110) |             |
| Acionar primeira<br>entrada (jogada 15)<br>Aguardar ate o fim<br>da operacao quando<br>db_estado = 0110 | iniciar=0 reset=0<br>chaves=0001 | db_igual=1 db_temjogada=1<br>db_jogadafeita=0001<br>db_memoria=0001<br>db_contagem=1 leds=0001<br>db_estado=(0011 ate 0110) |             |
| Acionar primeira<br>entrada (jogada 16)<br>Aguardar ate o fim<br>da operacao quando<br>db_estado = 0110 | iniciar=0 reset=0<br>chaves=0100 | acertou=1 pronto=1<br>db_igual=1 db_estado=0111<br>db_jogada=0100<br>db_memoria=0100<br>leds=0100                           |             |

## 5.5 Execução Prática do Cenário de Teste 2 – Integração com a FPGA

Este plano de testes busca avaliar o funcionamento do circuito construído anteriormente na placa FPGA. A ordem de execução e as entradas de cada etapa de teste são as mesmas realizadas na simulação digital deste. Desse modo, no caso da aparição de algum erro, é possível identificar com maior facilidade seus motivos.

Tabela 4 – Plano de Teste para Errar na quarta jogada

| Descrição do<br>Estado                                                                                 | Sinais de Entrada                | Saída Esperada                                                                                                              | Observações |
|--------------------------------------------------------------------------------------------------------|----------------------------------|-----------------------------------------------------------------------------------------------------------------------------|-------------|
| Condições Iniciais                                                                                     | iniciar=0 reset=0<br>chaves=0000 | acertou=0 errou=0 pronto=0 db_igual=0 db_temjogada=0 db_estado=0 db_jogadafeita=0 db_memoria=0 db_contagem=0 leds=0         |             |
| Acionar o Reset<br>para ir ao estado de<br>inicio                                                      | iniciar=0 reset=1<br>chaves=0000 | zeraC=1 zeraR=1                                                                                                             |             |
| Aguardar alguns segundos                                                                               |                                  |                                                                                                                             |             |
| Acionar o Iniciar                                                                                      | iniciar=1 reset=0<br>chaves=0000 | zeraC=1 db_estado=0001                                                                                                      |             |
| Acionar primeira entrada (jogada 1) Aguardar ate o fim da operacao quando db_estado = 0110             | iniciar=0 reset=0<br>chaves=0001 | db_igual=1 db_temjogada=1 db_jogadafeita=0001 db_memoria=0001 db_contagem=1 leds=0001 db_estado=(0011 ate 0110)             |             |
| Acionar primeira entrada (jogada 2) Aguardar ate o fim da operacao quando db_estado = 0110             | iniciar=0 reset=0<br>chaves=0010 | db_igual=1 db_temjogada=1 db_jogadafeita=0010 db_memoria=0010 db_contagem=1 leds=0010 db_estado=(0011 ate 0110)             |             |
| Acionar primeira entrada (jogada 3) Aguardar ate o fim da operacao quando db_estado = 0110             | iniciar=0 reset=0<br>chaves=0100 | db_igual=1 db_temjogada=1<br>db_jogadafeita=0100<br>db_memoria=0100<br>db_contagem=1 leds=0100<br>db_estado=(0011 ate 0110) |             |
| Acionar primeira entrada<br>(jogada 4) Aguardar ate<br>o fim da operacao<br>quando db_estado =<br>0110 | iniciar=0 reset=0<br>chaves=0001 | errou=1 pronto=1 db_igual=0<br>db_estado=1000 db_jogada=0001<br>db_memoria=1000 leds=0001                                   |             |

| 6.2.3 Alterações do Sistema Digital |                                        |                                  |                             |                                 |
|-------------------------------------|----------------------------------------|----------------------------------|-----------------------------|---------------------------------|
| 6.3 VERIFICA                        | 6.3 Verificação e Validação do Desafio |                                  |                             |                                 |
| 6.3.1 Cená                          | rio de Teste 1 –                       |                                  |                             |                                 |
| Tak                                 | pela 6 – Descrição e Resul             | Itados do Cena                   | ário de Teste 1 pa          | ara o Desafio                   |
| Entradas                            | Saídas Esperadas                       | Resultad<br>o<br>Simulado<br>OK? | Resultado<br>Prático<br>OK? | Análise de Não<br>Conformidades |
|                                     |                                        |                                  |                             |                                 |
|                                     |                                        |                                  |                             |                                 |
|                                     |                                        |                                  |                             |                                 |
|                                     |                                        |                                  |                             |                                 |
|                                     |                                        |                                  |                             |                                 |
|                                     |                                        |                                  |                             |                                 |
|                                     |                                        |                                  |                             |                                 |
|                                     |                                        |                                  |                             |                                 |
|                                     |                                        |                                  |                             |                                 |

6 Projeto do Desafio da Experiência

6.2 Descrição do Projeto Lógico

6.2.1 Alterações do Fluxo de Dados

6.2.2 Alterações da Unidade de Controle

6.1 DESCRIÇÃO DO DESAFIO

| Entradas | Saídas Esperadas | Resultad<br>o<br>Simulado<br>OK? | Resultado<br>Prático<br>OK? | Análise de Não<br>Conformidades |
|----------|------------------|----------------------------------|-----------------------------|---------------------------------|
|          |                  |                                  |                             |                                 |
|          |                  |                                  |                             |                                 |
|          |                  |                                  |                             |                                 |
|          |                  |                                  |                             |                                 |
|          |                  |                                  |                             |                                 |
|          |                  |                                  |                             |                                 |
|          |                  |                                  |                             |                                 |
|          |                  |                                  |                             |                                 |
|          |                  |                                  |                             |                                 |
|          |                  |                                  |                             |                                 |

## 6.3.2 Cenário de Teste 2 -

.

Tabela 7 – Descrição e Resultados do Cenário de Teste 2 para o Desafio

| Entradas | Saídas Esperadas | Resultado<br>Simulado<br>OK? | Resultado<br>Prático<br>OK? | Análise de Não<br>Conformidades |
|----------|------------------|------------------------------|-----------------------------|---------------------------------|
|          |                  |                              |                             |                                 |
|          |                  |                              |                             |                                 |
|          |                  |                              |                             |                                 |
|          |                  |                              |                             |                                 |
|          |                  |                              |                             |                                 |
|          |                  |                              |                             |                                 |
|          |                  |                              |                             |                                 |
|          |                  |                              |                             |                                 |
|          |                  |                              |                             |                                 |
|          |                  |                              |                             |                                 |
|          |                  |                              |                             |                                 |
|          |                  |                              |                             |                                 |

## 7 Conclusões