**Disciplina**: Prática de Eletrônica Digital 1 – Período 1/2022

Professor: Gilmar Beserra



# Trabalho Prático 2 – Familiarização com VHDL Terça-feira, 03 de Agosto de 2022

# **Objetivos:**

Familiarização com a implementação de circuitos combinacionais em VHDL e seu teste em FPGA. Acesso ao LabRemoto.

### **Projetos:**

Crie os projetos abaixo no Vivado, seguindo o fluxo de projeto visto em aula, e teste no LabRemoto. Use os slides das aulas e os materiais de referência para fazer a codificação em VHDL.

# 1) Circuito do projeto do estacionamento

$$c0 = \overline{s0} \cdot \overline{s1} \cdot s2 + \overline{s0} \cdot \underline{s1} \cdot \overline{s2} + s0 \cdot \overline{s1} \cdot \overline{s2} + s0 \cdot \underline{s1} \cdot \underline{s2}$$
  
$$c1 = \overline{s0} \cdot \underline{s1} \cdot \underline{s2} + \underline{s0} \cdot \underline{s1} \cdot \underline{s2} + \underline{s0} \cdot \underline{s1} \cdot \underline{s2} + \underline{s0} \cdot \underline{s1} \cdot \underline{s2}$$

| Inputs |            |    | Outputs   |    |
|--------|------------|----|-----------|----|
| s0     | s <b>1</b> | s2 | <b>c1</b> | c0 |
| 0      | 0          | 0  | 0         | 0  |
| 0      | 0          | 1  | 0         | 1  |
| 0      | 1          | 0  | 0         | 1  |
| 0      | 1          | 1  | 1         | 0  |
| 1      | 0          | 0  | 0         | 1  |
| 1      | 0          | 1  | 1         | 0  |
| 1      | 1          | 0  | 1         | 0  |
| 1      | 1          | 1  | 1         | 1  |

# 2) Decodificador do display de 7 segmentos (exercício 4)

**Professor**: Gilmar Beserra



```
library ieee; use ieee.std_logic_1164.all;
entity seven_seg_decoder is
  port ( bcd : in std_logic_vector(3 downto 0);
          blank : in std_logic;
          seg : out std_logic_vector(7 downto 1) );
end entity seven_seg_decoder;
architecture behavior of seven_seg_decoder is
  signal seg_tmp : std_logic_vector(7 downto 1);
begin
  with bcd select
     seg_tmp <= "0111111" when "0000",
                                              -- 0
                 "0000110" when "0001",
                 "1011011" when "0010",
                 "1001111" when "0011",
                                              -- 3
                 "1100110" when "0100",
                 "1101101" when "0101"
                 "1101101" when "0101", "1111101" when "0110", "0000111" when "0111",
                                              -- 6
                                             -- 7
                 "1111111" when "1000",
                "1101111" when "1001", -- 9
"1000000" when others; -- "-" for invalid code
  seg <= "0000000" when blank = '1' else
         seg_tmp;
end architecture behavior;
```

### 3) Somador 1 bit

#### Curso de Graduação em Engenharia Eletrônica

**Disciplina**: Prática de Eletrônica Digital 1 – Período 1/2022

Professor: Gilmar Beserra



### 4) Somador 3 bits

#### Vistos:

- 1) Mostrar testbenches e simulações de cada um dos projetos (1 ponto para cada).
- 2) Mostrar o funcionamento de cada um dos projetos na placa (1,5 ponto para cada).

#### Bom trabalho!