



# Circuitos Digitais II - 6882

### Paulo Roberto de Oliveira

# Universidade Estadual de Maringá Departamento de Informática

Bacharelado em Ciência da Computação

### VHDL - Pacotes

#### Pacotes ou *packages*

- · Esta unidade permite a declaração de um conjunto de definições que podem ser partilhadas por vários projetos VHDL.
- · A unidade package é composta por uma parte declaratória mandatária (package declaration) e por um corpo opcional (package body).

PACKAGE nome\_package IS

-- Parte declaratória

END nome\_package;

PACKAGE BODY OF nome\_package IS

-- Corpo do package

END nome\_package;

**PACKAGE** 

**Declarações** 

Corpo do Package

Estrutura de um *Package* 



### VHDL - Pacotes

#### Pacotes ou *packages*

- · A parte declaratória do package pode conter:
  - Declaração de objetos (sinais e constantes);
  - Declaração de componentes;
  - Declaração de tipos e subtipos de dados;
  - Declaração de subprogramas (funções e procedimentos).
- No corpo do package são definidos os subprogramas declarados na parte declaratória do package.



# Aula de Hoje

Projeto e Simulação dos seguintes circuitos usando pacotes:

- 1. Decodificador 2x4
- 2. Somador Completo de 1 bit
- 3. Subtrator Completo de 1 bit



# Decodificador

#### Decodificador 2x4





## TV do Decodificador

**Entradas** 

Saídas

| ·                     |                       |    |       |                |                |
|-----------------------|-----------------------|----|-------|----------------|----------------|
| <b>S</b> <sub>1</sub> | <b>S</b> <sub>0</sub> | Do | $D_1$ | D <sub>2</sub> | D <sub>3</sub> |
| 0                     | 0                     | 1  | 0     | 0              | 0              |
| 0                     | 1                     | 0  | 1     | 0              | 0              |
| 1                     | 0                     | 0  | 0     | 1              | 0              |
| 1                     | 1                     | 0  | 0     | 0              | 1              |

$$D1 = \overline{5}1.50$$

$$D2 = 51.50$$

$$D3 = 51.50$$



### Circuito do Decodificador





## TV do Somador

| Entradas |   |                 | Saídas |      |
|----------|---|-----------------|--------|------|
|          |   |                 |        |      |
| A        | В | C <sub>in</sub> | 5      | Cout |
| 0        | 0 | 0               | 0      | 0    |
| 0        | 0 | 1               | 1      | 0    |
| 0        | 1 | 0               | 1      | 0    |
| 0        | 1 | 1               | 0      | 1    |
| 1        | 0 | 0               | 1      | 0    |
| 1        | 0 | 1               | 0      | 1    |
| 1        | 1 | 0               | 0      | 1    |
| 1        | 1 | 1               | 1      | 1    |







## Circuito do Somador

# Circuito Somador $S = A \oplus B \oplus C_{in}$ $C_{\text{out}} = AB + BC_{\text{in}} + AC_{\text{in}}$ A o $A \oplus B \oplus C_{in}$ B + Cin C<sub>in</sub> O BC<sub>in</sub> Somador $AB+BC_{in}+AC_{in}$ AB

# TV do Subtrator

| Entradas |   |                 | Saídas |      |
|----------|---|-----------------|--------|------|
|          |   |                 |        |      |
| A        | В | C <sub>in</sub> | 5      | Cout |
| 0        | 0 | 0               | 0      | 0    |
| 0        | 0 | 1               | 1      | 1    |
| 0        | 1 | 0               | 1      | 1    |
| 0        | 1 | 1               | 0      | 1    |
| 1        | 0 | 0               | 1      | 0    |
| 1        | 0 | 1               | 0      | 0    |
| 1        | 1 | 0               | 0      | 0    |
| 1        | 1 | 1               | 1      | 1    |







### Circuito do Subtrator

#### Circuito Subtrator

 $S = A \oplus B \oplus C_{in}$   $C_{out} = \overline{A}B + BC_{in} + \overline{A}C_{in}$ 



#### Criar as seguintes pastas dentro do diretório "work":

- 1. not\_1
- 2. and 2
- 3. or\_3
- 4. xor\_2
- 5. deco2to4
- 6. somador
- 7. subtrator



Criar os componentes para as portas lógicas NOT, AND de 2 entradas, XOR de 2 entradas, OR de 3 entradas e salvar o código VHDL nas respectivas pastas:

- 1. NOT\_1
- 2. AND 2
- 3. OR 3
- 4. XOR\_2

#### **OBS 1:**

 Salvar apenas os códigos em VHDL (extensão .VHD) com os mesmos nomes das respectivas pastas (não precisa criar o projeto).



#### Código para a porta lógica NOT (Criação do Componente):

```
LIBRARY ieee:
USE ieee.std_logic_1164.all;
ENTITY not 1 IS
    PORT (x: IN bit;
           z: OUT bit);
END not_1;
ARCHITECTURE logical OF not_1 IS
BEGIN
        z < = not x:
END logica1;
```



Código para a porta lógica AND (Criação do Componente):

```
LIBRARY ieee:
USE ieee.std_logic_1164.all;
ENTITY and 2 IS
     PORT (x, y: IN bit;
              z: OUT bit);
END and 2;
ARCHITECTURE logica2 OF and_2 IS
BEGIN
        z <= x and y;
END logica2;
```



#### Código para a porta lógica OR (Criação do Componente):

```
LIBRARY ieee:
USE ieee.std_logic_1164.all;
ENTITY or_3 IS
     PORT (x, y, w: IN bit;
                 z: OUT bit);
END or 3;
ARCHITECTURE logica4 OF or_3 IS
BEGIN
        z <= x or y or w;
END logica4;
```



#### Código para a porta lógica XOR (Criação do Componente):

```
LIBRARY ieee:
USE ieee.std_logic_1164.all;
ENTITY xor 2 IS
     PORT (x, y: IN bit;
              z: OUT bit);
END xor_2;
ARCHITECTURE logica3 OF xor_2 IS
BEGIN
        z <= x xor y;
END logica3;
```



#### Criar os pacotes para os seguintes circuitos:

- 1. Decodificador 2x4
- 2. Somador de 1 bit
- 3. Subtrator de 1 bit

#### OBS 2:

- Salvar os códigos dos pacotes no diretório "work".
- Os nomes dos pacotes são:
  - o deco2to4\_package.vhd
  - somador\_package.vhd
  - o subtrator\_package.vhd



Código para o pacote deco2to4\_package (Criação do Pacote):

```
LIBRARY ieee:
USE ieee.std_logic_1164.all;
PACKAGE deco2to4_package IS
COMPONENT not 1
   PORT (x: IN bit;
          z: OUT bit);
END COMPONENT:
COMPONENT and 2
    PORT (x, y: IN bit;
             z: OUT bit);
END COMPONENT:
END deco2to4_package;
```



#### Código para o pacote somador\_package (Criação do Pacote):

```
LIBRARY ieee:
USE ieee.std_logic_1164.all;
PACKAGE somador_package IS
COMPONENT xor 2
   PORT (x, y: IN bit;
            z: OUT bit);
END COMPONENT:
COMPONENT and 2
    PORT (x, y: IN bit;
             z: OUT bit);
END COMPONENT;
```

```
COMPONENT or_3

PORT (x, y, w: IN bit;

z: OUT bit);

END COMPONENT;

END somador_package;
```



#### Código para o pacote subtrator\_package (Criação do Pacote):

```
LIBRARY ieee:
USE ieee.std_logic_1164.all;
PACKAGE subtrator_package IS
COMPONENT not 1
   PORT (x: IN bit;
          z: OUT bit);
END COMPONENT:
COMPONENT xor 2
   PORT (x, y: IN bit;
            z: OUT bit);
END COMPONENT;
```

```
COMPONENT and_2

PORT (x, y: IN bit;

z: OUT bit);

END COMPONENT;

COMPONENT or_3

PORT (x, y, w: IN bit;

z: OUT bit);

END COMPONENT;

END COMPONENT;

END Subtrator_package;
```



#### Criar os projetos para os seguintes circuitos:

- 1. Decodificador 2x4
- 2. Somador de 1 bit
- 3. Subtrator de 1 bit

#### OBS 3:

- Na janela de adição de arquivos, adicione os seguintes arquivos ao projeto:
  - o Para o decoficador:
    - o and 2.vhd, not 1.vhd, deco2to4 package.vhd
  - o Para o somador:
    - o and 2.vhd, xor 2.vhd, or 3.vhd, somador package.vhd
  - o Para o subtrator:
    - o and \_2.vhd, not \_1.vhd, xor \_2.vhd, or \_3.vhd, subtrator \_package.vhd



#### Criar os projetos para os seguintes circuitos:

- 1. Decodificador 2x4
- 2. Somador de 1 bit
- 3. Subtrator de 1 bit

#### **OBS 4:**

- Criar e salvar os códigos em VHDL dos projetos, isto
   é, deco2to4.vhd, somador.vhd, subtrator.vhd.
- Compilar e simular cada projeto.
- END TIME: para decodificador 2X4 40 ns, somador de 1 bit 80 ns e subtrator de 1 bit 80 ns.
- Para verificar que os arquivos foram devidamente adicionados acesse o menu ASSIGNMENTS => SETTINGS => FILES



### Circuito do Decodificador





#### Código para o projeto decodificador 2X4 (Criação do Projeto):

```
LIBRARY ieee:
USE ieee.std_logic_1164.all;
--LIBRARY work:
USE work.deco2to4_package.all;
ENTITY deco2to4 IS
        PORT (s1, s0: IN BIT;
         d3,d2,d1,d0: OUT BIT);
END deco2to4;
```

```
ARCHITECTURE teste OF deco2to4 IS
SIGNAL +0,+1: BIT;
BEGIN
P1: not 1 PORT MAP (s0, t0);
P2: not 1 PORT MAP (s1, t1);
P3: and_2 PORT MAP (t0, t1, d0);
P4: and_2 PORT MAP (s0, t1, d1);
P5: and_2 PORT MAP (t0, s1, d2);
P6: and_2 PORT MAP (s0, s1, d3);
END teste:
```



### Circuito do Somador

#### Circuito Somador

$$S = A \oplus B \oplus C_{in}$$

$$C_{out} = AB + BC_{in} + AC_{in}$$

$$A = AB + BC_{in} + AC_{in}$$



26

#### Código para o projeto somador de 1 bit (Criação do Projeto):

```
LIBRARY ieee:
USE ieee.std_logic_1164.all;
-- LIBRARY work:
USE work.somador_package.all;
ENTITY somador IS
   PORT (A, B, Cin: IN BIT;
           S, Cout: OUT BIT);
END somador:
```

```
ARCHITECTURE teste OF somador IS
SIGNAL +0, +1, +2, +3: BIT;
BEGIN
P1: xor_2 PORT MAP (B, Cin, t0);
P2: and_2 PORT MAP (B, Cin, t1);
P3: and_2 PORT MAP (A, B, t2);
P4: and_2 PORT MAP (A, Cin, t3);
P5: xor 2 PORT MAP (A, t0, S);
P6: or_3 PORT MAP (t1, t2, t3, Cout);
END teste:
```



### Circuito do Subtrator

#### <u>Circuito Subtrator</u>

 $S = A \oplus B \oplus C_{in}$   $C_{out} = \overline{AB} + BC_{in} + \overline{AC}_{in}$ 



#### Código para o projeto subtrator de 1 bit (Criação do Projeto):

```
LIBRARY ieee:
USE ieee.std_logic_1164.all;
-- LIBRARY work:
USE work.subtrator_package.all;
ENTITY subtrator IS
     PORT (A, B, Cin: IN BIT;
             S, Cout: OUT BIT);
END subtrator:
```

```
ARCHITECTURE teste OF subtrator IS
SIGNAL +0, +1, +2, +3, +4: BIT;
BEGIN
PO: not_1 PORT MAP (A, t0);
P1: xor_2 PORT MAP (B, Cin, t1);
P2: and_2 PORT MAP (B, Cin, t2);
P3: and_2 PORT MAP (t0, B, t3);
P4: and_2 PORT MAP (t0, Cin, t4);
P5: xor_2 PORT MAP (A, t1, S);
P6: or_3 PORT MAP (t2, t3, t4, Cout);
END teste:
```

