TUTORIAL INTRODUCTORIO ISE, ISim e IMPACT Cristian Sisterna Sección 1 – Introducción al ISE Introducción En este tutorial se presenta la herramienta Integrated Software Environment (ISE) de la empresa Xilinx. El ISE se usa para modelar, simular y sintetizar diseños a ser implementados en FPGAs de Xilinx. Aún cuando este tutorial es presentado para utilizar el software ISE, el flujo a seguir es muy similar para otro software como por ejemplo el Quartus II de Altera. El ISE en sí, integra diferentes herramientas que permiten completar todos los pasos necesarios para implementar un sistema digital en un FPGA. Figura 1 muestra un diagrama de flujo de los distintos pasos a seguir dentro de un sistema integrado como el ISE. Las líneas de puntos son caminos opcionales en caso que se necesite algún ajuste para cumplir ciertas especificaciones. Figura 1 - Flujo de diseño para implementación en FPGA de un sistema digital descrito en VHDL C7 Technology NT 13 - Tutorial ISE Página | 2 Preparación para el Tutorial La idea de este tutorial es familiarizarse con los distintos pasos necesarios para implementar un sistema digital en un FPGA. Para ello se propone usar un proyecto ya elaborado y seguir los pasos descritos en esta guía. Los pasos necesarios a realizar antes de comenzar a trabajar son los siguientes: Descargue e instale el software ISE WebPack tal como se detalla en al Apéndice A al final de este tutorial. Instale la licencia respectiva para poder hacer uso del ISE WebPack (instalación explicada también en Apéndice A). En su disco duro cree una carpeta para ser usada como repositorio de este tutorial, por ejemplo utilice un directorio tipo C:\ISE_Tutorial\ como directorio raíz. En este directorio descargue los archivos de este tutorial desde el siguiente link: xxxxxxxxxxxxxxxxxxxxxx.. una vez descargado, descomprima el mismo. Sistema a Implementar El sistema a implementar en este tutorial es un simple contador para arriba/abajo con visualización de la cuenta en un display tipo 7 segmentos. La frecuencia de entrada al sistema proviene del cristal disponible en la placa y es dividida por un divisor de frecuencia, cuya baja frecuencia de salida controla el contador. La salida del contador excita un decodificador BCD-7segmentos. La siguiente figura muestra un esquema del sistema a implementar. Figura 2 – Esquema del sistema a implementar en el FPGA de la Nexys 2 C7 Technology NT 13 - Tutorial ISE Página | 3 Ejecución del ISE Para ejecutar el ISE haga Inicio-> Todos los Programas -> Xilinx Design Tools -> ISE Design Suite 14.3 -> ISE Design Tools -> Project Navigator. Luego debe aparecer el logo de Xilinx junto con una ventana pequeña indicando que el programa se está cargando, tal como se aprecia en Figura 3. Figura 3 - Indicador de que el ISE se está cargando La ventana principal del ISE se muestra en la Figura 4. A continuación se describen sus principales paneles. C7 Technology NT 13 - Tutorial ISE Página | 4 1 2 3 2 4 Figura 4 - Ventana principal del ISE Panel 1: Hierarchy. Detalla la jerarquía del diseño, es decir los distintos módulos VHDL que componen el sistema, ya sean módulos de descripción de hardware como así también módulos de estímulos (test bench). Detalla también el nombre del proyecto y el dispositivo FPGA a ser usado en la implementación del sistema descripto en la jerarquía. Panel 2: Procesos: detalla los procesos que se pueden ejecutar dependiendo que parte de la jerarquía (panel 1) seleccionada. Panel 3: Espacio de Trabajo, este panel es multiuso, en el cual se puede mostrar un módulo VHDL, un reporte de uso del FPGA, o tal como se muestra en Figura 4, un resumen de los recursos del FPGA utilizados para el diseño implementado. Dependiendo de lo que se seleccione es lo que se muestra. Panel 4: Consola, a medida que se van ejecutando los diferentes procesos (Panel 2) se muestra en este panel los mensajes respectivos. Una vez finalizado el proceso en ejecución, este panel tiene diferentes tabs en los que se puede seleccionar para ver solo los Warnings, solo los Errores o ver los resultados de las búsquedas en archivos. C7 Technology NT 13 - Tutorial ISE Página | 5 Creación de un Proyecto en ISE A continuación se detallan los pasos a seguir para crear un proyecto en el entorno ISE: a. En la barra del menú seleccione File->New Project. La ventana de opciones de un nuevo proyecto (New Project Wizard) aparecerá. b. Introduzca como nombre del proyecto ise_tutorial. Navegue para encontrar el directorio destino del proyecto o cree un directorio para este tutorial. Convenientemente use un directorio para el proyecto en sí, en este caso por ejemplo syn_ise (síntesis de ISE), y otro directorio para los archivos .vhd. c. Desde la opción Top-Level Source Type seleccione la opción HDL (esto significa que los módulos del sistema pueden ser descritos en VHDL o en Verilog). Finalizados los pasos a-c, se debería tener una ventana similar a la de la Figura 5. Figura 5 - Configuración proyecto nuevo d. Presione Next. La nueva ventana, llamada Project Settings, muestra las opciones referidas a la selección de la familia del FPGA, y dentro de la familia seleccionada, cual FPGA se va usar para implementar el proyecto. Las otras opciones de esta ventana están referidas a las herramientas de síntesis y simulación a usar en el proyecto, como así también la versión de VHDL. Se detalla a continuación la configuración respectiva. Este tutorial está orientado a usar la placa Nexys2, por lo que en caso de usar esta placa se debe seleccionar como Familiy la familia de FPGA Spartan 3E, y como Device el Spartan 3E-500 (que es el FPGA soldado en la placa Nexys 2), cuyo nombre comercial es el XC3S500E, por lo que seleccione ese FPGA del menú de Devices. En la C7 Technology NT 13 - Tutorial ISE Página | 6 parte de Package (encapsulado), seleccione el FG320, que es el encapsulado del FPGA soldado en la Nexys 2. La selección de Speed (velocidad) es importante solo para proyectos que trabajan a una muy alta frecuencia y es necesario tener un reporte de timing muy preciso, por ahora deje el valor que tiene por defecto. Los demás valores de configuración de esta ventana están referidos a las herramientas a usar para síntesis y para simulación, como así también si se va usar VHDL o Verilog. Deje los valores configurados por defecto, asegurándose que VHDL este seleccionado como Preferred Language, y que VHDL Source Analysis Standard esté en VHDL-200x. La siguiente figura detalla las opciones configuradas en este proceso. Figura 6 - Detalle del FPGA a ser usado para implementar el diseño en la Nexys 2 y configuración de herramientas de simulación y síntesis Para los que vayan a realizar este tutorial usando otra placa que no sea la Nexys 2, asegurarse de seleccionar correctamente primero la Family del FPGA (Spartan 3, Spartan 6, Virtex, etc.); luego seleccionar el Device, y el Package, esta información debe ser precisa para no tener problemas en las asignaciones de los pines de E/S del sistema a implementar. Normalmente todos los kits de desarrollo vienen con un manual de usuario detallando el FPGA soldado en la placa, y el encapsulado usado. Recordar que para un mismo Device hay varios diferentes Packages. e. Al hacer click en Next, una ventana que detalla la configuración del proyecto es mostrada, tal como se puede ver en Figura 7. C7 Technology NT 13 - Tutorial ISE Página | 7 Figura 7 - Resumen de la configuración del proyecto f. Al hacer click en Finish, la ventana principal del ISE del nuevo proyecto debe aparecer, similar a la mostrada en la siguiente figura. Figura 8 - Proyecto recién creado, detallado en el panel Hierarchy C7 Technology NT 13 - Tutorial ISE Página | 8 Una vez creado el proyecto hay dos opciones en este panel con respecto al agregado o la escritura de los códigos VHDL: 1. Una opción Add Source, que es agregar un archivo .vhd que ya ha sido escrito anteriormente a la creación de este proyecto (por ejemplo un código .vhd escrito para otro proyecto, o con otro editor de texto). 2. La otra opción es New Source, es crear un nuevo archivo VHDL. Para acceder a estas dos opciones, se presiona el botón derecho del mouse, teniendo el cursor del mouse en el panel de Hierarchy, y se elige la opción que desee, tal como se puede apreciar en Figura 9. Ambas opciones se detallan a continuación. Figura 9 - Selección de archivos .vhd a ser agregados al proyecto Para el caso de querer agregar, Add Source, un código VHDL ya escrito se deben realizar los siguientes pasos: 1. Desde la ventana de ‘New Project window”, haga click en Next, y luego en Add Source. Esto abrirá la ventana de opciones. 2. Usando el navegador, seleccione el directorio y luego el archivo a ser agregado. Si Ud. ha descargado el .zip de este tutorial, los archivos .vhd están en la carpeta rtl_src, tal como se detalla en la siguiente figura. Seleccione todos los archivos y presione Open. C7 Technology NT 13 - Tutorial ISE Página | 9 Figura 10 – localización de los archivos .vhd de este tutorial 3. Los archivos a agregar al proyecto se detallan en una nueva ventana, similar a la mostrada en la siguiente figura. Figura 11 - Archivos .vhd a agregar al proyecto 4. Para la ejecución de este tutorial es necesario agregar otro archivo .vhd que reside en el subdirectorio pckgs, tal como se ve en Figura 12. Este archivo .vhd es un paquete (package) que es usado en este proyecto. Figura 12 - Localización del archivo tutorial_pckg.vhd 5. Una vez concluido el proceso de agregar los archivos, click Next para ver la información relativa al proyecto recién creado. Si ha realizado los C7 Technology NT 13 - Tutorial ISE Página | 10 procedimientos antes descritos correctamente la ventana de jerarquía de su proyecto debería ser similar a la mostrada en Figura 13. Figura 13 - Jerarquía completa del proyecto ISE_Tutorial Nota: no siempre el package es mostrado en la ventana de Hierarchy. Para el caso de querer crear un nuevo archivo .vhd, ejecute los siguientes pasos: 1. En el dialogo ‘Create a New Source’, click ‘New Source’, y especifique el tipo, VHDL, el nombre y la locación del archivo. Ver Figura 14. Figura 14 - Especificaciones del archivo .vhd a ser creado 2. La ventana de dialogo de nuevo archivo aparecerá. Introduzca los nombres de los puertos, y la respectiva dirección e indique si alguno de los puertos es un bus. Tal como detalla Figura 15. C7 Technology NT 13 - Tutorial ISE Página | 11 Figura 15 - Detalle puertos E/S del módulo .vhd a ser creado 3. Click Next, un resumen de los puertos de entrada y salida se detallan, compruebe que los datos sean correctos. Luego presione Finish. 4. Esta última acción incorpora el .vhd recién creado al proyecto y lo abre en la ventana del editor de texto. Este .vhd es solo las entradas y salidas, y unas líneas de la arquitectura, el código en si se debe escribir a partir de estas bases. Flujo de Diseño del ISE Una vez creado el proyecto, en los distintos paneles del ISE se muestra la siguiente información (tal como se detalló en la parte Ejecución del ISE de este tutorial): a) Panel Jerarquía: Los distintos módulos componentes del proyecto b) Panel Proceso: Los procesos que pueden ejecutarse c) Panel Espacio de Trabajo: El estado del proyecto d) Panel Consola: El resumen del diseño implementado en la FPGA. Una marca verde de chequeo exitoso (check mark) al costado de cada módulo .vhd indica que el archivo ha sido incorporado correctamente al proyecto. Por otro lado, un signo de pregunta (?) indica que el archivo aún no es parte del proyecto, y que se necesita se incorpore al mismo (Project -> Add Source). La siguiente figura, muestra, en el panel Hierarchy, el proyecto recién creado, y los distintos módulos componentes del proyecto. C7 Technology NT 13 - Tutorial ISE Página | 12 Figura 16 - Proyecto creado para este tutorial luego de agregar los .vhd respectivos Procesos Básicos a Ejecutar para Implementar en FPGA Sintetizar (Synthesize - XST) El proceso de sintetizar el diseño, primero chequea la sintaxis de todos los módulos componentes del proyecto conforme al estándar VHDL. Luego, realiza la síntesis de los distintos módulos del sistema, es decir convierte el código VHDL en lógica, LUT, FFs, bloques de memoria, etc.,. Presione dos veces la opción de Synthesize – XST para comenzar el proceso de síntesis. Si el proceso termina exitosamente una marca de chequeo verde aparece al costado del proceso de síntesis, de lo contrario una ‘X’ roja es mostrada al costado del módulo con error. Información detallada sobre el proceso de síntesis es mostrada en la consola del ISE (panel inferior de la ventana principal de Project Navigator). Nota: recuerde tener seleccionado el módulo de mayor nivel jerárquico del proyecto, antes de selección Synthesize – XST (en realidad antes de ejecutar cualquier proceso, salvo el de simulación). C7 Technology NT 13 - Tutorial ISE Página | 13 Figura 17 – Selección del proceso de síntesis Si creó el proyecto agregando los módulos .vhd incluidos en el ISE_Tutorial.zip, luego de presionar dos veces Synthesize – XST, se generarán varios mensajes de error tal como se puede ver en la Figura 18. Estos mensajes son generados por una omisión hecha a propósito a fin de que se familiaricen con el proceso de corrección de errores. Figura 18 - Mensajes de error Al leer los mensajes de error, se puede deducir que el problema está en el módulo bcd_7seg_v2.vhd. Puede hacer doble click en cualquiera de los mensajes de error para abrir en el editor de texto del ISE el módulo bcd_7seg_v2.vhd. Una vez abierto el .vhd, agregar la siguiente línea en la parte Library Declarations (ver Figura 19, línea 33): use work.tutorial_pckg.all; C7 Technology NT 13 - Tutorial ISE Página | 14 Figura 19 - Modificación a realizar en el archivo bcd_7seg.vhd Subsanado el error, grabe el archivo bcd_7seg.vhd y ejecute nuevamente Synthesize – XST. Una vez finalizada la síntesis, ISE muestra automáticamente un resumen (Summary) de la síntesis del sistema descrito en VHDL. Figura 20 muestra los datos creados por la herramienta de síntesis. Se puede observar, por ejemplo, en la parte de Device Utilization Summary una estimación de los recursos del FPGA utilizados para implementar el sistema en el FPGA, y el porcentaje de recursos usados en función del total de recursos disponibles. Figura 20 - Resumen de los resultados de síntesis del sistema descrito en VHDL Es importante ver el reporte detallado generado por la herramienta de síntesis, el cual tiene información diversa tales como cuales son las opciones usadas para llevar a cabo la síntesis, mensajes de advertencia (warnings) , uso de recursos, etc . Para abrir el reporte se debe hacer click en Synthesis Report de la opción Detailed Report, tal como se muestra en Figura 21. Nota: otra información útil del reporte de síntesis es la codificaion usada en maquienas de estados, en el caso de este proyecto simple no se ha implementado una máquina de estados, por lo que no se reporta nada al respecto, pero cuando se implementan máquinas de estado es conveniente revisar la codificación usada, la cual puede ser cambiada por el usuario. C7 Technology NT 13 - Tutorial ISE Página | 15 Figura 21 – Reporte generado por el proceso de síntesis Vista RTL del Diseño Finalizado el proceso de síntesis, una herramienta interesante, aunque no necesaria para el proceso de implementación, es el proceso View RTL Schematic. Como resultado de la ejecución de ese proceso se obtiene una vista del esquemático que se genera de la información suministrada por la herramienta de síntesis. Para ejecutar este proceso hacer doble click en View RTL Schematic, al que se accede al presionar el símbolo + al costado de Synthesize – XST, tal como se detalla en Figura 22. Figura 22 - Selección del proceso RTL Schematic View Después se abre la ventana mostrada en Figura 23. C7 Technology NT 13 - Tutorial ISE Página | 16 Figura 23 – Primer paso para la creación del RTL Schematic View En esta ventana por defecto en la sección de Available Elements está seleccionado el módulo de mayor jerarquía, en este caso el módulo top. Hacer click en la opción Add para que el nombre del módulo aparezca ahora en la sección Selected Elements. Presionar luego Create Schematic. La primera vista del esquemático generado usualmente es solo un módulo con el nombre del componente seleccionado en el paso anterior. En la Figura 24 se muestra el modulo top y sus respectivas E/S. Figura 24 - RTL View del módulo de mayor jerarquía C7 Technology NT 13 - Tutorial ISE Página | 17 Hacer doble click con el mouse en el bloque top, y ahora aparecerá un esquemático de más bajo nivel mostrando los bloques de menor jerarquía, que constituyen el módulo top (el de mayor jerarquía). El esquemático también muestra la respectiva interconexión entre los diferentes módulos, tal como se puede apreciar en Figura 25. Si se desea se puede a su vez hacer nuevamente doble click en alguno de estos módulos y se abrirá una nueva ventana mostrando el respectivo esquemático, se puede seguir así hasta llegar a un nivel que no permita seguir. Figura 25 - Detalle de los módulos componentes del sistema y sus respectivas interconexiones Creación de Restricción de Periodo Mínimo de Reloj Uno de los puntos más importantes en la implementación de un sistema digital en un FPGA es saber cuál es la frecuencia máxima a la que puede funcionar correctamente el sistema. Para ello todos los softwares disponibles en el mercado traen una herramienta que realizan lo que se llama Análisis de Tiempo Estático (Static Timing Anaysis, STA). Ahora bien, para que esta herramienta genere un reporte de los retardos críticos del sistema a implementar, y de ahí deducir la frecuencia máxima de funcionamiento, se debe proveer a esta herramienta de un valor aproximado de la frecuencia a la cual se desea funcione el sistema. Para ello se dispone de lo que se llama restricciones de tiempo (timing constraints) que pueden ser escritas en un archivo de texto o a través de una interface gráfica. En este tutorial usaremos esta última opción. Para abrir la interface gráfica para generar gráficamente la restricción de tiempo de periodo mínimo (frecuencia máxima), del menú de barras seleccione Tools -> Constraints Editor, tal como se muestra en Figura 26. C7 Technology NT 13 - Tutorial ISE Página | 18 Figura 26 - Selección de la opción para crear una restricción de frecuencia de reloj Una vez realizado Tools -> Contraints Editor, aparece la ventana mostrada en Figura 27, en la cual se pregunta si desea ejecutar el proceso para generar los datos de restricciones de tiempo dado que el sistema no tiene todavía ninguno. Click Yes. Figura 27 - Habilitación del proceso de generación de periodo mínimo Luego de presionar Yes, aparece una nueva ventana en la que se pregunta si se desea agregar automáticamente al proyecto el archivo de restricciones de implementación (User Constraint File, .ucf) que se va a generar. Presionar Yes. Figura 28 - Pregunta si se desea agregar automáticamente el .ucf al Proyecto Nota: el archivo .ucf es en realidad un archivo de texto (como se verá más adelante). Una vez configurada gráficamente la frecuencia mínima, la herramienta genera la sintaxis correcta en texto, para el valor especificado usando la restricción de tiempo adecuada. Una vez habilitado el proceso de creación del .ucf aparece una nueva ventana, mostrada en la Figura 29. Esta ventana tiene distintas partes, pero la que interesa en este proceso es la que dice Unconstrained Clocks. En esta parte se muestran los relojes del sistema a los que no se les ha asociado un periodo mínimo. En el caso del proyecto de este tutorial, el reloj se denomina high_freq_clock. C7 Technology NT 13 - Tutorial ISE Página | 19 Figura 29 - Selección del reloj a ser restringido Hacer doble click en el nombre del reloj, high_freq_clock. Aparecerá una nueva ventana similar a la de la Figura 30. En esta ventana, en la parte Specify Time se debe escribir el periodo mínimo de funcionamiento del reloj seleccionado en el paso anterior. En este caso, y dado que la tarjeta Nexys 2, tiene un cristal que oscila a 50MHz, y esta frecuencia entra directamente al FPGA, se define el periodo mínimo de high_freq_clock como 20 ns. Los demás valores se dejan en su valor por defecto. Figura 30 - Interface gráfica para fijar periodo mínimo del reloj seleccionado Nota: Este es un ejemplo muy sencillo y sobre todo de inicialización en la familiarización del software y hardware, para proyectos más complicados aparecerán más relojes, y se debe ir configurando de a uno. También, pueden haber relojes generados internamente, tales como las salidas de los PLLs, estos relojes también deberían aparecer en la ventana Unconstrained Clock de la Figura 29. Una vez terminado con el paso explicado anteriormente y luego de presionar Ok, en la ventana inicial, mostrada en Figura 29, ahora debe aparecer high_freq_clock en el panel Create Timing Constraints for Clock Domians, tal como se muestra en Figura 31. C7 Technology NT 13 - Tutorial ISE Página | 20 Figura 31 - Restricción configurada para high_freq_clock Finalmente hacer, File -> Save As para grabar el .ucf en el sub-directorio /ucf. Luego File -> Exit. De este modo se agrega automáticamente al proyecto el archivo .ucf con las restricciones de reloj recién generadas. Figura 32 detalla la nueva estructura del proyecto tutorial con el archivo top.ucf recién creado. Figura 32 - Archivo .ucf agregado automáticamente al proyecto Si hace doble click en top.ucf, se abrirá en el panel de edición el archivo de texto que contiene la restricción del reloj generada a partir de la interface gráfica. En este caso debería ver algo similar a lo siguiente: #Created by Constraints Editor (xc3s500e-fg320-5) - 2015/01/17 NET "high_freq_clock" TNM_NET = "high_freq_clock"; TIMESPEC TS_high_freq_clock = PERIOD "high_freq_clock" 20 ns HIGH 50 %; Nota: en la figura 32 se observa que se detalla el camino completo del directorio donde reside cada archivo del proyecto. Este camino se puede activar o desactivar (en otras figuras de este tutorial no se muestra el camino completo). Para activar/desactivar, situar el mouse sobre cualquier archivo .vhd, presionar botón derecho del mouse y seleccionar File/Path Display y luego seleccionar Show para mostrar el camino completo de la locación de los archivos. Asignación de pines de E/S Otro proceso importante antes de realizar la implementación del sistema en el FPGA es el proceso de asignación de pines de E/S del sistema diseñado. En este proceso se asocia cada C7 Technology NT 13 - Tutorial ISE Página | 21 E/S del sistema con un pin especifico del FPGA, esta asociación queda expresada en forma de texto en el archivo de restricción (archivo top.ucf). Del mismo modo que para el caso de la restricción del periodo de reloj, la asignación de pines de E/S se puede hacer ya sea escribiendo en el mismo archivo .ucf la restricción respectiva, siguiendo una cierta sintaxis, o se puede hacer la asociación en forma gráfica para posteriormente generar automáticamente el texto correspondiente en el .ucf. Se detalla a continuación la forma gráfica de asociación mediante el uso de la herramienta PlanAhead, para la generación de las restricciones de asociación de pines del FPGA con los pines E/S del sistema. Para ello haga doble click en el proceso I/O Pin Planning (PlanAhead) – Post-Synthesis. Ver Figura 33. Figura 33 - Proceso a invocar para la asignación de pines de E/S Este proceso invoca la herramienta gráfica llamada PlanAhead, que tiene diversas funciones de utilización siendo una de ellas la asignación de pines del E/S (las otras funciones de PlanAhead son avanzadas, y por ende no se explican en este tutorial introductorio). La ventana principal de PlanAhead se muestra en Figura 34. C7 Technology NT 13 - Tutorial ISE Página | 22 Figura 34 - Ventana principal de la herramienta Plan Ahead La ventana principal de PlaAhead tiene varios paneles, tal como se puede ver en Figura 34. En el panel inferior, llamado I/O Ports, y en la primer columna de dicho panel, se detallan todas la entradas y salidas del sistema. Las siguientes columnas detallan diversos valores y características de cada E/S, especificándose algunos valores por defecto, entre ellos por ejemplo el valor de VCCO, el estándar de E/S, para las salidas se especifica el tipo de pendiente (slew/fast), como así también la capacidad de drenaje de la corriente, también se puede especificar si la E/S necesita algún tipo de resistor de arranque (pull up / pull down). Ahora bien estos valores que son mostrados por defecto no necesariamente deben ser respetados. Sobre todo los referidos a la tensión VCCO y al I/O estándar. A este punto del tutorial es necesario revisar la información provista por el fabricante de la kit que se vaya a usar para implementar el diseño en el FPGA, en este caso revisaremos la guía de usuario de la Nexys 2, que en realidad se llama manual de referencia. Este manual se puede descargar del siguiente link: http://www.digilentinc.com/Data/Products/NEXYS2/Nexys2_rm.pdf C7 Technology NT 13 - Tutorial ISE Página | 23 Del manual de referencia se obtiene la información de cual pin del FPGA está asociado a los componentes de la placa que hacen falta para este proyecto. Así por ejemplo, se necesita saber los pines de salida del FPGA que controlan los LEDs de uno de los siete segmentos disponibles en la placa. También, se necesita conocer el pin del FPGA asociado a la entrada del reloj de 50 MHz, los pines de entradas al FPGA asociados a los switches, etc. Esta información se puede obtener del manual de referencia en página 4 y página 5. Teniendo el manual de referencia a mano, y con PlanAhead abierto, se debe completar para cada entrada y salida los siguientes datos: Site: se refiere al pin del FPGA que se va asociar con la entrada o salida respectiva. Así, por ejemplo la salida seven_segm_dsply[6] se asocia con el pin L18 del FPGA, que es el pin que controla el segmento a del primer 7-segmentos (esta información se obtiene de la Figura 8 del manual de referencia). Se deben completar todos los sites para cada entrada y para cada salida del sistema diseñado. Para escribir un pin específico del FPGA se puede directamente escribir el nombre del pin, por ejemplo L14, o presionar con el mouse el extremo derecho de la respectiva celda y aparece un menú de los pines disponibles, seleccione el que necesite. I/O Std: los pines de E/S del FPGA tienen un buffer programable que se adapta a las distintas necesidades del estándar de E/S que se necesite. Tal como se vió en la Figura 34, por defecto PlanAhead muestra un I/O Std de LVCMOS25, pero tal como se puede observar en Figura 8 del manual de referencia de la placa Nexys 2, los periféricos de E/S funcionan con LVCMOS 3.3V, por lo que se debe cambiar el I/O Std a ese valor para cada E/S del sistema. Del mismo modo que en el caso anterior para cambiar el I/O Std directamente se puede escribir el estándar o presionar el mouse en el extremo derecho de la celda y seleccionar LVCMOS33. Los demás valores de esta tabla se dejan con su valor por defecto. Figura 35 muestra como debería quedar el panel de I/O Ports de PlanAhead luego de realizar las asignaciones indicadas en Site y I/O Std. Figura 35 - Pines E/S y voltajes asignados a cada puerto de E/S C7 Technology NT 13 - Tutorial ISE Página | 24 Al cerrar la ventana de PlanAhead, ya sea presionando la X de la ventana o mediante File -> Exit, automáticamente se genera el archivo de restricciones .ucf. En caso de existir un .ucf, tal como por ejemplo uno en el que se haya establecido la frecuencia de reloj, las nuevas restricciones automáticamente se agregan a la existente. Figura 36 muestra la locación del archivo. Figura 36 - Archivo de restricciones top.ucf Para abrir el archivo top.ucf se puede presionar botón derecho y abrirlo con cualquier editor de texto o directamente presionar dos veces sobre top.ucf en el panel de jerarquía del proyecto. A continuación se muestra el contenido del archivo de restricciones. #Created by Constraints Editor (xc3s500e-fg320-5) - 2015/01/17 NET "high_freq_clock" TNM_NET = "high_freq_clock"; TIMESPEC TS_high_freq_clock = PERIOD "high_freq_clock" 20 ns HIGH 50 %; # PlanAhead Generated physical constraints NET NET NET NET NET NET NET NET NET NET NET "seven_segm_dsply[6]" LOC = "seven_segm_dsply[5]" LOC = "seven_segm_dsply[4]" LOC = "seven_segm_dsply[3]" LOC = "seven_segm_dsply[2]" LOC = "seven_segm_dsply[1]" LOC = "seven_segm_dsply[0]" LOC = "high_freq_clock" LOC = B8; "sys_reset" LOC = B18; "up_down" LOC = G18; "dsply1_anodo" LOC = F15; L18; F18; D17; D16; G14; J17; H14; # PlanAhead Generated IO constraints NET NET NET NET NET NET NET NET NET NET NET "seven_segm_dsply[6]" IOSTANDARD = LVCMOS33; "seven_segm_dsply[5]" IOSTANDARD = LVCMOS33; "seven_segm_dsply[4]" IOSTANDARD = LVCMOS33; "seven_segm_dsply[3]" IOSTANDARD = LVCMOS33; "seven_segm_dsply[2]" IOSTANDARD = LVCMOS33; "seven_segm_dsply[1]" IOSTANDARD = LVCMOS33; "seven_segm_dsply[0]" IOSTANDARD = LVCMOS33; "dsply1_anodo" IOSTANDARD = LVCMOS33; "high_freq_clock" IOSTANDARD = LVCMOS33; "sys_reset" IOSTANDARD = LVCMOS33; "up_down" IOSTANDARD = LVCMOS33; Este .ucf tiene tres partes, la primera referida al periodo del reloj high_freq_clock, configurado a 20 ns, la segunda parte referida a la asociación de pines del FPGA con las señales de E/S del sistema diseñado, y la tercer parte configura el estándar de E/S (LVCMOS33). C7 Technology NT 13 - Tutorial ISE Página | 25 Implementación del Diseño Una vez completados los pasos anteriores ya se puede comenzar con los procesos necesarios para la implementacion del sistema en el FPGA. El proceso de implementación del diseño, Implement Design, crea el hardware y genera el ruteo a ser implementado en el FPGA. Hay varios procesos relacionados con la implementación del diseño: Translate: crea una base de datos interna del diseño. Esto puede incluir una variedad de formatos tales como VHDL, EDIF netlist, etc. Todos estos formatos son convertidos y unidos en un netlist con un formato dado por Xilinx. Map: este proceso mapea la lógica generada en el proceso de Translate en hardware de la FPGA (CLBs, IOBs, BRAM, etc). Este paso también optimiza lógica, y remueve lógica no usada. Place and Route (P&R): este proceso asigna CLBs, IOBs, BRAMs, específicos del FPGA y los respectivos ruteos de interconexión de lógica. Si una restricción de tiempo ha sido establecida será usada para guiar la locación de la lógica. El ruteo del diseño también será controlado por la locación de los pines de E/S. El reporte de P&R indica la calidad del ruteo, un resumen de timing, y si alguna señal no ha sido exitosamente ruteada. A los fines prácticos de este tutorial, se puede ejecutar cualquiera de los procesos contenidos dentro del proceso de Place & Route. Al ejecutarse uno de estos procesos todos los procesos anteriores serán ejecutados también. Por ejemplo, la siguiente figura muestra la opción de seleccionar el proceso de Generate Post Place and Route Static Timing. Figura 37 - Ejecución del proceso Generate Post Place and Route Static Timing Finalizada la ejecución de cualquiera de los procesos de Implement Design, es muy conveniente leer alguno de los distintos reportes generados en función del proceso ejecutado. C7 Technology NT 13 - Tutorial ISE Página | 26 Los reportes se encuentran en la columna del medio del panel principal. De acuerdo al reporte que se seleccione es como cambia la parte inferior de la mencionada columna. La siguiente figura detalla lo escrito. Figura 38 - Distintos reportes disponibles En caso de no tener disponible a simple vista la columna de los reportes, presionar el tab Design Summary en la parte inferior del panel principal, o tambien puede hacer Layout -> Load Default Layout. Uno de los reportes importantes que se debe examinar antes de proseguir con el proceso de implementación, es el reporte de pines de E/S asignados. Este reporte es conocido como Pinout Report y es parte del reporte del Design Summary. Figura 39 muestra como acceder a este reporte. Ayuda: presione el indicador Signal Name para ordenar las señales por su nombre y de ese modo aparecerán primero las señales de E/S del proyecto. En este reporte es necesario verificar que la asociación de pines del FPGA y las E/S del sistema diseñado sea correcta. Por ello teniendo el manual de referencia de la placa que esté usando verificar los pines del FPGA asignados a los periféricos que serán usados y su correcta asociación con las E/S del módulo top.vhd. C7 Technology NT 13 - Tutorial ISE Página | 27 Figura 39 - Reporte de pines de E/S asignados C7 Technology NT 13 - Tutorial ISE Página | 28 Sección 2 - TUTORIAL ISim Una vez descrito el sistema en VHDL y luego de ser sintetizado por la herramienta de síntesis, es necesario crear los estímulos necesarios y ejecutar las respectivas simulaciones para comprobar el comportamiento del sistema antes de ser implementado en el FPGA. El archivo que contiene los estímulos para el sistema a ser simulado se llama genéricamente test bench. El test bench en sí puede ser creado, tal como se crea un nuevo módulo VHDL, o puede ser importado al proyecto, en caso que ya existiese el test bench, usando la opción Add Source. Se describen a continuación ambas opciones. Creación del Test Bench (New Source) Si no tiene abierto el proyecto, ábralo ejecutando File->Open Project. Una vez abierto el proyecto, para crear el respectivo test bench presione el botón derecho del mouse en el panel Hierarchy, y seleccione New Source. En la ventana de New Source Wizard seleccione VHDL Test Bench, e introduzca el nombre del test bench, tal como se muestra en Figura 40. Figura 40 - Test bench a ser creado y agregado al proyecto Una vez seleccionado el nombre y la locación del test bench, click Next. En la ventana que aparece debe seleccionar con cual archivo .vhd desea asociar el test bench a crear. Seleccione cuidadosamente el archivo correspondiente. En Figura 41 se muestra que el nuevo test bench se va asociar al módulo top.vhd. C7 Technology NT 13 - Tutorial ISE Página | 29 Figura 41 - Asociación con el módulo top del test bench a ser creado Complete la creación del nuevo Test Bench al hacer click en Next y Finish, luego en el panel Espacio de Trabajo se abrirá automáticamente el recientemente creado test bench para ser editado. El código generado incluye lo siguiente: Definición de las librerías La entidad (entity) La arquitectura Declaración de señales internas Un bloque de instanciación Procesos de estímulo de reloj y reset El código generado es realmente un patrón muy genérico, por lo que para diseños complejos puede ser que el test bench generado sea muy sencillo, mientras que para diseños simples algunas partes deben ser removidas. Una de las primeras cosas a modificar es la constante <clock>_period. Verifique también los valores iníciales asignados por defecto. Agregue las líneas de código que considere necesarias para generar los estímulos. Recuerde también de agregar código de verificación en caso que así lo desee. Después de realizar los respectivos cambios, grabe al archivo. Nota: no es la intención de este tutorial introductorio describir en detalle las distintas partes y formas de estímulos de un test bench. Para los interesados pueden leer la siguiente nota de aplicación: http://hdl-fpga.blogspot.com.ar/2012/05/generacion-de-estimulos-y-verificacion.html Agregar Test Bench (Add Source) Del mismo modo como se puede agregar un módulo VHDL de descripción de hardware, se puede agregar un módulo VHDL de estímulo (test bench). Para ello en la ventana de jerarquía del proyecto presione botón derecho del mouse y selección Add Source. Si ha bajado el ISE_Tutorial.zip puede encontrar el test bench top_tb.vhd en el subdirectorio tb_source tal como se detalla en la Figura 42. C7 Technology NT 13 - Tutorial ISE Página | 30 Figura 42 - Agregar al proyecto el modulo top_tb.vhd incluido en el c7t_ise_tutorial.zip top_tb.vhd es un test bench muy simple, que básicamente genera el reloj de alta frecuencia, de un periodo de 20 ns, y genera también una señal de inicialización del sistema (reset). De nuevo no es el propósito de este tutorial enseñar a escribir test benches. Opciones de Simulación Por defecto la opción del subpanel Design es Implementation, por esta razón el/los test benches que pudieran ser parte del proyecto no aparecen por defecto en el panel de jerarquía. Para que aparezcan los test benches relacionados con el proyecto, se debe cambiar a la opción Simulation en el subpanel Design, tal como muestra en Figura 43. Figura 43 – Visualización del test bench top_tb cuando se selecciona Simulation En Figura 43, se observa que los archivos .vhd del panel de Hierarchy cambian de orden, siendo ahora el test bench (top_tb) el primer archivo desde arriba hacia abajo. Si se selecciona el test bench, es decir se presiona el mouse una vez sobre top_tb, en el panel de procesos (Processes) aparecen dos opciones, ver Figura 44: la opción Syntax Check que llevará a cabo un chequeo de la sintaxis del archivo .vhd. La otra opción es Simulate Behavioral Model, que en caso de presionar dos veces el mouse en esa opción, se invoca al simulador ISim del ISE, y se llevará a cabo una simulación de tipo de funcionalidad (otras opciones de simulación se detallan más adelante). C7 Technology NT 13 - Tutorial ISE Página | 31 Figura 44 - Selección de herramienta de simulación ISim Tiempo de Simulación Antes de correr la simulación verifique que el tiempo de simulación que se asigna por defecto al simulador sea mayor que el tiempo de simulación requerido para su diseño. Presione botón derecho del mouse en el proceso Simulate Behavioral Model y seleccione Process Properties. Las principales propiedades del ISim se detallan tal como se puede ver en Figura 45. Figura 45 - Opciones de configuración del Simulador C7 Technology NT 13 - Tutorial ISE Página | 32 En el caso mostrado en Figura 45 el tiempo de simulación es de 1000ns, verifique si ese valor se adecua a los tiempos de simulación de su diseño, sino cámbielo al valor que necesite. Luego, para ejecutar el test bench, haga doble click en Simulate Behavioral Model, la ventana principal del simulador, llamado ISim, aparecerá. A continuación se explican las principales funciones de este simulador. Paneles del ISim Una vez abierto el ISim se tienen cuatro paneles principales, detallados en la Figura 46. 3 1 2 4 Figura 46 - Paneles principales del ISim Panel 1: Instancias y Procesos, para la selección de archivos fuentes. Panel 2: Objetos, detalla las señales que se pueden agregar a la simulación. Panel 3: Simulación, donde el estado de las señales y sus respectivas formas de ondas pueden ser observadas. Panel 4: Consola, donde los mensajes relativos a la simulación se detallan. Algunas herramientas útiles del ISim: El icono ‘Zoom to Full View’, se usa para tener una vista completa de la simulación. Para ver más detalles de la simulación, usar la lupa con al signo más (+) C7 Technology NT 13 - Tutorial ISE . Página | 33 En la parte izquierda del panel de simulación hay dos columnas denominadas Name y Value. Para una señal determinada en la columna Name puede hacer click sobre el botón derecho del mouse en la señal deseada, y seleccionar la opción de borrar, renombrar o cambiar de color. Las señales se pueden arrastrar para arriba o para abajo. Otra opción útil es agregar ‘New Divider’, para separar las señales por funcionalidad por ejemplo. El bloque de control de simulación, sobre la parte derecha del menú de barras del ISim, tiene las siguientes características: o Re-comienzo de simulación, la detiene y vuelve el tiempo de simulación a 0. o Ejecuta la simulación hasta que todos los eventos son ejecutados o Ejecuta la simulación por el tiempo especificado en el indicador del valor de tiempo o Indicador del valor de tiempo de ejecución de la simulación, y unidad de tiempo o Ejecuta la simulación, una instrucción por vez o Pausa la simulación Otra herramienta bastante útil de ISim es la que posibilita ir a la próxima transición de una señal seleccionada. Para ello se debe primero seleccionar una señal de la columna Name del panel de simulación. Luego se presiona el icono y el simulador centra las formas de ondas mostradas en próxima transición de la señal seleccionada, por ejemplo una transición de 0 -> 1, o de 1 -> 0 de la señal, e identifica la transición con un cursor. Una vez finalizada la simulación por el periodo de tiempo determinado por el valor del tiempo de ejecución de la simulación, por ejemplo 1.0us, se puede seguir la simulación por otro periodo de tiempo al presionar o escribiendo en el panel de consola: run 1.0us, y presionando <enter>. Por supuesto que se puede variar el tiempo de simulación en caso de ser necesario. Por ejemplo, para el diseño de este tutorial el tiempo de simulación debe ser bastante largo ya que la base de tiempo para mostrar los números en el display 7 segmentos es de aproximadamente 1 segundo, por lo que para ver las transiciones en la ventana del simulador se debe cambiar la duración de la simulación a un valor bastante largo, por ejemplo a 6.000ms (6 segundos). C7 Technology NT 13 - Tutorial ISE Página | 34 Ejecución de Simulación Post Place and Route Para la ejecución de la simulación Post Place and Route se debe: Generar el respectivo archivo del modelo de simulación del diseño implementado en el FPGA conteniendo todos los retardos lógicos y de ruteos. Figura 47 - Generación del archivo de simulación con retardos lógicos y de ruteos Seleccionar la simulación Post-Route desde el menú de simulación. Figura 48 - Configuración para simulación post place and route C7 Technology NT 13 - Tutorial ISE Página | 35 La opción del proceso de simulación cambia adecuándose a la nueva simulación requerida. Figura 49 - Simulación post place and route Haciendo doble click sobre Simulate Post-Place and Route Model se abre ISim. Es conveniente correr la simulación, y luego expandir las formas de ondas hasta que pueda visualizar algún retardo, tal como se muestra en la siguiente figura. Figura 50 - Simulación post-P&R y medición de retardo (5,65 ns) Uso de Cursores Para la medición de los retardos es necesario el uso de cursores en el panel de simulación. Para insertar el primer cursor solo es necesario hacer un simple click de mouse sobre la C7 Technology NT 13 - Tutorial ISE Página | 36 forma de onda en la cual se desea el cursor. Una vez que el cursor aparece se puede mover a las próximas o anteriores transiciones de la señal por medio del uso de los iconos de próxima transición o transición anterior . Para que aparezca el segundo cursor es necesario, primero posicionar el cursor sobre la forma de onda deseada, luego presionar la tecla <Shift>, y dejando presionado <Shift>, presionar el botón izquierdo del mouse. De ese modo se tienen los dos cursores disponibles para medir retardos o periodos de tiempo. Uso de Marcadores Otro elemento útil en la ventana de simulación es el marcador. Básicamente los marcadores son usados para navegar a lo largo de la forma de onda de simulación y mostrar la simulación en un determinado valor de tiempo. Por ejemplo, se pueden insertar marcadores en los tiempos de simulación 200ns, 555ns, 1233ns, etc, y cuando se necesite ir a uno de esos tiempos solo hace falta seleccionar el marcador respectivo y el simulador saltará y mostrará las formas de ondas centradas en ese tiempo específicamente. Para agregar un marcador, agregar primero el cursor principal presionando el botón izquierdo del mouse en la el tiempo deseado o en la transición deseada. Presionar luego el icono Add Marker . Se pueden agregar tantos marcadores como se necesiten. Para moverse en la ventana de simulación usando los marcadores se pueden usar los iconos de transición de marcadores . Nota: diferencia entre cursores y marcadores (markers): cursores se usan principalmente para mediciones de tiempo, mientras que marcadores son usados para marcar la forma de onda en un tiempo de simulación en particular, facilitando de este modo la navegación de la simulación. Configuración personalizada del ISim ISim tiene varias opciones muy útiles para personalizar la configuración de la ventana de simulación. Detallada información al respecto se puede encontrar en la siguiente nota de aplicación: http://hdl-fpga.blogspot.com.ar/2012/12/personalizando-el-uso-de-isim.html C7 Technology NT 13 - Tutorial ISE Página | 37 Sección 3 - TUTORIAL IMPACT Generación del Archivo de Configuración del FPGA Una vez comprobado el correcto funcionamiento del sistema diseñado mediante la simulación funcional y la simulación post-place&route (esta última es opcional), el último paso para la implementación del sistema en el FPGA es la creación del respectivo archivo de programación conteniendo toda la información para configurar el FPGA. Este archivo se llama bitstream (.bit). Para la generación del archivo .bit, se deben realizar los siguientes pasos: 1. Seleccione el proceso ‘Generate Programming File’. Haga click en el botón derecho del mouse y seleccione Process Properties. Figura 51 - Acceso a las propiedades de archivo de programación del FPGA 2. En Category seleccione Startup Options, y cambie el valor por defecto para FPGA Start-UP Clock (CCLK), por JTAG Clock, tal como muestra Figura 52. Haga click en Apply para aceptar los cambios. Nota: este paso en necesario para la placa Nexys 2, Nexys 3. Si Ud. tiene otra placa consultar el respectivo manual de usuario. C7 Technology NT 13 - Tutorial ISE Página | 38 Figura 52 - Configuración del reloj para programar el FPGA 3. Doble click sobre el proceso ‘Generate Programming File’ (a veces aparece un mensaje preguntando si desea habilitar el envío de información a Xilinx, para sus estadísticas, se sugiere declinar dicha invitación para evitar el flujo de información). Si el archivo de configuración, conocido como bitstream, se genera exitosamente, un check mark verde aparece al costado del proceso, tal como se ve en Figura 53. Figura 53 - Generación exitosa del archivo de programación Programación del FPGA Usando IMPACT Una vez generado del archivo de programación se debe descargar el mismo al FPGA, para ello el ISE tiene una herramienta dedicada llamada IMPACT. Dentro del proceso Configure Target Device, seleccione el proceso Manage Configuration Project (IMPACT), tal como se aprecia en Figura 54. C7 Technology NT 13 - Tutorial ISE Página | 39 Figura 54 - Selección del proceso IMPACT La ventana principal del IMPACT es la mostrada en Figura 55. Figura 55 - Ventana principal de IMPACT Doble click en la opción Boundary Scan. Y luego, en la ventana Boundary Scan, presione botón derecho del mouse y seleccione Initialize Chain. C7 Technology NT 13 - Tutorial ISE Página | 40 Figura 56 - Inicialización de la cadena JTAG en la placa del FPGA a programar El proceso Initialize Chain lleva a cabo un test de los componentes existentes en la cadena JTAG en el board donde se encuentra el FPGA. Al finalizar el test se grafica en esta ventana los dispositivos encontrados en la cadena JTAG del board. Por ejemplo, para el caso del board Nexys 2 la cadena JTAG a mostrarse debe ser similar a la mostrada en la siguiente figura. Figura 57 - Dispositivos presentes en la cadena JTAG en el board Nexys 2 Tal como se aprecia en Figura 57, aparecen dos dispositivos en la cadena JTAG, uno es el FPGA XC3S500E y el otro es la memoria de configuración del FPGA, XCF04S. En este caso vamos a configurar solo el FPGA; para ello seleccionar el FPGA con un simple click del mouse; luego presionar una vez botón derecho del mouse y seleccionar Assign New Configuration File, ver Figura 58. Navegar hasta encontrar el archivo de configuración del FPGA (* .bit), seleccionarlo y presionar Open. Inmediatamente aparecerá una ventana con un mensaje diciendo que el dispositivo, el FPGA, soporta Flash PROMS, si se desea adjuntar una PROM. Por ahora seleccione No. C7 Technology NT 13 - Tutorial ISE Página | 41 Figura 58 - Asignación del archivo .bit al FPGA Si el proceso se ejecuta correctamente el nombre del archivo .bit debe aparecer debajo del FPGA. Volver a presionar el botón derecho sobre el FPGA y ahora seleccionar Program. Una ventana similar a la siguiente aparecerá. Figura 59 - Opciones Program Por defecto aparece seleccionado el FPGA como el dispositivo a ser programado. Presione OK, para comenzar la configuración del FPGA. Si la operación es realizada exitosamente un mensaje similar al de la Figura 60 debe aparecer. Figura 60 - Mensaje de configuración exitosa del FPGA C7 Technology NT 13 - Tutorial ISE Página | 42 De este modo el FPGA en la placa Nexys 2 ha quedado configurado por lo que en el display 7 segmentos debe aparecer la cuenta de 0 a 9, con una duración aproximada de un segundo en cada digito. Cambiando la posición del switch SW0 la cuenta debe cambiar a forma descendente, de 9 a 0. Y presionando el botón BTN0 se inicializa (reset) el sistema. Si todo funciona correctamente Ud. ha finalizado su primer proyecto en FPGA !!! FELICITACIONES C7 Technology NT 13 - Tutorial ISE Página | 43 Sección 4 - Otras Herramientas del ISE Para los que estén interesados en el uso de herramientas más avanzadas se detalla a continuación algunas de las disponibles den el ISE, su forma y propósito de uso. Analyze Post-Place & Rout Static Timing Este proceso se ejecuta haciendo doble click en el proceso Analyse Post-Place & Route Static Timming, tal como se detalla en la siguiente figura. Figura 61 - Ejecución del proceso de análisis estático de tiempo del diseño Los resultados de la ejecución de la herramienta de análisis estático de tiempo se presentan en forma de texto en la pantalla principal, tal como se muestra en Figura 62. A su vez, los caminos críticos se pueden visualizar en el Technology Viewer al presionar botón derecho del mouse, sobre el nombre del camino crítico (Maximun data Path) y seleccionar Show in Technology Viewer, tal como se detalla también en Figura 62. Figura 62 - Selección de la opción de vista del camino crítico C7 Technology NT 13 - Tutorial ISE Página | 44 El resultado de la vista en el Technology Viewer es un circuito esquemático del camino crítico tal como se aprecia en Figura 63. Figura 63 – Detalle en forma de esquemático del camino crítico Esta información a veces es muy importante pues da una idea directa de cuales son los orígenes de los retardos más largos del sistema, y en caso que sea necesario (por ejemplo cuando el retardo es más largo que el periodo mínimo requerido) es posible ver donde se puede ‘acortar’ ese camino crítico para lograr que el sistema funcione a la frecuencia requerida. Más información acerca de este proceso y de los caminos críticos en un sistema digital se puede encontrar en: http://hdl-fpga.blogspot.com.ar/2011/07/frecuencia-maxima-de-un-sistema-digital.html C7 Technology NT 13 - Tutorial ISE Página | 45 FPGA Editor FPGA Editor es una herramienta del entorno ISE que permite ‘ver’ la locación de los distintos elementos lógicos del diseño y su respectivo ruteo dentro del FPGA. Para ejecutar FPGA Editor, se debe primero seleccionar el proceso Place & Route, y luego View/Edit Routed Design (FPGA Editor), tal como detalla Figura 64. Figura 64 - Ejecución del proceso FPGA Editor Figura 65 muestra la pantalla principal del FPGA editor. Tal como se puede apreciar FPGA Editor mostrará una imagen interna del FPGA sobre la ventana principal, llamada Array1, mientras que sobre las ventanas de la derecha de la pantalla muestra en la parte superior una lista de todos los componentes del sistema, List1, y en la inferior un zoom de todo el FPGA, World1. Dentro de la figura en Array 1, los cuadraditos blancos son los SLICEs, mientras que las líneas celeste son líneas de ruteo de interconexión entre los diferentes elementos lógicos del sistema implementado en el FPGA, la línea roja es una de las líneas de interconexión que ha sido seleccionada, en el caso de la Figura 65 es una línea de reloj. En la barra de herramienta hay varios iconos con diferentes funciones, tales como el ícono Sites , Switch Boxes y Routes . Para ver la funcionalidad de cada ícono seleccione uno o más de los íconos y luego presiones el ícono Apply (este ícono queda activo una vez que se presione, es decir no hace falta presionarlo cada vez que se presione un ícono). Puede usar el ícono Zoom rectángulo para marcar el área que desea amplificar. Notar que en la ventana Wordl1 se puede observar cual es la parte amplificada dentro de todo el FPGA. Por ejemplo amplifique la zona donde se encuentra la lógica del diseño implementado en el FPGA usando el ícono Zoom rectángulo . Puede ver cuantos SLICEs son usados en esa parte seleccionada. Seleccione ahora alguno de los SLICEs ocupados por el diseño, estos son los SLICEs rellenos con azul, una vez seleccionado cambian a color rojo. C7 Technology NT 13 - Tutorial ISE Página | 46 Figura 65 - FPGA Editor Los detalles del SLICE seleccionado se muestran en el panel inferior del FPGA Editor, por ejemplo para el caso del SILCE se especifica que tipo de SLICE es el seleccionado (SLICEL/SLICEM), y también cual es la locación del mismo dentro de la matriz de SLICEs del FPGA. Por ejemplo si se muestra “SLICE_X52Y83”, significa que es un SLICEL con locación en la fila 52, columna 83. También dentro de esta información se detalla el nombre del SLICE, dado por la herramienta de Place & Route. Si se hace doble click en el SLICE seleccionado, se abrirá una nueva ventana mostrando todos los recursos disponibles en el SLICE, y cual es la lógica realmente usada del SLICE, detalladas por las líneas de interconexiones celestes. Otra función útil del FPGA Editor es la localización de los pines de E/S del FPGA. Para ello puede ir a un extremo del FPGA, y seleccionar uno de los pines de E/S usados (bloques de azul) con un simple click del mouse. Información del pin es detallada en el panel inferior de la ventana principal. Al hacer doble click en el pin seleccionado se abre una nueva ventana graficando los recursos del bloque de E/S (IOB). C7 Technology NT 13 - Tutorial ISE Página | 47 Apéndice A Descarga e Instalación de ISE WebPack Para todos aquellos que usan FPGAs de Xilinx, Xilinx provee una versión gratis de su software ISE llamado WebPack. El software ISE WebPack puede ser usado para implementar sistemas en FPGAs descrito en VHDL o en Verilog. A continuación se detallan los pasos necesarios para la descarga e instalación del software. Descarga Para la descarga ir al siguiente link: http://www.xilinx.com/support/download/index.html/content/xilinx/en/downloadNav/desi gn-tools.html Se debería acceder a una página similar a la siguiente: Figura 66 – Sitio web de Xilinx para descarga del ISE Verificar que la tabulación ISE Design Tools sea la seleccionada. Nota: como este tutorial está preparado para el uso de placas de FPGAs tipo Spartan 3 y Spartan 6, no se hace uso del software Vivado Design Tools. En la página de descargas seleccione el método de descarga (múltiple archivos, un solo archivo, imagen, etc.) que Ud. desee, y seleccione también el sistema operativo correcto. Tenga en cuenta que el archivo de descarga es bastante grande, unos 6,7 GB. Antes de C7 Technology NT 13 - Tutorial ISE Página | 48 iniciar la descarga Xilinx le va solicitar se registre en su sitio web, o si ya tiene una cuenta, que introduzca los datos correspondientes. Instalación Una vez guardado el archivo descargado, ir al respectivo directorio de descarga, descomprima y ejecute el archivo xsetup.exe. En las primeras ventanas de la instalación, seleccione las opciones que se muestran por defecto, y acepte las condiciones de la licencia. Cuando aparezca la ventana para seleccionar el producto a instalar, seleccione el producto ISE WebPack. Figura 67 – Selección de ISE WebPack para ser instalado Siga las indicaciones y deje las opciones que se presentan por defecto, a menos q Ud. quiera cambiar algo. La instalación toma un largo tiempo. Espere hasta que aparezca un cartel tipo “Install Completed”. C7 Technology NT 13 - Tutorial ISE Página | 49 Figura 68 – Ventana indicando la finalización exitosa de la instalación Instalación de la Licencia Una vez que se termina el proceso de instalación del software, una nueva ventana aparecerá para seleccionar el tipo de licencia que se desea. Seleccione la opción “Vivado/ISE WebPack License”, y presione “Next”. Figura 69 – Selección del tipo de licencia A veces ocurre que luego de presionar “Next”, automáticamente se accede a la página de Xilinx, y una licencia es generada e instalada automáticamente en su PC. Sin embargo, lo más común es que tenga que acceder a la página: https://secure.xilinx.com/webreg/register.do?group=esd_oms&tab=CreateLicense C7 Technology NT 13 - Tutorial ISE Página | 50 En esta ventana debe introducir los datos de su cuenta de Xilinx. Luego aparece una ventana en la que se muestran las licencias registradas a su nombre. Si es la primera vez que instala un software de Xilinx, deberá aparecer una sola licencia en la ventana “Manage Licences”. Haga click en el icono de descarga, que está situado en la esquina izquierda de debajo de la ventana de licencias. Ahora ejecute el software llamado “Manage Xilinx Licences”, que lo encuentra dentro de las opciones de accesorios del software ISE. Figura 70 – Software para administración de licencias Una vez que se abra la ventana de “Manage Xilinx Licenses”, selecciones “Copy”, y navegue hasta el directorio donde descargó la licencia, seleccione el archivo y el software copiará la licencia en el directorio de instalación del ISE WebPack. Finalizado este proceso, ya está todo listo para ejecutar el software ISE WebPack. C7 Technology http://www.c7t-hdl.com Copyright © 2015 All rights reserved C7 Technology NT 13 - Tutorial ISE Página | 51