Documente Academic
Documente Profesional
Documente Cultură
Veracruz
Tabla Comparativa
Microcontroladores
Arquitectura no configurable
Ejecucin de un programa
(firmware)
Lenguaje de bajo nivel (assembler)
Lenguaje de alto nivel (C)
Programar consiste en establecer
las instrucciones para la CPU
DISPOSITIVOS LGICOS
PROGRAMABLES (PLDS)
Equipo No. 5
Barrios Ochoa Joaqun
Crisanto Bez Luis Alfredo
Delgado Chi Mara Daniela
Salinas Ricci Jos Antonio
Introduccin
Un dispositivo lgico programable, o PLD (De sus siglas
Programmable Logic Device), es un dispositivo cuyas
caractersticas pueden ser modificadas y almacenadas
mediante programacin.
La mayora de los PLDs estn formados por una matriz
de conexiones; la cual es una red de conductores
distribuidos en filas y columnas con un fusible en cada
punto de interseccin, mediante la cual se seleccionan
cuales entradas del dispositivo sern conectadas al
arreglo AND cuyas salidas son conectadas al arreglo OR.
Dicha matriz de conexiones esta compuesta
generalmente compuesta por una matriz de compuertas
AND, y una matriz de compuertas OR y en algunos
casos con registros. Las matrices pueden ser fijas o
programables. Con estos recursos se implementan las
funciones lgicas deseadas mediante un software
especial y un programador de dispositivos.
Ejecucin secuencial
Cambia el SW
PLDS
Arquitectura configurable
Configuracin por: Mtodos
tabulares, ecuaciones lgicas.
Lenguajes de alto nivel (HDL
Hardware
Description
Language)
Programar consiste en cambiar
las
conexiones
y
entradas/salidas de la lgica del
dispositivo: se configura
Ejecucin en paralelo
Cambia el HW
FUNCIONALIDAD COMPLETA
La cual se fundamenta en el hecho de que cualquier
funcin lgica se puede realizar mediante una suma de
productos.
CELDAS DE FUNCIONES UNIVERSALES
Tambin denominadas generadores de funciones, son
bloques lgicos configurados para procesar cualquier
funcin lgica, similares en su funcionamiento a una
memoria. En estas celdas se almacenan los datos de
salida del circuito combinacional en vez de implementar
fsicamente la ecuacin booleana.
Macrocelda de un GAL22V10
CPLD
Un CPLD (Complex Programmable Logic Device) extiende el
concepto de un PLD a un mayor nivel de integracin ya que
permite implementar sistemas ms eficientes porque utilizan
menos espacio, mejoran la confiabilidad en el circuito, y
reducen costos. Un CPLD se forma con mltiples bloques
lgicos, cada uno similar a un PLD. Los bloques lgicos se
comunican entre s utilizando una matriz programable de
interconexiones lo cual hace ms eficiente el uso del silicio y
conduce a un mejor desempeo. A continuacin se explican
brevemente las principales caractersticas de la arquitectura de
un CPLD.
MATRIZ DE INTERCONEXIONES
PROGRAMABLES
La matriz de interconexiones programables,
PIM Programmable Interconect Matrix (vase la figura
2.4), permite unir los pines de entrada/salida a las
entradas del bloque lgico, o las salidas del bloque lgico
a las entradas de otro bloque lgico, o inclusive a las
entradas del mismo bloque. La mayora de los CPLDs
usan una de dos configuraciones para esta matriz:
interconexin mediante arreglo o interconexin
mediante multiplexores. La primera se basa en una
matriz de filas y columnas con una celda EECMOS en
cada interseccin. Al igual que en el GAL esta celda
puede ser activada para conectar/desconectar la
correspondiente fila y columna. Esta configuracin
permite una total interconexin entre las entradas y
salidas de los bloques lgicos.
Sin embargo, estas ventajas provocan que disminuya el
desempeo del dispositivo adems de aumentar el
consumo de energa y el tamao del componente. En la
interconexin mediante multiplexores, existe un
BLOQUES LGICOS
Un bloque lgico es muy similar a un PLD, cada uno de
ellos poseen generalmente una matriz de compuertas
AND, una matriz de compuertas OR y una configuracin
para la distribucin de los productos en las diferentes
macroceldas del boque.
El tamao del bloque lgico es una medida de la
capacidad del CPLD, ya que de esto depende el tamao
de la funcin booleana que pueda ser implementada
dentro del bloque. Los bloques lgicos usualmente tienen
de cuatro a veinte macroceldas. La cantidad de bloques
lgicos que puede poseer un CPLD depende de la familia
y fabricante del dispositivo.
DISTRIBUCIN DE PRODUCTOS
Existen pequeas diferencias en cuanto a la distribucin
de los productos en un CPLD, esto depender de la
familia del dispositivo y del fabricante. Obviamente el
tamao de las sumas sigue siendo el factor ms
importante para la implementacin de funciones lgicas.
Pero cada fabricante distribuye los productos de diferente
forma.
La familia MAX de CPLDs que fue desarrollada por
Cypress Semiconductor conjuntamente con Altera
Corporation, siendo los primeros en sacar al mercado
unan familia de CPLDs, Altera la llam MAX5000 y
Cypress por su parte la clasific como MAX340, la
distribucin de productos no es igual a la de un PLD. En
un dispositivo como el 22V10 tenemos que la suma de
productos es fija por cada macrocelda -8, 10, 12, 14 o 16
productos-, en la familia MAX se colocan 4 productos por
macrocelda los cuales pueden ser compartidos con otras
macroceldas. Cuando un producto puede ser nicamente
utilizado por una macrocelda se le conoce como termino
- producto dirigido, y cuando estos pueden ser
utilizados por otras macroceldas se le llama termino
producto compartido. Mediante estos productos
compartidos se mejora la utilizacin del dispositivo, sin
embargo, esto produce un retardo adicional al tener que
Distribucin de Productos en
dispositivos de las familias MAX340 y MAX5000
MACROCELDAS
Las macroceldas de un CPLD son similares a las de un
PLD. Estas tambin estn provistas con registros, control
de polaridad, y buffers para utilizar salidas con alta
impedancia. Por lo general un CPLD tiene macroceldas
de entrada/salida, macroceldas de entrada y
macroceldas internas u ocultas (buried macrocells), en
tanto que un 22V10 tiene solamente macroceldas de
entrada/salida. Una macrocelda interna es similar a una
macrocelda de entrada/salida, slo que esta no puede
ser conectada directamente a una terminal del
dispositivo. La salida de una macrocelda