### Laboratório de Sistemas Digitais

#### Trabalho Prático nº 7

# Construção e utilização de testbenches em VHDL Simulação comportamental e temporal Depuração de circuitos em FPGA

## **Objetivos**

- Construção e utilização de *testbenches* para simulação em VHDL de circuitos combinatórios e sequenciais.
- Simulação comportamental e temporal.
- Depuração de circuitos digitais implementados em FPGA com base em ferramentas de visualização de sinais capturados em tempo-real (analisadores lógicos).

#### Sumário

Este trabalho prático é dedicado à simulação comportamental, à simulação temporal e à depuração de um sistema em FPGA, como tarefas do fluxo de projeto usadas para validar o sistema em diferentes etapas de desenvolvimento. A simulação comportamental pode ser usada logo após a modelação do sistema, para avaliar o seu funcionamento, considerando componentes ideais, i.e. sem atrasos, e independentemente da compilação (implementação) para uma FPGA específica. Por outro lado, a simulação temporal pode ser realizada após a compilação (implementação) do sistema para uma FPGA em concreto e tem em conta as estimativas para os atrasos dos componentes do sistema, resultantes do seu posicionamento e interligação na FPGA, pelo que permite efetuar uma simulação muito mais próxima do funcionamento do sistema em hardware real. Por último a depuração é realizada com o sistema a funcionar em hardware, i.e. com a FPGA configurada com o sistema alvo, e com o objetivo de observar a operação e resposta do circuito a estímulos reais.

Este trabalho prático está dividido em cinco partes. A primeira e a segunda partes são dedicadas à simulação comportamental com base nos exemplos de *testbenches* apresentados nas aulas teórico-práticas (a primeira baseada num descodificador, como um exemplo de um componente combinatório e a segunda baseada num contador, como um exemplo de um circuito sequencial).

Na terceira parte é utilizada uma *testbench* para um componente combinatório (ALU) de forma a realizar primeiro a sua simulação comportamental e depois a temporal.

A quarta parte é dedicada à depuração, pretendendo-se introduzir o princípio de funcionamento e as capacidades dos analisadores lógicos integrados disponibilizados pelos fabricantes de FPGAs. Estes analisadores consistem num conjunto de blocos de hardware e ferramentas de software que permitem a captura de sinais em tempo-real e a sua visualização através de uma aplicação de software, possibilitando assim a depuração de sistemas implementados em FPGA. Esta apresentação é baseada num projeto de um contador binário que permitirá ilustrar todos os passos necessários para a utilização do analisador lógico.

Por último, na quinta parte pretende-se que sejam realizados os três tipos de tarefas de validação (simulação comportamental e temporal, assim como a depuração) ao longo do fluxo de projeto de um sistema baseado num temporizador, de forma dar uma perspetiva global das tarefas de verificação de um sistema digital ao longo do seu desenvolvimento.

Ano Letivo 2015/16 Página 1 de 18

#### Parte I

- **1.** Abra a aplicação "Altera Quartus Prime" e crie um novo projeto para a FPGA Altera Cyclone IV EP4CE115F29C7. Poderá designar o projeto e a entidade *top-level* como "Dec2 4En".
- 2. O código VHDL apresentado na Figura 1 implementa um descodificador binário de 2 →4 com entrada de habilitação (*enable*). Crie um novo ficheiro VHDL, introduza esse código e grave o ficheiro com o nome "Dec2 4En.vhd".
- **3.** Execute o comando "Analysis & Synthesis" da aplicação "Altera Quartus Prime" para realizar a análise e verificação sintática do projeto.
- **4.** O código VHDL apresentado na Figura 2 implementa uma *testbench* para o descodificador da Figura 1. Crie um novo ficheiro VHDL, introduza esse código e grave o ficheiro com o nome "Dec2\_4En\_Tb.vhd".
- 5. Verifique se a path "ModelSim-Altera" em "Tools → Options (EDA Tool Options)" está de acordo com a Figura 3 (localização no disco da ferramenta de simulação "ModelSim-Altera": "C:\altera lite\15.1\modelsim ase\win32aloem" em Windows).
- **6.** Execute a ferramenta de simulação "ModelSim ALTERA STARTER EDITION", através do menu "Tools  $\rightarrow$  Run Simulation Tool  $\rightarrow$  RTL Simulation".

```
library IEEE;
use IEEE.STD LOGIC 1164.all;
entity Dec2 4En is
   port(enable : in std logic;
        inputs : in std logic vector(1 downto 0);
        outputs : out std logic vector(3 downto 0));
end Dec2 4En;
architecture Behavioral of Dec2 4En is
begin
   process (enable, inputs)
  begin
      if (enable = '0') then
         outputs <= "0000";
      else
         if (inputs = "00") then
            outputs <= "0001";
         elsif (inputs = "01") then
            outputs <= "0010";
         elsif (inputs = "10") then
            outputs <= "0100";
            outputs <= "1000";
         end if;
      end if;
   end process;
end Behavioral;
```

Figura 1 – Código VHDL de um descodificador binário 2→4 com enable ("Dec2 4En").

Ano Letivo 2015/16 Página 2 de 18

**NOTA:** No contexto da simulação comportamental, o módulo "Dec2\_4En" (ou outro que se pretenda simular e seja a "Unit Under Test – UUT" numa testbench) deve ser o top-level e compilado previamente no "Altera Quartus Prime". Por outro lado, o módulo relativo à testbench só pode ser compilado na ferramenta de simulação "ModelSim ALTERA STARTER EDITION", atuando como top-level apenas no simulador.

```
library IEEE;
use IEEE.STD LOGIC 1164.all;
-- Entidade sem portos
entity Dec2 4En Tb is
end Dec2 4En Tb;
architecture Stimulus of Dec2 4En Tb is
   -- Sinais para ligar às entradas da UUT
   signal s enable : std_logic;
   signal s_inputs : std_logic vector(1 downto 0);
   -- Sinal para ligar às saídas da UUT
   signal s_outputs : std_logic_vector(3 downto 0);
begin
   -- Instanciação da Unit Under Test (UUT)
   uut: entity work.Dec2 4En(Behavioral)
        port map(enable => s_enable,
                 inputs => s inputs,
                 outputs => s outputs);
   --Process stim
   stim proc : process
   begin
      wait for 100 ns;
      s enable <= '0';
      wait for 100 ns;
      s enable <= '1';
      wait for 100 ns;
      s inputs <= "00";
      wait for 100 ns;
      s inputs <= "10";
      wait for 100 ns;
      s inputs <= "01";
      wait for 100 ns;
      s inputs <= "11";
      wait for 100 ns;
   end process;
end Stimulus;
```

Figura 2 – Código VHDL de uma *testbench* ("Dec2\_4En\_Tb") para o descodificador binário 2→4 com *enable* ("Dec2\_4En").

**7.** Quando executada, a ferramenta de simulação "ModelSim ALTERA STARTER EDITION" deve apresentar o aspeto ilustrado na Figura 4. Caso a janela "Wave" (destinada ao desenho das formas de onda) não apareça, poderá ativá-la através do menu "View → Wave".

Ano Letivo 2015/16 Página 3 de 18



Figura 3 – Path correto para a ferramenta de simulação (em Windows).



Figura 4 – Aspeto inicial da janela da ferramenta de simulação "ModelSim ALTERA STARTER EDITION".

- **8.** Compile a *testbench* através do menu "Compile → Compile", selecionando o ficheiro "Dec2\_4En\_Tb.vhd" e premindo "Compile" (Figura 5).
- **9.** Inicie a simulação através de um duplo clique na arquitetura "stimulus" da entidade "dec2\_4en\_tb" apresentada na biblioteca "work" (projeto atual) na janela "Library" da aplicação "ModelSim ALTERA STARTER EDITION" (Figura 6).



Figura 5 – Compilação da testbench "Dec2\_4En\_Tb.vhd".

Ano Letivo 2015/16 Página 4 de 18



Figura 6 – Simulação da entidade "Dec2 4En Tb.vhd".

**10.** Adicione à janela "Wave" (por drag-and-drop da janela "Objects") os sinais da testbench ligados aos portos da entidade a simular ("s\_enable", "s\_inputs" e "s\_outputs") conforme ilustrado na Figura 7.



Figura 7 – Sinais "s\_enable", "s\_inputs" e "s\_outputs" adicionados à janela "Wave".

**11.** Execute a simulação, especificando previamente o tempo pretendido (e.g. 1000 ns tal como ilustrado na Figura 8), prima "Run" e analise os resultados. A janela "Wave" deve ser atualizada à medida que a simulação progride.



Figura 8 – Resultados de simulação do descodificador binário de 2→4 "Dec2\_4En.vhd" com a *testbench* "Dec2\_4En Tb.vhd".

Ano Letivo 2015/16 Página 5 de 18

#### Parte II

Repita os passos da parte I deste guião para a simulação comportamental (com uma *testbench* em VHDL) do contador binário *up/down* de 4 bits apresentado nos slides da aula teórico-prática 6, como um exemplo de simulação de um componente sequencial.

### Parte III

A simulação <u>comportamental</u>, realizada nas partes I e II deste guião, não toma em consideração os atrasos dos elementos lógicos da FPGA bem como atrasos devidos a recursos de encaminhamento, supondo que todo o processamento é realizado em tempo zero. Dito de outra forma, a simulação comportamental realizada logo após a modelação do sistema em VHDL assume que os elementos lógicos e os recursos de interligação da FPGA são ideais, não apresentando atrasos.

Por outro lado, a simulação <u>temporal</u> permite não só testar a função dum circuito mas também observar o cumprimento dos requisitos temporais, desde que sejam usados vetores de simulação adequados (que "exercitem" o caminho crítico). Para tal utiliza o resultado da compilação dum circuito, que incorpora o mapeamento da *netlist* em primitivas da FPGA, o seu posicionamento em localizações específicas, bem como o encaminhamento e interconexões entre as primitivas, possibilitando a simulação com atrasos estimados, muito próximos dos reais. Este tipo de simulação permite modelar de forma mais precisa o comportamento do sistema em hardware real. Nesta parte pretende-se realizar a simulação temporal (com uma *testbench* em VHDL) de uma ALU de 16 bits, semelhante à implementada (com 4 bits) na parte II do trabalho prático 3.

- **1.** Na aplicação "Altera Quartus Prime" crie um novo projeto para a FPGA Altera Cyclone IV EP4CE115F29C7. Poderá designar o projeto e a entidade top-level como "ALU16".
- **2.** O código VHDL apresentado na Figura 9 implementa uma ALU de 16 bits. Crie um novo ficheiro VHDL, introduza esse código e grave o ficheiro com o nome "ALU16.vhd".
- **3.** Execute o comando "Analysis & Synthesis" da aplicação "Altera Quartus Prime" para realizar a análise e verificação sintática do projeto.
- **4.** O código VHDL apresentado na Figura 10 implementa uma *testbench* para a ALU da Figura 9. Crie um novo ficheiro VHDL, introduza esse código e grave o ficheiro com o nome "ALU16\_Tb.vhd".
- **5.** Realize a simulação comportamental da ALU com a *testbench* fornecida, executando a ferramenta "ModelSim ALTERA STARTER EDITION", através do menu "Tools → Run Simulation Tool → RTL Simulation", tal como na parte I deste guião. Apesar da *testbench* "ALU16 Tb.vhd" compilar com sucesso, a simulação não arranca devido a um erro. Sugestão: compile também o módulo "ALU16.vhd" na aplicação "ModelSim ALTERA STARTER EDITION" para ter mais informação sobre a causa do problema que não se manifestou anteriormente.
- **6.** Analise os resultados da simulação que deverão ser semelhantes aos apresentados na Figura 11. Observe que a ALU não apresenta nesta simulação comportamental atrasos de propagação entre a alteração dos operandos de entrada e o resultado de saída. Para visualizar os valores dos sinais em hexadecimal, escolha a opção "Radix → Hexadecimal" do menu acessível com o botão direito do rato quando clica sobre o(s) sinal(is) pretendidos na janela "Wave". No final feche a aplicação de simulação "ModelSim ALTERA STARTER EDITION".

Ano Letivo 2015/16 Página 6 de 18

```
library IEEE;
use IEEE.STD LOGIC 1164.all;
use IEEE.NUMERIC STD.all;
entity ALU16 is
   port(op : in std_logic_vector(2 downto 0);
        op0 : in std_logic_vector(15 downto 0);
        op1 : in std logic vector(15 downto 0);
        res : out std logic vector(15 downto 0);
        mHi : out std logic vector(15 downto 0));
end ALU16;
architecture Behavioral of ALU16 is
   signal s mRes : std logic vector(31 downto 0);
begin
  s mRes <= std logic vector(unsigned(op0) * unsigned(op1));</pre>
  process(op, op0, op1, s mRes)
  begin
    case op is
      when "000" =>
        res <= std logic vector(unsigned(op0) + unsigned(op1));</pre>
      when "001" =>
        res <= std logic vector(unsigned(op0) - unsigned(op1));</pre>
      when "010" =>
        res <= s mRes(15 downto 0);
      when "011" =>
        res <= std logic vector(unsigned(op0) / unsigned(op1));</pre>
      when "100" =>
        res <= std logic vector(unsigned(op0) rem unsigned(op1));</pre>
      when "101" =>
        res <= op0 and op1;
      when "110" =>
        res <= op0 or op1;
      when "111" =>
        res <= op0 xor op1;
      end case;
   end process;
   mHi \le s_mRes(31 downto 16) when (op = "010") else
          (others => '0');
end Behavioral;
```

Figura 9 – Código VHDL de uma ALU de 16 bits ("ALU16").

Ano Letivo 2015/16 Página 7 de 18

```
library IEEE;
use IEEE.STD LOGIC 1164.all;
entity ALU16 Tb is
end ALU16 Tb;
architecture Stimulus of ALU16 Tb is
  -- Sinais para ligar às entradas da UUT
   signal s op : std logic vector(2 downto 0);
   signal s_op0 : std_logic_vector(15 downto 0);
   signal s_op1 : std_logic_vector(15 downto 0);
  -- Sinais para ligar às saídas da UUT
   signal s res : std logic vector(15 downto 0);
   signal s mHi : std logic vector(15 downto 0);
begin
   uut: entity work.ALU16(Behavioral)
        port map(op => s_op,
                 op0 => s_op0,
                 op1 => s op1,
                 res => s res,
                 mHi => s mHi);
   --Process stim
   stim proc : process
   begin
      s op0 \le x"FEDC";
      s op1 \le x"0123";
      s op <= "000";
      wait for 100 ns;
      s op <= "001";
      wait for 100 ns;
      s op <= "010";
      wait for 100 ns;
      s op <= "011";
      wait for 100 ns;
      s op <= "100";
      wait for 100 ns;
      s op0 \le x"F30C";
      s op1 \le x"F50A";
      s op <= "101";
      wait for 100 ns;
      s op <= "110";
      wait for 100 ns;
      s op <= "111";
      wait for 100 ns;
      wait;
   end process;
end Stimulus;
```

Figura 10 – Código VHDL de uma testbench ("ALU16\_Tb") para a ALU de 16 bits ("ALU16").

Ano Letivo 2015/16 Página 8 de 18



Figura 11 – Resultados da simulação comportamental da ALU de 16 bits com a testbench "ALU16 Tb".

- **7.** Vamos agora efetuar a simulação <u>temporal</u> da ALU. Para esse efeito configure as ferramentas de simulação, realizando os seguintes passos:
- Especifique as opções de simulação através do menu "Assignments → Settings..." (que deverá abrir a janela da esquerda da Figura 12).
- Selecione a categoria "EDA Tool Settings (Simulation)".
- Nas opções "NativeLink Settings" ative "Compile test bench:" e clique no botão "Test Benches…" (Figura 12).
- Na janela seguinte clique no botão *"New..."* (Figura 12) e preencha todos os campos conforme ilustrado na Figura 13 (não se esquecendo de adicionar o ficheiro "ALU16\_Tb.vhd" à lista de *"Test bench and simulation files"*).

Após configuração, as três janelas da Figura 12 devem apresentar o aspeto das Figuras 13 a 15.



Figura 12 – Passos de configuração da testbench a usar na simulação temporal da ALU de 16 bits.

**8.** Execute a opção "Compile Design". Para além de serem gerados o ficheiro de configuração da FPGA e os relatórios adequados, serão também criados o ficheiro "ALU16.vho" que contém a netlist sintetizada e o ficheiro "ALU16\_vhd.sdo" com a informação temporal. Estes ficheiros encontram-se no subdiretório "simulation\modelsim" do projeto. Abra cada um destes ficheiros e observe, no ficheiro "ALU16.vho", que a arquitetura criada com o modelo da ALU pós-implementação possui o nome "structure".

Ano Letivo 2015/16 Página 9 de 18



Figura 13 – Aspeto da janela "New Test Bench Settings" após configuração das opções corretas.



Figura 14 – Aspeto da janela "Test Benches" após configuração das opções corretas.



Figura 15 – Aspeto da janela "Settings" após configuração das opções corretas.

**9.** Altere nome da arquitetura instanciada no módulo "ALU16\_Tb" da *testbench* para "structure" (na linha "uut: "entity work.ALU16(Behavioral structure)".

Ano Letivo 2015/16 Página 10 de 18

**10.** Execute a ferramenta de simulação "ModelSim ALTERA STARTER EDITION", através do menu "Tools  $\rightarrow$  Run Simulation Tool  $\rightarrow$  Gate Level Simulation…". Selecione o modelo temporal da simulação "Slow -7 1.2V 85 Model" e clique em "Run" (Figura 16).



Figura 16 – Especificação do modelo temporal da simulação (*speed grade* da FPGA, tensão de alimentação e temperatura do dispositivo).

**11.** A simulação arrancará automaticamente, através de uma *script* gerada pelo "Altera Quartus Prime" e de acordo com a configuração realizada no ponto 7. Analise os resultados da simulação (que deverão ser semelhantes aos apresentados na Figura 17) e observe os atrasos de propagação entre a modificação dos operandos de entrada e a atualização do resultado à saída da ALU. Faça "Zoom In" das forma de onda na janela "Wave" de forma a observar as múltiplas transições espúrias (glitches) que ocorrem sempre que o resultado da ALU é atualizado. A que se devem estes glitches?



Figura 17 – Resultados da simulação temporal da ALU de 16 bits com a testbench "ALU16 Tb".

### Parte IV

- 1. Crie um novo projeto para a FPGA Altera Cyclone IV EP4CE115F29C7. Poderá designar o projeto e a entidade *top-level* como "DebugDemo". O projeto consistirá num contador binário crescente, apresentado na Figura 18 e descrito no ficheiro "CntUp.vhd". O módulo *top-level* "DebugDemo.vhd" interliga os portos do contador a dispositivos do kit DE2-115 (Figura 19). Edite os ficheiros com o código fonte fornecido, grave-os com os nomes indicados, importe o ficheiro "DE2\_115.qsf", compile o projeto, programe a FPGA e responda às questões dos pontos seguintes.
- a. Qual a frequência de incremento (atualização) do contador?
- b. Que bits de saída do contador não estão ligados aos LEDs?
- c. Qual a frequência do bit de saída menos significativo do contador?
- d. Qual a frequência do bit de saída mais significativo do contador?
- e. Qual a frequência do bit de saída menos significativo do contador visível nos LEDs?
- f. Quanto tempo demora um ciclo completo de contagem (entre 2 passagens por zero)?

Ano Letivo 2015/16 Página 11 de 18



Figura 18 - Código fonte do módulo "CntUp.vhd".



Figura 19 - Código fonte do módulo "DebugDemo.vhd".

2. Devido à elevada frequência de comutação, a maioria dos bits do contador não podem ser devidamente observados a olho nu em dispositivos simples como os LEDs. Para resolver este problema e avaliar o funcionamento correto de todos os bits do contador vamos recorrer a uma ferramenta, designada *Analisador Lógico Integrado*, tipicamente disponibilizada pelos fabricantes das FPGA. Estas ferramentas permitem especificar os sinais do sistema que pretendemos visualizar, adicionar de forma transparente e automática a lógica necessária para a sua captura, armazenamento e transferência para um computador de desenvolvimento onde será realizada a sua visualização. A lógica adicionada para este efeito utiliza os próprios recursos lógicos programáveis da FPGA. A interface para transferir os sinais capturados é também a usada na programação da FPGA (denominada JTAG e acessível através do porto "USB Blaster") o que é bastante conveniente. Para usar esta facilidade, o primeiro passo é a criação de um ficheiro no "Altera Quartus Prime" do tipo "SignalTap II Logic Analyser File" (Figura 20).

Ano Letivo 2015/16 Página 12 de 18

3. Após a criação do ficheiro do tipo SignalTap II Logic Analyser File é apresentada a aplicação da Figura 21, onde devem ser especificados os sinais que se pretende capturar e visualizar, o sinal de clock usado para estabelecer a frequência de amostragem dos sinais, o número de amostras capturadas e as condições que disparam a amostragem. A configuração destes parâmetros vai ser descrita nos próximos pontos.



Figura 20 – Criação de um ficheiro do tipo "SignalTap II Logic Analyser File".

**4.** O primeiro passo é a adição dos nodos (sinais e portos) do sistema que se pretende capturar. Para tal, deve ser selecionada a opção "Add Nodes..." do menu acessível com o botão direito do rato na área "Setup" mostrada na Figura 21. Os portos a selecionar para captura e visualização no analisador lógico são os apresentados na Figura 22.



Figura 21 – Aspeto inicial da aplicação "SignalTap II Logic Analyser".

Ano Letivo 2015/16 Página 13 de 18

- **5.** Após premir *Insert* e fechar a janela de "*Node Finder*" deverá configurar na janela principal os seguintes parâmetros (Figura 23):
- Hardware: USB-Blaster (dispositivo/interface usado para programação e depuração)
- Clock: CLOCK\_50 (sinal de relógio usado para estabelecer os instantes de amostragem / frequência de amostragem – 50 MHz)
- Sample Depth: 4K (número de amostras consecutivas a capturar)



Figura 22 – Portos do contador selecionados ("reset", "enable" e "cntVal").

- *Trigger Conditions* (condições que levam ao disparo da captura de amostras; neste caso reset = 0 e enable = 1 para capturar o instante em que é libertado o reset)
- CntUp:cnt\_up|reset: 0CntUp:cnt\_up|enable: 1
- 6. Seguidamente, grave o ficheiro com o nome "DebugDemo.stp".



Figura 23 – Aspeto da aplicação "SignalTap II Logic Analyser" com os parâmetros configurados.

Ano Letivo 2015/16 Página 14 de 18

- 7. Uma vez que as componentes de hardware do analisador lógico usam recursos lógicos programáveis da FPGA, antes de efetuar a captura e visualização dos sinais, é necessário voltar a compilar o projeto no "Altera Quartus Prime". O projeto consiste nos ficheiros "DebugDemo.vhd", "CntUp.vhd" e "DebugDemo.stp". O ficheiro top-level deve continuar a ser o "DebugDemo.vhd". Após compilação, execute a aplicação "SignalTap II Logic Analyser" (menu "Tools → SignalTap II Logic Analyser").
- **8.** Especifique o ficheiro SOF a usar para configurar a FPGA ("output\_files/DebudDemo.sof") e programe a FPGA (canto superior direito da Figura 23). O ficheiro SOF inclui quer a configuração da lógica do sistema desenvolvido, quer a configuração da lógica correspondente às componentes de hardware do analisador lógico.
- 9. Após a programação da FPGA (Figura 24) mude a janela principal da aplicação "SignalTap II Analyser" de "Setup" para "Data" (Figura 25). Neste ponto está tudo configurado e preparado para ser iniciada a captura de amostras dos sinais pretendidos. Para tal, basta selecionar o comando "Processing → Run Analysis" e de seguida desativar a entrada de "reset" e ativar a entrada de "enable" do contador de forma a que seja satisfeita a condição de trigger e iniciada a captura dos sinais pretendidos. Uma vez recolhidas 4K amostras de cada sinal, os respetivos valores são transferidos para o computador e visualizados na aplicação "SignalTap II Analyser" (Figura 26).



Figura 24 – Aspeto da aplicação "SignalTap II Logic Analyser" após programação da FPGA.

Ano Letivo 2015/16 Página 15 de 18

**10.** Podem ser visualizados instantes particulares da contagem se forem definidas condições de *trigger* mais restritas. A título de exemplo, pode ser visualizado o instante de *wrap-around* do contador através da atribuição do valor "11...100" a **cntVal**, o que leva a que a captura seja disparada três ciclos de relógio antes do contador voltar à contagem "00...00" (Figura 27). Volte a executar o comando "*Processing* → *Run Analysis*" para efetuar a captura (Figura 28).



Figura 25 – Janela "Data" da aplicação "SignalTap II Logic Analyser" antes da captura (aguardar verificação da condição de disparo da captura).



Figura 26 – Janela "Data" da aplicação "SignalTap II Logic Analyser" depois da captura.

Ano Letivo 2015/16 Página 16 de 18



Figura 27 – Configuração do instante de disparo da captura (trigger) com base no valor dos sinais "reset", "enable" e "cntVal".



Figura 28 – Janela "Data" da aplicação "SignalTap II Logic Analyser" depois de uma nova aquisição, onde foi capturado o wrap-around do contador.

Ano Letivo 2015/16 Página 17 de 18

### Parte V

- **1.** Abra a aplicação *"Altera Quartus Prime"* e crie um novo projeto para a FPGA Altera Cyclone IV EP4CE115F29C7. Designe o projeto e a entidade *top-level* como "TimerTest".
- **2.** Construa um módulo relativo a um temporizador (parametrizável) de atraso à desoperação. Na sua instanciação utilize um sinal de relógio de 50 MHz e configure-o de modo a que, cada vez que for disparado, forneça um impulso na saída com a duração de 200 ns.
- **3.** Realize todos os passos necessários para efetuar:
- A simulação comportamental do sistema com uma testbench adequada.
- A simulação temporal do sistema, após a sua compilação, com a mesma testbench do ponto anterior.
- A captura dos sinais em tempo-real, o teste e depuração do circuito implementado em FPGΔ

PDF criado em 07/04/2016 às 11:06:28

Ano Letivo 2015/16 Página 18 de 18