

# Dispositivos Lógicos Progamáveis II

Implementação de PLL para Relógio Digital (Milisegundos)

Arthur Cadore Matuella Barcella e Gabriel Luiz Espindola Pedro

23 de Abril de 2024

Engenharia de Telecomunicações - IFSC-SJ

## Sumário

| 1. Introdução                                        | . 3 |
|------------------------------------------------------|-----|
| 2. Implementação                                     | . 3 |
| 3. Implementação com somador binário e conversor BCD |     |
| 1. Conclusão                                         | . 4 |
| 5. Códigos VHDL utilizados                           |     |
| 5.1. bin2bcd                                         |     |

#### 1. Introdução

Neste relatório, será apresentado o desenvolvimento de um relógio digital com precisão de milisegundos, utilizando um PLL (Phase-Locked Loop) para a geração de um sinal de clock de 5 kHz. O projeto foi desenvolvido utilizando a ferramenta Quartus Prime Lite Edition 20.1.0.720 e a placa de desenvolvimento DE2-115.

#### 2. Implementação

A primeira etapa da implementação é a geração de um sinal de clock de 5 kHz. Para isso, foi utilizado um PLL com um clock de entrada de 50 MHz (valor de clock padrão para o chip implantado nesta placa).

Para isso, geramos o PLL através da ferramenta PLL Intel FPGA IP. Após a configuração do PLL, o sinal de clock de 5 kHz foi obtido na saída deste componente, sendo na sua configuração um **divisor de frequência de 10.000.** 

Abaixo está uma sessão do código VHD gerado pelo Quartus para a configuração do PLL.

```
1 GENERIC MAP (
     bandwidth type => "AUTO",
     clk0_divide_by => 25000,
4
    clk0_duty_cycle => 50,
    clk0 multiply by => 1,
     clk0 phase shift => "0",
7
     compensate_clock => "CLKO",
     inclk0 input frequency => 20000,
     intended_device_family => "Cyclone IV E",
     lpm_hint => "CBX_MODULE_PREFIX=pll",
     lpm type => "altpll",
11
     operation_mode => "NORMAL",
12
     pll type => "AUTO",
```

Figure 1: Elaborada pelo Autor

#### Top View - Wire Bond Cyclone IV E - EP4CE115F29C7



Sinal de entrada no domínio do tempo

#### 3. Implementação com somador binário e conversor BCD

#### 4. Conclusão

A partir da implementação do PLL vista anteriormente, juntamente com a implementação de divisão de clock sem o uso do PLL, podemos concluir que a utilização de um PLL é muito útil para a geração de sinais de clock com frequências específicas de maneira confiável.

Isso pois o PLL é capaz de gerar sinais de clock com frequências específicas, além de possuir uma maior precisão e estabilidade em relação a outros métodos de geração de clock.

Abaixo estão as principais diferenças de tempo de propagação e quantidade de registradores utilizados entre a implementação com e sem o uso do PLL:

Table 1: Elaborada pelo Autor

| Implementacao | Área (LE) | Registradores |
|---------------|-----------|---------------|
| Parte 1       | 239       | 124           |
| Parte 2       | 83        | 13.699        |

Sinal de entrada no domínio do tempo

### 5. Códigos VHDL utilizados

#### 5.1. bin2bcd

```
library ieee;
  use ieee.std logic 1164.all;
  use ieee.numeric_std.all;
5 entity bin2bcd is
       port (
                  : in std_logic_vector (7 downto 0);
8
           sd, su, sc : out std_logic_vector (3 downto 0)
9
       );
10 end entity;
  architecture ifsc_v1 of bin2bcd is
12
13
       signal A uns : unsigned (7 downto 0);
14
       signal sd_uns, su_uns, sc_uns : unsigned (7 downto 0);
16
  begin
17
      A uns <= unsigned(A);
      sc uns \leq A uns/100;
18
       sd_uns <= A_uns/10;
       su uns <= A uns rem 10;
              <= std_logic_vector(resize(sc_uns, 4));
22
              <= std_logic_vector(resize(sd_uns, 4));
       sd
              <= std_logic_vector(resize(su_uns, 4));
       su
24 end architecture;
```

O código bin Adder é reponsavel por somar dois números binários de 7 (128 represetações possiveis, e portanto atendendo a especificação) bits e retornar o resultado em binário com 8 bits.