

# Experiência 3 – Projeto de uma Unidade de Controle

PCS3635 – Laboratório de  
Projeto de Sistemas Digitais I  
1º Quadrimestre de 2026

# Experiência 3

- Objetivos

- Projeto hierárquico de circuitos com fluxo de dados e unidade de controle;
- Projeto da unidade de controle de um circuito digital;
- Codificação de uma máquina de estados em Verilog;
- Síntese em uma placa FPGA

**Algoritmo:** sistema digital simples  
entradas: iniciar, chaves  
saídas: pronto  
depuração: contagem, memória, estado, igual

```
1. {
2.     while (verdadeiro) {
3.         espera acionamento do sinal INICIAR
4.         Inicia circuito para condições iniciais
5.         enquanto não atingir o último dado {
6.             compara chaves de entrada com dados armazenados
7.             incrementa contador interno
8.         }
9.     }
10.    ativa saída PRONTO
11. }
```



```
17 architecture fsm of unidade_controle is
18 type t_estado is (A, B, C, D, E);
19 signal Eatual, Eprox: t_estado;
20 begin
21     -- memoria de estado
22     process (clock,reset)
23 begin
24     if reset='1' then
25         Eatual <= A;
26     elsif clock'event and clock = '1' then
27         Eatual <= Eprox;
28     end if;
29     end process;
30     -- logica de proximo estado
31     Eprox <=
32         A when Eatual=A and iniciar='0' else
33         B when Eatual=A and iniciar='1' else
34         C when Eatual=B else
35         D when Eatual=C and fim='1' else
36         E when Eatual=C and fim='0' else
37         E when Eatual=D else
38         C when Eatual=D else
39         A when Eatual=E else
40         A;
41     -- logica de saida (maquina de Moore)
42     with Eatual select
43         zera <= 1' when A | C | D | E,
44         '1' when B,
45         '0' when others;
```

# Experiência 3

- Especificação do Projeto da Experiência:

Projetar o circuito  
ao lado baseado em  
uma descrição usando  
Verilog e sintetizar  
em placa FPGA



# Experiência 3

- Desenvolvimento do Projeto da Experiência:
  1. Sistema Digital = Fluxo de Dados + Unidade de Controle
  2. Fluxo de Dados baseado no projeto da aula passada
  3. Unidade de Controle = máquina de estados
  4. Modificação proposta (Desafio)

# Experiência 3

- Projeto Lógico de um Sistema Digital

## **Descrição de funcionamento:**

1. O circuito do sistema digital sequencial inclui um conjunto de 16 dados de 4 bits que é armazenado em uma memória interna, cujos endereços são percorridos por meio de um contador interno.
2. Depois do acionamento do sinal `reset`, o circuito deve aguardar o início de sua operação até o acionamento do sinal de entrada `iniciar` – replicado na saída de depuração `db_inicial`.
3. Depois de iniciar seu funcionamento, o circuito deve armazenar o valor das chaves de entrada (sinal `chaves`) e depois comparar o conteúdo armazenado das chaves com o respectivo dado da memória.
4. A saída de depuração `db_igual` deve indicar o resultado da comparação.
5. Em seguida, o contador interno deve ser incrementado para posicionar o endereçamento da memória para permitir o acesso ao próximo dado da memória.
6. As saídas de depuração `db_contagem` e `db_memoria` indicam, respectivamente, o endereço e o dado armazenado pela memória, ao passo que a saída de depuração `db_estado`, por sua vez, deve indicar o código do estado vigente da Unidade de Controle em determinado instante do funcionamento do sistema digital .
7. O ciclo de comparação e reposicionamento da memória deve prosseguir até que todos os 16 dados sejam verificados.
8. Ao final da operação, o sinal de saída `pronto` deve ser acionado por um período de `clock`.
9. Depois disso, o circuito deve voltar para o estado inicial para aguardar a próxima ativação de `iniciar`.

# Experiência 3

- Projeto Lógico de um Sistema Digital



# Experiência 3

- Atividade 1 – Circuito da experiência
  1. Adaptação do fluxo de dados
  2. Estudo da unidade de controle
  3. Projeto do circuito da experiência
  4. Simulação com ModelSim



fluxo de dados



unidade de controle



sistema digital  
(descrição estrutural)



# Experiência 3

- Atividade 1 – Projeto Lógico de um Sistema Digital

- Desenvolvimento do Fluxo de dados

componentes  
registrador\_n e  
sync\_rom\_16x4  
fornecidos



# Experiência 3

- Atividade 1 – Projeto Lógico de um Sistema Digital

## Desenvolvimento da Unidade de Controle

1. O circuito do sistema digital sequencial inclui um conjunto de 16 dados de 4 bits que é armazenado em uma memória interna, cujos endereços são percorridos por meio de um contador interno.
2. **Depois do acionamento do sinal `reset`, o circuito deve aguardar o início de sua operação até o acionamento do sinal de entrada `iniciar`** – replicado na saída de depuração `db_inicial`.
3. **Depois de iniciar seu funcionamento**, o circuito deve armazenar o valor das chaves de entrada (sinal `chaves`) e depois comparar o conteúdo armazenado das chaves com o respectivo dado da memória.
4. A saída de depuração `db_igual` deve indicar o resultado da comparação.
5. **Em seguida**, o contador interno deve ser incrementado para posicionar o endereçamento da memória para permitir o acesso ao próximo dado da memória.
6. As saídas de depuração `db_contagem` e `db_memoria` indicam, respectivamente, o endereço e o dado armazenado pela memória, ao passo que a saída de depuração `db_estado`, por sua vez, deve indicar o código do estado vigente da Unidade de Controle em determinado instante do funcionamento do sistema digital .
7. O ciclo de comparação e reposicionamento da memória **deve prosseguir até que todos os 16 dados sejam verificados**.
8. **Ao final da operação, o sinal de saída `pronto` deve ser acionado por um período de `clock`**.
9. **Depois disso, o circuito deve voltar para o estado inicial** para aguardar a próxima ativação de `iniciar`.

# Experiência 3

## • Atividade 1 – Projeto Lógico de um Sistema Digital

1. O circuito do sistema digital sequencial inclui um conjunto de 16 dados de 4 bits que é armazenado em uma memória interna, cujos endereços são percorridos por meio de um contador interno.
2. **Depois do acionamento do sinal reset, o circuito deve aguardar o início de sua operação até o acionamento do sinal de entrada iniciar** – replicado na saída de depuração db\_inicial.
3. **Depois de iniciar seu funcionamento**, o circuito deve armazenar o valor das chaves de entrada (sinal chaves) e depois comparar o conteúdo armazenado das chaves com o respectivo dado da memória.
4. A saída de depuração db igual deve indicar o resultado da comparação.
5. **Em seguida** o contador interno deve ser incrementado para posicionar o endereçamento da memória para permitir o acesso ao próximo dado da memória.
6. As saídas de depuração db\_contagem e db\_memoria indicam, respectivamente, o endereço e o dado armazenado pela memória, ao passo que a saída de depuração db\_estado, por sua vez, deve indicar o código do estado vigente da Unidade de Controle em determinado instante do funcionamento do sistema digital .
7. O ciclo de comparação e reposicionamento da memória **deve prosseguir até que todos os 16 dados sejam verificados**.
8. **Ao final da operação, o sinal de saída pronto deve ser acionado por um período de clock**.
9. **Depois disso, o circuito deve voltar para o estado inicial** para aguardar a próxima ativação de iniciar.



# Experiência 3

- Atividade 1 – Projeto Lógico de um Sistema Digital
  - Sinais de controle e Sinais de condição para a Unidade de Controle



Diagrama de transição de alto nível

# Experiência 3

- Atividade 1 – Projeto Lógico de um Sistema Digital
  - Sinais de controle e Sinais de condição para a Unidade de Controle



Diagrama de transição de alto nível



exemplos de sinais



Diagrama de transição de estados

# Experiência 3

- Atividade 1 – Projeto Lógico de um Sistema Digital
  - Máquinas de estado em Verilog (`exp3_unidade_controle.v` – fornecido)

Estudar a tradução  
do diagrama de  
transição de estados  
para o código Verilog



Inconsistências?

# Experiência 3

- Simulação com **ModelSim** (circuito\_exp3) com *testbench*

Executar simulação dos testes contidos no Plano de Testes



Inserir anotações nas formas de onda no Planejamento.

# Experiência 3

- Projeto no Intel Quartus Prime

código Verilog

```
module circuito_exp3 (
    input ..... clock,
    input ..... reset,
    input ..... iniciar,
    input [3:0] chaves,
    output ..... pronto,
    output ..... db_igual,
    output ..... db_iniciar,
    output [6:0] db_contagem,
    output [6:0] db_memoria,
    output [6:0] db_chaves,
    output [6:0] db_estado
);
```



RTL Viewer

# Experiência 3

- Projeto no Intel Quartus Prime

código Verilog

```
module circuito_exp3 (
    input ..... clock,
    input ..... reset,
    input ..... iniciar,
    input [3:0] chaves,
    output ..... pronto
);
```

State Machine  
Viewer



RTLViewer

# Experiência 3

- Uso do **Analog Discovery** (ligação com a placa FPGA)

1. Ligar primeiro o fio **GND** (preto) no pino **GND** da **GPIO\_0**

2. Ligação dos canais digitais **DIO0** (rosa) e **DIO1** (verde) nos pinos **GPIO\_0\_D0** e **GPIO\_0\_D1** da **GPIO\_0**, respectivamente.



# Experiência 3

- Uso do Analog Discovery (ligação com a placa FPGA)



Analog Discovery



GPIO\_0 da placa DE0-CV

# Experiência 3

- Uso do Analog Discovery (configuração)

1. Software Waveforms
2. Ferramenta StaticIO
3. Configurar DIO0 e DIO1 como Button 0/1



# Experiência 3

- Uso do Analog Discovery (acionamento dos sinais)

1. Software Waveforms
2. Ferramenta StaticIO
3. Configurar DIO0 e DIO1 como Button 0/1
4. Nomear DIO0 e DIO1



# Experiência 3

- Plano de Teste (teste detalhado)

## Teste do circuito na bancada

- Análise *clock* a *clock*;
- Acionamento das entradas;
- Monitoramento das saídas.

| #    | Operação                                                      | Sinais de controle                             | Resultado esperado                                                                                                                                                                  |
|------|---------------------------------------------------------------|------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| c.i. | Condições iniciais                                            | clock=0<br>reset=0<br>iniciar=0<br>chaves=0000 | pronto=0<br>db_igual=0<br>db_contagem=0000<br>db_memoria=0001<br>db_chaves=0000<br>db_estado=0000                                                                                   |
| 1    | "Resetar" circuito e observar a saída da memória              | reset=1<br>clock ↑                             | pronto=0<br>db_igual=0<br>db_contagem=0000<br>db_memoria=0001<br>db_chaves=0000<br>db_estado=0000                                                                                   |
| 2    | Acionar sinal de clock 5 vezes com iniciar=0                  | reset=0<br>iniciar=0<br>clock ↑ (5x)           | (permanece no estado inicial)<br>pronto=0<br>db_igual=0<br>db_contagem=0000<br>db_memoria=0001<br>db_chaves=0000<br>db_estado=0000                                                  |
| 3    | Ajustar chaves para 0100, ativar iniciar=1 e acionar clock 1x | chaves=0100<br>iniciar=1<br>clock ↑            | (muda para estado preparação)<br><completar todas as saídas>                                                                                                                        |
| 4    | Mantém chaves em 0100 e acionar clock 1x                      | chaves=0100<br>iniciar=0<br>clock ↑            | (muda para estado regista)<br><completar todas as saídas>                                                                                                                           |
| 5    | Mantém chaves em 0100 e acionar clock 1x                      | chaves=0100<br>iniciar=0<br>clock ↑            | (muda para estado comparação)<br>db_igual=0<br>db_contagem=0000<br>db_memoria=0001<br>db_chaves=0100<br><completar todas as saídas>                                                 |
| 6    | Mantém chaves em 0100 e acionar clock 1x                      | chaves=0100<br>clock ↑                         | (muda para estado próximo)<br><completar todas as saídas>                                                                                                                           |
| 7    | Mantém chaves em 0100 e acionar clock 3x                      | chaves=0100<br>clock ↑ (3x)                    | (passa pelos estados regista, comparação e próximo)<br>pronto=0<br>db_igual=0<br>db_contagem=0001<br>db_memoria=0010<br>db_chaves=0100                                              |
| 8    | Mantém chaves em 0100 e acionar clock 3x                      | chaves=0100<br>clock ↑ (3x)                    | (passa pelos estados regista, comparação e próximo)<br>pronto=0<br>db_igual=1<br>db_contagem=0010<br>db_memoria=0100<br>db_chaves=0100                                              |
| 9    | Mantém chaves em 0100 e acionar clock 9x                      | chaves=0100<br>clock ↑ (9x)                    | (passa 3x pelos estados regista, comparação e próximo)<br>pronto=0<br>db_igual varia 0-1-0<br>db_contagem varia 0011-0100-0101<br>db_memoria varia 1000-0100-0010<br>db_chaves=0100 |
| 10   | Ajustar chaves para 0001 e acionar clock 6x                   | chaves=0001<br>clock ↑ (6x)                    | <completar todas as saídas>                                                                                                                                                         |
| 11   | Ajustar chaves para 0010 e acionar clock 6x                   | chaves=0010<br>clock ↑ (6x)                    | <completar todas as saídas>                                                                                                                                                         |
| 12   | Ajustar chaves para 0100 e acionar clock 6x                   | chaves=0100<br>clock ↑ (6x)                    | <completar todas as saídas>                                                                                                                                                         |
| 13   | Ajustar chaves para 1000 e acionar clock 6x                   | chaves=1000<br>clock ↑ (6x)                    | <completar todas as saídas>                                                                                                                                                         |
| 14   | Ajustar chaves para 0000 e acionar clock 3x                   | chaves=0001<br>clock ↑ (3x)                    | <completar todas as saídas>                                                                                                                                                         |
| 15   | Mantém chaves em 0000 e acionar clock 3x                      | chaves=0010<br>clock ↑ (3x)                    | (passa pelo estado fim)<br>pronto=1<br><completar todas as saídas>                                                                                                                  |
| 16   | Mantém chaves em 0000 e acionar clock                         | chaves=0000<br>clock ↑                         | (termina no estado inicial)<br><completar todas as saídas>                                                                                                                          |