Escolar Documentos
Profissional Documentos
Cultura Documentos
Apostila VHDL PDF
Apostila VHDL PDF
Objetivo
Esta apostila tem como objetivo introduzir conceitos bsicos de VHDL, para alunos de Engenharia
Eletrnica ou de Computao, envolvidos em atividades de projeto de hardware digital de alguma
complexidade, que exija boa documentao e que busque independncia de tecnologia de implementao.
Para um aprendizado mais aprofundado do assunto, indicam-se as referncias [1], [2] e [3], alm das
normas IEEE-STD-1076/1987 e IEEE-STD-1164/1993, que estabelecem os padres internacionais para a
linguagem. Outras referncias citadas ao longo do texto permitem um aprofundamento em temas e estruturas
especficas.
Definies e Abreviaturas
VHDL (VHSIC Hardware Description Language). A sigla derivada de outra abreviatura - VHSIC (Very
High Speed Integrated Circuits), j que seu objetivo inicial era voltado ao projeto de circuitos integrados de
altssima velocidade.
VHSIC (Very High Speed Integrated Circuits) Circuito integrado de altssima velocidade.
1/
151
VHDL
Histrico
Nas dcadas de 70 e 80 foi posto em prtica um programa do Departamento de Defesa (DoD) americano,
para desenvolvimento de circuitos integrados de alta velocidade, denominado VHSIC e originado da
preocupao de domnio das tecnologias envolvidas. Desde o princpio, anteviu-se o problema de
representao dos projetos segundo uma linguagem que fosse comum s vrias empresas envolvidas e que
permitisse uma documentao fechada e clara para projetos de complexidade crescente. Nesta mesma
poca, j havia no mercado de computao a chamada crise do software, caracterizada pela dificuldade de
gesto, documentao e sistematizao do ciclo de vida do software (que envolve, em termos gerais, todas
as atividades de relativas sua criao e uso)1. O problema surgiu inicialmente no software porque era no
software que se desenvolviam as aplicaes, que tornavam o produto particular para um uso especfico. Isso
fazia com que um grande volume de projetos fossem conduzidos, quase sempre com muita complexidade e
pouco mtodo. No hardware a questo era mais bem controlada, pois os projetos eram, em geral, mais
genricos, especialmente para o hardware digital. Os projetos de microprocessadores, que eram os mais
complexos, visavam na maior parte dos casos o uso geral. Um mesmo microprocessador seria utilizado em
vrias aplicaes, seria reproduzido e testado aos milhes. Isso significava que o investimento em um nico
projeto poderia ser muito maior, inclusive em termos de especificao e testes. A evoluo da metodologia
de projeto de software foi ento natural, em funo dos argumentos sustentados pela crise. Hoje ainda
grande o desenvolvimento de novos mtodos e a busca por uma linguagem descritiva universal, como o
UML, para especificao e projeto de software orientado a objetos.
A questo preocupante quanto ao hardware, para o programa VHSIC americano, era que alguns fatos
indicavam para uma evoluo do mercado que faria surgirem problemas semelhantes aos apresentados pela
crise de software. Entre estes fatos:
1
Os captulos iniciais de Pressman tratam com clareza das causas e decorrncias da crise de software.
2/
151
VHDL
a) A fabricao de circuitos integrados deixava de ser exclusiva de alguns poucos fabricantes. Surgiam
empresas especializadas na fabricao de projetos de terceiros, o que permitiria, em conjunto com o
desenvolvimento de tecnologias de fabricao menos custosas, a criao de CIs de uso especfico para
certas aplicaes.
b) As novas tecnologias de fabricao (abaixo de 2m, na poca) permitiam um aumento de densidade dos
CIs, com conseqente aumento de complexidade.
c) Surgiam componentes de lgica programvel (PLDs e PALs), inicialmente de pequena densidade, mas
que poderiam evoluir para densidades muito maiores rapidamente. Tais componentes poderiam criar, como
de fato ocorreu posteriormente, um grande mercado de projetos de pequena escala e aplicaes especficas,
muito parecido com o mercado de projetos de software.
A criao de uma linguagem de descrio de hardware patrocinada pelo programa e, em paralelo algumas
outras linguagens criadas pela indstria, foi ento uma decorrncia natural. Em 1987, o VHDL foi
normalizado pelo IEEE, tornando-se um padro mundial, ao lado do Verilog, uma alternativa tambm
expressiva no mercado de projetos de hardware. Hoje, praticamente todas as ferramentas de
desenvolvimento de hardware computadorizadas aceitam essas linguagens como entrada, de forma que um
projeto baseado em VHDL ou Verilog pode ser implementado com qualquer tecnologia.
Vantagens do Uso
A alternativa para uso de uma linguagem formal de descrio de hardware como o VHDL a descrio por
diagramas esquemticos. O VHDL apresenta as seguintes vantagens:
b) O objetivo do projeto fica mais claro que na representao por esquemticos, nos quais a implementao
se sobrepe inteno do projeto;
3/
151
VHDL
c) O volume de documentao diminui, j que um cdigo bem comentado em VHDL substitui com
vantagens o esquemtico e a descrio funcional do sistema;
d) O projeto ganha portabilidade, j que pode ser compilado em qualquer ferramenta e para qualquer
tecnologia. comum, na indstria, o uso de FPGAs e CPLDs para produes iniciais ou de menores
escalas em projetos que posteriormente possam ser implementados em ASICs. Todas as implementaes
podem usar o mesmo cdigo VHDL.
Ciclo de Projeto
O projeto de um sistema digital auxiliado por ferramentas computadorizadas segue normalmente as etapas
descritas a seguir.
1- Especificao
Esta etapa visa determinar os requisitos e funcionalidade de projeto, incluindo timing dos sinais e definido
completamente as interfaces. uma etapa comum e necessria a qualquer projeto, independentemente do
uso do VHDL.
2- Codificao
Nesta etapa, o objetivo descrever, de forma estruturada e bem documentada, em VHDL, todo o
projeto, segundo seus padres de sintaxe. Assim, formaliza-se a especificao da etapa anterior, numa
implementao de alto nvel, em que so descritos apenas os aspectos relevantes soluo do problema.
Nesta etapa, procura-se simular o cdigo em uma ferramenta confivel, a fim de verificar, preliminarmente, o
cumprimento da especificao. Esta simulao no considera ainda detalhes tecnolgicos de implementao.
4/
151
VHDL
Sntese - o processo de traduo ou compilao de um cdigo VHDL para uma descrio abstrata,
em linguagem mais prxima da implementao. Naturalmente, a sntese ainda um processo independente
da tecnologia. Basicamente, o resultado obtido o que se chama de RTL (register- transfer level), em que
se definem registros, suas entradas e sadas e a lgica combinacional entre elas.
Otimizao - o processo de seleo da melhor soluo de implementao para uma dada tecnologia.
Logicamente, as ferramentas EDA (Engineering Design Automation) so preparadas para aceitar diretivas de
otimizao, dependendo do resultado que se quer (minimizao de rea, consumo, tempo de resposta, etc).
Fitting - o processo em que a lgica sintezada e otimizada mapeada nos recursos oferecidos pela
tecnologia.
A simulao realizada com o resultado do fitting permite resultados mais apurados de comportamento e
timing, porque considera as caractersticas da implementao definitiva na tecnologia, como, por exemplo,
os tempos de propagao dos sinais.
6- Gerao
Entidades e Arquiteturas
-- comparador de 4 bits
entity comp4 is
port ( a, b: in bit-vector (3 downto );
equals: out bit);
end comp4;
Uma entidade (entity) uma abstrao que descreve um sistema, uma placa, um chip, uma funo ou, at
mesmo, uma porta lgica. Na declarao de uma entidade, descreve-se o conjunto de entradas e sadas. No
exemplo dado, a entidade comp4 possui duas entradas, a e b, e uma sada, equals, que definem o port da
entidade.
Os ports correspondem a pinos e so tratados como objetos de dados. Pode-se atribuir valores ou obt-los
de ports. Cada entrada ou sada possui um modo (mode) de operao. Os modos possveis so:
in entrada;
out sada: os pinos definidos como sada no podem ser utilizados como entradas, nem seus valores
utilizados na lgica interna;
inout - substitui qualquer um dos outros, mas seu uso deve ser limitado aos casos em que o pino deva ser
utilizado como entrada e sada, para clareza na descrio.
A arquitetura (architecture) descreve as funes realizadas pela entidade. No caso do exemplo atribudo o
valor 1 sada equals, sempre que as entradas forem iguais e 0, caso contrrio.
Corpo de Arquitetura
A arquitetura de uma entidade pode ser descrita de trs formas distintas, mas que, em geral, conduzem a
uma mesma implementao.
a) Descrio comportamental
6/
151
VHDL
Esta a forma mais flexvel e poderosa de descrio. So definidos processos concorrentes (process). A
cada processo associada uma lista de sensibilidade, que indica quais so as variveis cuja alterao deve
levar reavaliao da sada. No simulador funcional, quando uma varivel da lista modificada, o processo
simulado novamente. O cdigo abaixo ilustra a aplicao deste tipo de descrio ao comparador do
exemplo.
-- comparador de 4 bits
entity comp4 is
port ( a, b: in bit_vector (3 downto );
equals: out bit);
end comp4;
Uma arquitetura pode ter mais de um processo e eles sero executados concorrentemente entre si.
Neste tipo de descrio, os valores de sada so atribudos diretamente, atravs de expresses lgicas.
Todas as expresses so concorrentes no tempo.
-- comparador de 4 bits
entity comp4 is
port ( a, b: in bit_vector (3 downto );
equals: out bit);
end comp4;
7/
151
VHDL
c) Descrio estrutural
A descrio estrutural apresenta netlists e instanciao de componentes bsicos, ou seja, como se fosse
uma lista de ligaes entre componentes bsicos pr-definidos.
-- comparador de 4 bits
entity comp4 is
port ( a, b: in bit_vector (3 downto );
equals: out bit);
end comp4;
use work.gateskg.all;
architecture estrut of comp4 is
signal x bit_vector (0 to 3);
begin
U: xnor2 port map (a(), b(), x());
U1: xnor2 port map (a(1), b(1), x(1));
U2: xnor2 port map (a(2), b(2), x(2));
U3: xnor2 port map (a(3), b(3), x(3));
U4: and4 port map (x(), x(1), x(2), x(3), equals);
end estrut;
Identificadores
Os identificadores so usados como referncia a todos os objetos declarados no cdigo. As regras para
formao de nomes so:
Objetos de dados
8/
151
VHDL
entity
architecture
process
Sinais - Representam ligaes (fios) que interligam componentes. Ports so exemplos de sinais.
Tipos de Dados
VHDL strongly typed: objetos de dados de tipos diferentes no podem ser atribudos um ao outro, sem
converso explcita.
Tipos escalares
a) Enumeration Types
9/
151
VHDL
NOTA: para usar std_logic e std_ulogic devem-se acrescentar as seguintes linhas antes da entidade:
library ieee;
use ieee.std_logic_1164.all;
b) Integer Types
Exemplo:
c) Flooting Types
10/
151
VHDL
d) Physical Types
Exemplo
Tipos compostos
Array
Exemplo:
Record
Exemplo:
11/
151
VHDL
Exerccios
1 - Projetar e simular:
2 Realizar o projeto de um contador sncrono, com uma seqncia pr-definida em VHDL e simular.
3 - Comentar os Exemplos:
--1 - VIGIA
LIBRARY ieee;
USE ieee.std_logic_1164.all;
ENTITY Vigia IS
PORT(
clk : IN STD_LOGIC;
SensorA, SensorB : IN STD_LOGIC;
Multa_Vel, Multa_Comp : OUT STD_LOGIC);
END Vigia;
ARCHITECTURE Intuitiva OF Vigia IS
TYPE STATE_TYPE IS (Espera,
Verificando_Velocidade,
Verificando_Tamanho,
Multa_Velocidade,
Multa_Tamanho,
Erro);
SIGNAL Estado: STATE_TYPE;
SIGNAL Cronometro: INTEGER RANGE 0 to 31;
BEGIN
PROCESS (clk)
BEGIN
12/
151
VHDL
13/
151
VHDL
--2 RECEPTOR
-- Receptor serial
entity Receptor is
port( data_in, clock, limpa: in bit;
pronto, ocupado: out bit;
data_out: buffer bit_vector(7 downto 0));
end Receptor
14/
151
VHDL
Data_out(5)<= Data_out(6);
Data_out(6)<= Data_out(7);
Data_out(7)<= Data_in;
END IF;
ELSE
Estado <= Pronto;
Pronto <= '1';
END IF;
WHEN Pronto =>
IF Limpa = 0 Then
Ocupado <= '0';
Pronto <= '0';
Estado <= Espera;
END IF;
END CASE;
END IF;
end process;
end Receptor;
15/
151
VHDL
Referncias
[1] Mazor, S. Langstraat, P. A Guide to VHDL. Kluwer Academic Publishers, Boston, 1993.
[2] Scarpino, F. VHDL and AHDL Digital System Implementation. Prentice Hall, New Jersey, 1998.
[3] Skahill, K. VHDL for Programmable Logic. Addison Wesley, Reading, Massachusetts, 1996.
16/
151