Documentos de Académico
Documentos de Profesional
Documentos de Cultura
Introducción
Estado del Arte
Características GHDL
Ejemplo 1: "hola mundo"
Ejemplo 2: inversor. Simulación y visualización ondas
Características avanzadas
Ejemplo 3: Llamadas a funciones en C desde VHDL
Conclusiones
Introducción(I):
Software libre
● Uso de plantillas
● Se imprime la cadena
"Hola mundo" por
pantalla
● Editor EMACS
● Resaltado de sintáxis
● Plantillas
● Documentación
● "Asistente"
Ejemplo 1: “Hola mundo”
Análisis
+
Fichero fuente Elaboración Fichero ejecutable
(GHDL)
hola_mundo.vhdl hola_mundo
$ ghdl -a hola_mundo.vhdl
$ ghdl -e hola_mundo
$ ./hola_mundo
¡¡¡Hola mundo!!!
Ejemplo 2: un inversor
Entrada
Salida
tb_inversor.vhdl inversor.vhdl
Visualización
Forma de onda
(GTKWAVE)
Ejemplo 2: un inversor
Análisis y elaboración:
Importar entidades a
$ ghdl -i *.vhdl librería de trabajo
$ ghdl --gen-makefile tb_inv > Makefile Generar Makefile
$ make
hola_mundo.vhdl
use std.textio.all;
use work.test.holac;
entity hola_mundo is
end hola_mundo;
architecture beh of hola_mundo is
begin
process
variable l : line;
variable v : integer;
begin
l := new string'("Hola desde VHDL...");
writeline (output, l);
v:=holac; Se invoca a la función en C
wait;
end process;
end beh;
Características avanzadas:
Invocación de funciones C, desde VHDL
$ ./hola_mundo
Hola desde VHDL...
Hola desde C...
Conclusiones
● GHDL: http://ghdl.free.fr
● GTKWAVE: http://www.cs.man.ac.uk/apt/tools/gtkwave/index.html
● LEON1: http://www.estec.esa.nl/wsmwww/leon/leon.html
● DLX: http://www.csee.umbc.edu/courses/undergraduate/411/spring96/dlx.html
TUTORIAL