Академический Документы
Профессиональный Документы
Культура Документы
UNIDAD 5
Arquitectura FPGA
Por la capacidad de un FPGA (el ms sencillo contiene 1,200, hasta los ms grandes
que contienen 4,000,0002 de compuertas lgicas), se dice que son dispositivos para
diseos LSI y VLSI.
1
En el mercado actual, los dispositivos fabricados por Xilinx y por Actel, son los ms utilizados comercialmente segn un estudio realizado por la
IEEE.
2
Dato actualizado hasta el primer semestre del ao 2000. El XCV3200 de Xilinx es el FPGA con mayor capacidad en el mercado.
CIDETEC IPN
Juan Carlos Herrera Lozada jlozada@ipn.mx
Juan Carlos Gonzlez Robles jgrobles@ipn.mx
Tecnologas Programables 23
La gran ventaja de utilizar estos dispositivos radica en que todo el desarrollo se
lleva a cabo en un solo ambiente de trabajo. El diseador propone la funcin lgica a
realizar y en base a mtodos de descripcin define los parmetros de su problema.
Esto se hace por medio de cdigo programable, que puede ser un Lenguaje de
Descripcin de Hardware, o bien, un diagrama esquemtico de conexiones.
Macrocelda de
Entrada / Salida.
Bloque Lgico
Configurable.
Canales de Ruteo
Configurables para
Interconexin.
CIDETEC IPN
Juan Carlos Herrera Lozada jlozada@ipn.mx
Juan Carlos Gonzlez Robles jgrobles@ipn.mx
Tecnologas Programables 26
En el contexto de desarrollo de sistemas empleando FPGAs resulta muy
socorrido el uso de estos conceptos. No redundaremos en stos, nos limitaremos a
aplicarlos en las arquitecturas implicadas.
En el mercado del diseo en FPGAs es muy importante conocer las ventajas que nos
ofrece un dispositivo en relacin al otro. Como resulta obvio, un dispositivo OTP no es
nada conveniente si estamos desarrollando prototipos experimentales, en este caso la
mejor opcin es emplear dispositivos MTPs. Un FPGA OTP, se dice que es un dispositivo
con Lgica No Reconfigurable, debido a que su lgica solamente puede ser
configurada en una sola ocasin. Por el contrario, un FPGA MTP es un dispositivo de
Lgica Reconfigurable.
Los FPGAs de Xilinx y los de Altera son MTP, programndose mediante tecnologa
SRAM, por lo que pueden ser Programados en Sistema, a diferencia de los OTP que se
programan Fuera de Sistema. Debido a que los SRAM necesitan almacenar su
configuracin en RAM, son mdulos voltiles y requieren en ocasiones una memoria
exterior para hacerlo, lo que implica mayor hardware de soporte. As mismo, se trata de
dispositivos ms lentos en comparacin a los OTP, pero con la gran ventaja de que son
completamente Reconfigurables y tienen una mayor capacidad de compuertas
lgicas.
3
Posteriormente comentaremos que Actel fabrica otra clase de dispositivos a los que llama Pro ASICs, los cuales no utilizan una
tecnologa de programacin Antifuses, sino FLASH EEPROM, por lo que resultan reprogramables.
4
Esta ventaja es muy mencionada por Actel y la justifica exponiendo que el sistema donde est empotrado el FPGA puede llegar a
afectar mediante ruido elctrico o algn otro factor, la configuracin del dispositivo; o debido a que el cable que sirve de interfase
de descarga de la configuracin, presente alguna anomala. Sin embargo, de acuerdo a nuestra experiencia personal, no llega a
pasar y son fallas que se pueden prevenir.
CIDETEC IPN
Juan Carlos Herrera Lozada jlozada@ipn.mx
Juan Carlos Gonzlez Robles jgrobles@ipn.mx
Tecnologas Programables 27
Los diseadores coinciden en afirmar que desde el punto de vista usuario,
existen tres fabricantes mayoritarios en la distribucin de FPGAs y software de soporte:
Xilinx, Altera y Actel. En el mercado mundial podemos encontrar otros tantos con
producciones menores pero que figuran tambin como FPGAs tiles: Lucent, Texas
Instruments, Philips, QuickLogic, Cypress, Atmel, etc. En este apartado nos enfocaremos
en los tres principales, dando una breve introduccin a las familias lgicas y sus
caractersticas principales.
5
Llamadas as, simplemente por estar en formato accesible electrnicamente, y no a travs de un libro consultable fsicamente,
como en el caso de un manual tradicional TTL. Adems la distribucin gratuita contiene la misma informacin que Internet en un
Disco Compacto Multimedia con archivos PDF (Acrobat Reader), que tambin incluye el software instalable para leerlos.
CIDETEC IPN
Juan Carlos Herrera Lozada jlozada@ipn.mx
Juan Carlos Gonzlez Robles jgrobles@ipn.mx
Tecnologas Programables 28
Xilinx est considerado como uno de los fabricantes ms fuertes a nivel
mundial. Sus FPGAs (tambin fabrica PLDs y CPLDs) estn basados en la tecnologa
SRAM y son dispositivos MTP, programables en sistema (IS).
Adems de los CLBs, los FPGA de este fabricante incluyen otros bloques complejos
que configuran la entrada de los pines fsicos que conectan el interior del dispositivo
con el exterior, a estos bloques se les llama IOBs (Input/Output Blocks Bloques de
Entrada/Salida). Cada IOB contiene una lgica compleja que permite que un pin
pueda actuar como entrada, salida o un tercer estado.
G1
Gen. H' de configuracin (Downloaded) de la PC
1
EC
RD a la Tarjeta en aprox. 1 segundo.
H G'
Y
Func. H'
S/R
F4 Gen. Control
F3 F
Func. DIN
SD
F2 Gen.
F'
G' D Q
F1 H'
EC
RD
1
H'
X
K
F'
Bloques de E/S
(IOBs)
C LB C LB
Interconexiones S witc h
Ma trix
Programables
C LB C LB
CIDETEC IPN
Juan Carlos Herrera Lozada jlozada@ipn.mx
Juan Carlos Gonzlez Robles jgrobles@ipn.mx
Tecnologas Programables 29
La serie XC Virtex, o tan solo Virtex, es la ms nueva de todas las propias de
Xilinx. Se dice que los dispositivos pertenecientes a esta familia son los ms rpidos
(velocidades de trabajo de hasta 250 Mhz), densos en compuertas y menor consumo
de potencia, pero por lo mismo son los ms costosos.
La tabla 5.1, ilustra una breve comparacin entre familias de Xilinx, tomando como
parmetros de comparacin a la densidad de compuertas lgicas y a los nmeros de
pines configurables como entradas o salidas.
Tabla 5.1. Comparacin de densidad entre las diferentes Familias de FPGAs de Xilinx.
6
Un diseo de bajo impacto, es un circuito digital simple, que no llega a ser un sistema completo. Recordemos que un diseo
pequeo en un FPGA ser grande en comparacin a uno diseado sobre un PLD o algunos CPLDs de poca capacidad.
CIDETEC IPN
Juan Carlos Herrera Lozada jlozada@ipn.mx
Juan Carlos Gonzlez Robles jgrobles@ipn.mx
Tecnologas Programables 30
familias estndar: FLEX 6000, 8000, y 10K; as como la ms novedosa, APEX 20K. Las
primeras familias estndar, la FLEX 6000 y la 8000, an se utilizan ampliamente. La serie
FLEX estndar contiene un nmero considerado de compuertas en tecnologa SRAM
con tablas de bsqueda, agregando mayor flexibilidad a los diseos (FLEX: Flexible
Logic Element Matrix Matriz Flexible de Elementos Lgicos).
Tabla 5.2. Comparacin de densidad entre las diferentes Familias de FPGAs de Altera.
La serie estndar FLEX combina la arquitectura de los CPLDs con los FPGAs. El
dispositivo consiste de una arquitectura muy parecida a la de un CPLD, en la que el
nivel ms bajo de la jerarqua es un conjunto de Tablas de Bsqueda, en lugar de un
bloque muy similar a un SPLD, por lo mismo se considera un FPGA. Por ejemplo, el FLEX
8000 est basado en tecnologa de programacin SRAM, teniendo una tabla de
bsqueda de 4 entradas en su mdulo lgico ms bsico. La figura 5.3, ilustra la
arquitectura general del FLEX 8000. El mdulo lgico bsico, nombrado por Altera,
Elemento Lgico (Logic Element), contiene la LUT de 4 entradas, un flip flop y un
elemento de acarreo (carry) de propsito especial para circuitos aritmticos (similar al
XC4000 de Xilinx). El Elemento Lgico tambin incluye circuitos en cascada que
permiten una implementacin eficiente de funciones AND amplias.
CIDETEC IPN
Juan Carlos Herrera Lozada jlozada@ipn.mx
Juan Carlos Gonzlez Robles jgrobles@ipn.mx
Tecnologas Programables 31
Actel ofrece una serie de familias OTP que resultan ampliamente utilizadas despus
de haber probado satisfactoriamente un diseo (emigrar a otro FPGA). Las principales
son: La serie estndar ACT, y las ms nuevas por orden cronolgico de aparicin, sX, sX
A, mX y la ms reciente, eX. Todas las anteriores son programables fuera del sistema
(OS). Tambin ofrece una familia reprogramable a la que llama Pro ASIC (es de alta
densidad de componentes, y Actel no la considera parte de los FPGAs), basada en
una tecnologa Flash EEPROM programable en sistema (IS).
Los FPGAs de Actel, emplean como mdulo o elemento bsico una estructura tipo
Arreglo Fijo de Compuertas. La figura 5.4, muestra un dispositivo ACT 3, donde podemos
apreciar como la lgica del arreglo est dispuesta en renglones de mdulos lgicos
interconectables, rodeados hacia fuera de la ilustracin por Mdulos de E/S
7
La crossbar de un FPGA de Altera est conformada por varias otras, por lo que resulta muy avanzada, incluyendo mayores
ventajas que la de un CPLD tpico.
CIDETEC IPN
Juan Carlos Herrera Lozada jlozada@ipn.mx
Juan Carlos Gonzlez Robles jgrobles@ipn.mx
Tecnologas Programables 32
(Input/Output Modules). La estructura de interconexiones consiste en pistas o
lneas fijas de interconexin horizontales y verticales con los segmentos de alambrado.
Hay muchas pistas en cada canal entre los renglones de la lgica. Las pistas verticales
son menos y pasan sobre los canales horizontales y los mdulos lgicos.
Una de las principales caractersticas de los mdulos lgicos de los FPGAs de Actel,
es que los mdulos no se programan8 para que efecten una operacin, sino que toda
la programacin se hace mediante antifusibles en las pistas de alambrado.
Dentro de las series antifusibles, la familia eX es la tiene el mejor desempeo, con las
caractersticas ms novedosas, pero en contraparte es la de menor densidad de
compuertas. La serie mX es la que entrega el menor retardo de propagacin entre
todas las familias y fabricantes de FPGAs, combinando la tecnologa antifusibles con las
interconexiones de alta rapidez para alcanzar velocidades de trabajo de hasta 450
Mhz. La serie Pro ASIC de Actel con tecnologa reprogramable EEPROM es la de mayor
8
Recordemos que en un CLB de Xilinx, la funcin lgica a implementar se programa configurando las tablas (LUTs). Mientras que
en un Mdulo de Actel, la funcin es fija, por lo que se dice que son arreglo de lgica o funcin fija.
CIDETEC IPN
Juan Carlos Herrera Lozada jlozada@ipn.mx
Juan Carlos Gonzlez Robles jgrobles@ipn.mx
Tecnologas Programables 33
densidad de componentes, pero ostenta el menor desempeo en comparacin a
los dispositivos de las otras familias.
Tabla 5.3. Comparacin de densidad entre las diferentes Familias de FPGAs de Actel.
UNIDAD 6
CIDETEC IPN
Juan Carlos Herrera Lozada jlozada@ipn.mx
Juan Carlos Gonzlez Robles jgrobles@ipn.mx
Tecnologas Programables 34
Metodologa de Diseo VLSI con Herramientas CAD
Como tal, el uso de un lenguaje formal implica conocer las diferentes apreciaciones
en la programacin lineal y paralela de procesos especficos, no slo como parte del
cdigo de un programa, sino en el algoritmo mismo que por su naturaleza como pieza
de hardware representa arquitecturas seriales o paralelas9, con la intencin de
optimizar resultados aprovechando los recursos disponibles.
9
El estudio de las arquitecturas en hardware, inici tiempo atrs en comparacin con el uso del software para modelar el
funcionamiento de las mismas.
10
El campo de desarrollo de dispositivos VLSI se divide en dos partes: la primera es el diseo de estos dispositivos a nivel sustrato,
es decir, la construccin del circuito integrado como tal. La otra parte hace referencia a la utilizacin de los dispositivos
comercialmente existentes para aplicaciones de usuario, que es el enfoque que se les da en este trabajo.
11
Actualmente es posible disear sobre dispositivos digitales (FPGAs, CPLDs) o sobre analgicos (FPAAs,- Field Programmable
Analog Array Arreglo Analgico Programable en Campo); de cualquier forma, el flujo de diseo es muy similar respetando
algunas restricciones en cuanto a aplicacin y topologa del dispositivo.
CIDETEC IPN
Juan Carlos Herrera Lozada jlozada@ipn.mx
Juan Carlos Gonzlez Robles jgrobles@ipn.mx
Tecnologas Programables 35
de diseo, aumentando la calidad del producto y reduciendo los costos de
produccin.
CIDETEC IPN
Juan Carlos Herrera Lozada jlozada@ipn.mx
Juan Carlos Gonzlez Robles jgrobles@ipn.mx
Tecnologas Programables 36
Figura 6.1. Flujo de desarrollo para ASICs programables, utilizando herramientas VLSI CAD.
1. Captura del diseo (Design Entry). En este paso se procede a la captura del
modelo dentro del ambiente de desarrollo VLSI CAD elegido por el diseador. La
captura puede ser mediante uno (es vlido el uso de varios) de los siguientes medios
que describen el funcionamiento del circuito: diagrama esquemtico, mediante un
Lenguaje de Descripcin de Hardware (HDL Hardware Description Language), o
mediante un Netlist (Archivo de Conexiones). En el caso de la captura de
esquemtico, el software de diseo cuenta con bibliotecas muy extensas de
componentes de uso comn, por lo que slo basta con realizar interconexiones entre
las primitivas12 formando el sistema digital (referirse a la figura 6.2).
12
Una primitiva es una celda lgica bsica, o bien un circuito muy simple formado con elementos muy bsicos; por ejemplo, una
compuerta lgica. Debido a su naturaleza, la primitiva es el elemento que se encuentra en el nivel ms bajo de la jerarqua de
diseo en el VLSI CAD.
CIDETEC IPN
Juan Carlos Herrera Lozada jlozada@ipn.mx
Juan Carlos Gonzlez Robles jgrobles@ipn.mx
Tecnologas Programables 37
Una captura por medio de un HDL tambin culmina con smbolos que se integran es
un diagrama esquemtico. Algunos ambientes, en especial los ms sofisticados,
permiten editar cdigo introduciendo la descripcin del funcionamiento del circuito
por medio de: Tablas de Estado, Diagramas de Estado (con herramienta grfica o
cdigo directo), y Ecuaciones; siguiendo una sintaxis natural. Los editores que
incorporan los diferentes ambientes VLSI CAD admiten cdigo HDL y posteriormente
crean una Macro reutilizable, que es un mdulo esquemtico (simblico) que
representa un componente cuya funcin es especfica. La biblioteca de la macro se
adiciona automticamente a las bibliotecas del software para quedar disponible en el
entorno de la captura esquemtica, pudindose utilizar como elemento
independiente o combinado con las primitivas originales, como se puede observar en
la figura 6.3.
CIDETEC IPN
Juan Carlos Herrera Lozada jlozada@ipn.mx
Juan Carlos Gonzlez Robles jgrobles@ipn.mx
Tecnologas Programables 38
13
La descripcin de Comportamiento o RTL, tiene adems, otra forma de nombrarse: High Level Modules (Mdulos de Nivel Alto),
y hacen referencia a que son mdulos que describen su funcionamiento desde el nivel ms alto de abstraccin, tal y como lo
comentaremos en el apartado 5.2.
CIDETEC IPN
Juan Carlos Herrera Lozada jlozada@ipn.mx
Juan Carlos Gonzlez Robles jgrobles@ipn.mx
Tecnologas Programables 39
La mayora de los diseos complejos (por ejemplo, un microprocesador) se
describen a nivel RTL, en consecuencia a que es ms simple describir un
comportamiento que realizar un diseo componente a componente. La desventaja es
obvia, a nivel compuerta perdemos de cierta forma el control de las acciones,
suponiendo solamente el funcionamiento sin reparar en cmo se est llevando a cabo
y por quin. Hace algunos aos era un verdadero inconveniente; sin embargo, la
evolucin y sofisticacin de las herramientas VLSI CAD, soporta que ahora sean
programadas con algoritmos inteligentes que compilan de la mejor manera un diseo,
dejando a consideracin del diseador si se desea un circuito con restricciones de
velocidad de procesamiento o con restricciones de espacio fsico.
14
Las tareas de Place y Rute, propias de los FPGAs, son conocidas como el Fitter (Ajuste) en el diseo sobre CPLDs.
CIDETEC IPN
Juan Carlos Herrera Lozada jlozada@ipn.mx
Juan Carlos Gonzlez Robles jgrobles@ipn.mx
Tecnologas Programables 40
respetando ciertas consideraciones como las lneas de retardo o las redundancias
en el diseo (componentes o conexiones repetidas).
7. Ruteo (Rutting). Realiza la conexin entre las celdas y los bloques que conforman
los arreglos lgicos.
8. Extraccin (Extraction). Determina la resistencia y capacitancia elctrica, entre las
interconexiones para verificar un correcto ruteo de las lneas. El software de diseo se
encarga automticamente de generar el ruteo y la extraccin de impedancias, sin
embargo, algunas herramientas incluyen editores para realizar las conexiones de modo
personalizado.
Este mtodo parte de una idea en un alto nivel de abstraccin y despus proseguir
la descripcin hacia abajo, incrementando el nivel de detalle segn sea necesario. En
otras palabras, el circuito inicial se divide en diferentes mdulos, cada uno de los
cuales se encuentra a su vez subdividido hasta llegar a los elementos primarios de la
CIDETEC IPN
Juan Carlos Herrera Lozada jlozada@ipn.mx
Juan Carlos Gonzlez Robles jgrobles@ipn.mx
Tecnologas Programables 41
descripcin, siguiendo un flujo descendente (figura 6.4b). No necesariamente se
debe alcanzar un nivel de primitivas, ya que un planteamiento correcto no lo permite.
CIDETEC IPN
Juan Carlos Herrera Lozada jlozada@ipn.mx
Juan Carlos Gonzlez Robles jgrobles@ipn.mx