280 likes | 740 Views
LENGUAJE DE DESCRIPCION DE HARDWARE. ELECTRONICA DIGITAL NAYIBE CHIO CHO. 2008 @ NAYIBE CHIO CHO. DISPOSITIVOS LOGICOS PROGRAMABLES (PLD). Se clasifican por su arquitectura. 2008 @ NAYIBE CHIO CHO. LENGUAJE DE DESCRIPCION DE HARDWARE (HDL).
E N D
LENGUAJE DE DESCRIPCION DE HARDWARE ELECTRONICA DIGITAL NAYIBE CHIO CHO 2008 @ NAYIBE CHIO CHO
DISPOSITIVOS LOGICOS PROGRAMABLES (PLD) • Se clasifican por su arquitectura 2008 @ NAYIBE CHIO CHO
LENGUAJE DE DESCRIPCION DE HARDWARE (HDL) • HDL = lenguaje de alto nivel que permite describir las características de una red lógica • Orientado a la descripción de estructuras y el comportamiento del hardware • Se pueden representar diagramas lógicos, expresiones booleanas o circuitos digitales • HDL se puede realizar simulación y síntesis 2008 @ NAYIBE CHIO CHO
Simulación lógica : representa la estructura y el comportamiento de un sistema digital empleando un computador. Permite detectar errores sin necesidad de crear el circuito físico. • Síntesis lógica : lista de componentes y sus interconexiones 2008 @ NAYIBE CHIO CHO
Algunos HDL son : • VHDL es un lenguaje de descripción de hardware para circuitos integrados de muy alta velocidad, utilizado por el departamento de defensa de estados unidos y universidades. • Verilog HDL es un lenguaje que fue promovido por la compañía Cadence Data Systems y que luego pasó a Open Verilog International (OVI). 2008 @ NAYIBE CHIO CHO
AHDL es un lenguaje de descripción de hardware de Altera . No es un lenguaje universal, programa sistemas digitales en PLD’s de Altera. 2008 @ NAYIBE CHIO CHO
VHDL • Lenguaje de descripción en hardware (Hardware Description Language) • Creado por el departamento de Defensa de Estados Unidos como parte del programa Very High Speed Integrated Circuits a principios de 1980 • Estándar VHDL IEEE 1164 • Lenguaje orientado a la descripción y modelado de sistemas digitales 2008 @ NAYIBE CHIO CHO
Ventajas • Notación formal : permite su uso en cualquier diseño electrónico • Disponibilidad pública • Independencia tecnológica de diseño : soporta PLD, FPGA,ASIC, etc. • Independencia de la tecnología y proceso de fabricación : lenguaje funcion igual en circuitos diseñados con tecnología MOS, bipolares, etc • Independencia de los proveedores • Reutilización de código 2008 @ NAYIBE CHIO CHO
Desventajas • Algunas compañías le adicionan características al lenguaje • Complejo debido a que es diseñado por un comité 2008 @ NAYIBE CHIO CHO
PROVEEDORES • Altera • Cypress Semiconductor • Clear Logic • Motorola • Xilinx • Vantis • Quick Logic 2008 @ NAYIBE CHIO CHO
VHDL : Organización y Arquitectura • 5 unidades de diseño • Declaración de entidad (Entity declaration) • Arquitectura (Architecture) • Configuración (Configuration) • Declaración del paquete (Package declaration) • Cuerpo del paquete (Package body) 2008 @ NAYIBE CHIO CHO
Declaración de entidad Arquitectura Configuración Declaración del paquete Cuerpo del paquete Unidades de diseño PRIMARIAS Unidades de diseño SECUNDARIAS 2008 @ NAYIBE CHIO CHO
Entidad : especifica las líneas de entrada y salida = puertos • Arquitectura : forma en que las salidas se relacionan con las entradas 2008 @ NAYIBE CHIO CHO
VHDL utiliza librerías y paquetes las cuales permiten declarar y almacenar estructuras lógicas seccionadas o completas • Librería : unidades de diseño predeterminadas por el fabricante de la herramienta, agiliza el diseño • Ieee : paquete std_logic_1164 • Work : numeric_std,std_arith y gatespkg. Lugar donde se almacenan los programas que el usuario va generando 2008 @ NAYIBE CHIO CHO
Paquete : contiene algoritmos preestablecidos como sumadores, restadores, contadores, etc • Paquete std_logic_1164 : contiene todos los tipos de datos como std_logic_vector, std_logic, etc. 2008 @ NAYIBE CHIO CHO
Arquitecturas • Estilo funcional o de comportamiento: expone la forma en que trabaja el sistema, relación que hay entre las entradas y salidas del circuito • Estilo por flujo de datos: indica la forma en que los datos s pueden transferir de una señal a otra se utilizan instrucciones when – else o ecuaciones booleanas • Estilo estructural : basa su comportamiento en modelos lógicos establecidos (compuertas, sumadores, contadores, etc) 2008 @ NAYIBE CHIO CHO
ao COMPARADOR a1 c bo b1 • Estilo funcional 1 --comparador descripción funcional 2 library ieee; 3 use ieee.std_logic_1164.all; 4 Entity comparador is 5 port (a,b: in bit_vector (1 downto 0); 6 C : out bit ); 7 end comparador; 8 architecture D_funcional of comparador is 9 begin 10 Compara : process (a,b) 11 begin 12 If a = b then 13 c<=‘1’; 14 else 15 c<= ‘0’; 16 end if; 17 end process compara; 18 End D_funcional; 2008 @ NAYIBE CHIO CHO
Estilo flujo de datos • Utilizando when - else 1 --comparador flujo de datos when-else 2 library ieee; 3 use ieee.std_logic_1164.all; 4 Entity comparador is 5 port (a,b: in bit_vector (1 downto 0); 6 C : out bit ); 7 end comparador; 8 architecture D_flujo_datos of comparador is 9 begin c<=‘1’ when (a=b) else ‘0’ 11 end D_flujo_datos; 2008 @ NAYIBE CHIO CHO
1 --comparador flujo de datos – ecuaciones booleanas 2 library ieee; 3 use ieee.std_logic_1164.all; 4 Entity comparador is 5 port (a,b: in bit_vector (1 downto 0); 6 C : out bit ); 7 end comparador; 8 architecture booleano of comparador is 9 begin 10 c<= (a(1) xnor b(1) 11 And a(0) xnor b(0)); 12 end booleano; • Estilo flujo de datos • Ecuaciones booleanas 2008 @ NAYIBE CHIO CHO
ao bo a1 b1 U0 U1 X0 x1 c U2 1 --comparador descripción estructural 2 library ieee; 3 use ieee.std_logic_1164.all; 4 Entity comparador is 5 port (a,b: in bit_vector (0 to 1); 6 c : out bit ); 7 end comparador; 8 use work.compuerta.all; 9. architecture estructural of comparador is 10 signal x: bit_vector (0 to 1); 11 begin 12 U0 : xnor2 port map (a(0), b(0), x(0)); 13 U1 : xnor2 port map (a(1),b(1),x(1)); 14 U2 : and2 port map (x(0), x(1), c); 15 end estructural; • Estilo estructural 2008 @ NAYIBE CHIO CHO
PALABRAS RESERVADAS abs acces after alias all and architecture array assert attribute begin block body buffer bus case component configuration constant disconnect downto else elseif end entity exit file for function generate generic group guarded if impure in inertial inout is 2008 @ NAYIBE CHIO CHO
PALABRAS RESERVADAS (cont..) label library linkage literal loop map mod nand new next nor not null of on open or others out package port postponed procedure process pure range record register reject rem report return rol ror 2008 @ NAYIBE CHIO CHO
PALABRAS RESERVADAS (cont..) select severity shared signal sla sll sra srl subtype then to transport type unaffected units until use variable wait when while with xor xnor 2008 @ NAYIBE CHIO CHO
SIMBOLOS 2008 @ NAYIBE CHIO CHO