fbpx
Wikipedia

Lógica programada

En electrónica y computación la Lógica programada es un tipo de diseño implementado en chips que permite la reconfiguración de los circuitos con el simple cambio del software que incorpora, es lo contrario de la lógica cableada.

La lógica programada se basa en dispositivos lógicos programables (PLD), los cuales tienen una función no establecida, al contrario que las puertas lógicas que tienen una función fija en el momento de su fabricación. Antes de poder utilizar el PLD en un circuito, este debe ser programado.

El uso de ROMs como PLDs

Antes de que se inventasen las PLDs, los chips de memoria de solo lectura (ROM) se utilizaban para crear funciones de lógica combinacional arbitrarias con un número determinado de entradas. Considerando una ROM con m entradas, a las que se denomina líneas de dirección; y con n salidas, a las que se denomina líneas de datos. Cuando se utiliza como memoria, la ROM contiene   palabras de n bits. Supongamos que las entradas no son direccionadas por una dirección de m-bits, sino por m señales lógicas independientes. Teóricamente, hay   funciones booleanas posibles de estas m señales, pero la estructura de la ROM permite solo producir n de estas funciones en los pines de salida. Por lo tanto, en este caso, la ROM se vuelve un equivalente de n circuitos lógicos separados, cada uno generando una función elegida de las m entradas.

La ventaja de utilizar una ROM de esta forma es que cualquier función concebible de las m entradas puede ser colocada por las n salidas, haciendo este el dispositivo lógico combinacional de mayor propósito general disponible. También las PROMs (ROMs programables), EPROMs (PROMs de borrado por ultravioleta) y EEPROMs (PROMs de borrado eléctrico) disponibles pueden ser programadas de esta manera con un programador PROM hardware o software. Sin embargo, existen varias desventajas:

  • Son bastante más lentas que los circuitos lógicos dedicados.
  • No necesariamente pueden proveer de "protección" ante transiciones lógicas asíncronas.
  • Consumen mayor potencia.
  • Sólo se utiliza una pequeña fracción de su capacidad en una sola aplicación: un uso ineficiente del espacio.
  • Por sí solas no pueden ser utilizadas para circuitos de lógica secuencial, puesto que no contienen biestables. Para realizar algunos circuitos secuenciales (como máquinas de estado) se utilizaba un registro TTL externo.

Las EPROMs comunes (como la 2716), se siguen utilizando a veces de esta forma por gente que tiene como hobby el diseño de circuitos, ya que a menudo tienen algunas sueltas. A las ROM utilizadas de esta manera se las conoce como la "PAL del pobre".

Lógica programable temprana

En 1960, Texas Instruments desarrolló un CI de máscara programable basado en la memoria asociativa de sólo lectura (ROAM) de IBM. Este dispositivo, el TMS2000, era programado alterando la capa metálica durante la producción del CI. El TMS2000 tenía hasta 28 entradas y 1 38 salidas con 19 biestables JK como memoria. Texas Instruments acuño el término Programmable logic array para este dispositivo.

En 1973 National Semiconductor introdujo un dispositivo PLA de máscara programable (DM7575) con 14 entradas y 8 salidas sin registros de memoria. Este era más popular que el de Texas Instruments, pero el coste de hacer la máscara metálica limitaba su uso. El dispositivo es significativo por ser la base de la FPLA (Field Programmable Logic Array) producido por Signetics en 1975, el 82S100.

En 1971, General Electric desarrollaba un PLD basado en la nueva tecnología PROM. Este dispositivo experimental mejoró el ROAM de IBM permitiéndole realizar lógica multinivel. Intel acababa de introducir la PROM de puerta flotante borrable por UV por lo que los desarrolladores en General Electric incorporaron esa tecnología. El dispositivo de General Electric era el primer PLD jamás desarrollado, antecesora del EPLD de Altera en una década. General Electric obtuvo varias patentes tempranas en PLDs.

En 1974, General Electric firmó un acuerdo con Monolithic Memories para desarrollar un PLD de máscara programable incorporando las innovaciones de General. El dispositivo se bautizó como Programmable Associative Logic Array (PALA, matriz lógica asociativa programable). El MMI 5760 fue terminado en 1976 y podía implementar circuitos multinivel o secuenciales de más de 100 puertas. El dispositivo estaba soportado por el entorno de desarrollo de General, donde las ecuaciones Booleanas podían ser convertidas a patrones de máscara para configurar el dispositivo. El integrado nunca se comercializó (hasta ahora debido a lo antes comentado).

PAL

MMI introdujo un dispositivo revolucionario en 1978, la Programmable Array Logic (Matriz lógica programable). La arquitectura era más sencilla que la FPLA de Signetics porque omitía la matriz OR programable. Esto hizo los dispositivos más rápidos, más pequeños y más baratos. Estaban disponibles en encapsulados de 20 pines y DIP de 300 milésimas de pulgada, mientras que las FPLAs venían en encapsulados de 28 pines y DIP de 600 milésimas de pulgada. Ciertas publicaciones sobre PALs desmitificaban el proceso de diseño. El software de diseño PALASM (PAL Assembler, ensamblador PAL) convertía las ecuaciones Booleanas de los ingenieros en el patrón de fusibles requerido para programar el dispositivo. Los PAL de MMI pronto fueron distribuidos por National Semiconductor, Texas Instruments y AMD.

Tras el éxito de MMI con los PAL de 20 pines, AMD introdujo los 22V10 de 24 pines con características adicionales. Tras comprar a MMI (1987), AMD desarrolló una operación consolidada como Vantis, adquirida por Lattice Semiconductor en 1999.

También hay PLAs : Programmable Logic Array.

PLA

Definido en inglés como: "Programmable Logic Array" forma parte de los PLD simples (SPLDs). Estos dispositivos fueron los primeros chips desarrollados específicamente para implementar circuitos lógicos. Como los PAL, anteriormente vistos, disponen de dos planos diferenciados: AND y OR. En este caso, los PLA tienen ambos planos programables lo que hace que su estructura sea ideal para implementar funciones lógicas como sumas de productos, por el contrario hace que el dispositivo tenga mayor tamaño y menor velocidad. Por último existen variantes de este tipo de estructura:

  • Solo plano AND o plano OR
  • Plano AND con reglamentación
  • Plano AND y OR con reglamentación
  • Con registros o registros programables
  • Factores fundamentales de revisión
  • Aplicación de álgebra de Boole.

GALs

 
Lattice GAL 16V8 y 20V8.

Una innovación del PAL fue la matriz lógica genérica (Generic array logic) o GAL. Ambas fueron desarrolladas por Lattice Semiconductor en 1985. Este dispositivo tiene las mismas propiedades lógicas que el PAL, pero puede ser borrado y reprogramado. La GAL es muy útil en la fase de prototipado de un diseño, cuando un fallo en la lógica puede ser corregido por reprogramación. Las GALs se programan y reprograman utilizando un programador OPAL, o utilizando la técnica de programación circuital en chips secundarios.

Un dispositivo similar llamado PEEL (programmable electrically erasable logic o lógica programable eléctricamente borrable) fue introducido por la International CMOS

Funcionamiento del GAL

Una GAL permite implementar cualquier expresión en suma de productos con un número de variables definidas. El proceso de programación consiste en activar o desactivar cada celda E2CMOS con el objetivo de aplicar la combinación adecuada de variables a cada compuerta AND y obtener la suma de productos.
Las celdas E2CMOS activadas conectan las variables deseadas o sus complementos con las apropiadas entradas de las puertas AND. Las celdas E2CMOS están desactivadas cuando una variable o su complemento no se utiliza en un determinado producto. La salida final de la puerta OR es una suma de productos. Cada fila está conectada a la entrada de una puerta AND, y cada columna a una variable de entrada o a su complemento. Mediante la programación se activa o desactiva cada celda E2CMOS, y se puede aplicar cualquier combinación de variables de entrada, o sus complementos, a una puerta AND para generar cualquier operación producto que se desee. Una celda activada conecta de forma efectiva su correspondiente fila y columna, y una celda desactivada desconecta la fila y la columna.

Celdas se pueden borrar y reprogramar eléctricamente. Una celda E2CMOS típica puede mantener el estado en que se ha programado durante 20 años o más. Las macroceldas lógicas de salida (OLMCs) están formadas por circuitos lógicos que se pueden programar como lógica combinacional o como lógica secuencial. Las OLMCs proporcionan mucha más flexibilidad que la lógica de salida fija de una PAL.

CPLDs

Las PALs y GALs están disponibles sólo en tamaños pequeños, equivalentes a unos pocos cientos de puertas lógicas. Para circuitos lógicos mayores, se pueden utilizar PLDs complejos o CPLDs. Estos contienen el equivalente a varias PAL enlazadas por interconexiones programables, todo ello en el mismo circuito integrado. Las CPLDs pueden reemplazar miles, o incluso cientos de miles de puertas lógicas.

Algunas CPLDs se programan utilizando un programador PAL, pero este método no es manejable para dispositivos con cientos de pines. Un segundo método de programación es soldar el dispositivo en su circuito impreso. Las CPLDs contienen un circuito que descodifica la entrada de datos y configura la CPLD para realizar su función lógica específica.

Cada fabricante tiene un nombre propietario para este sistema de programación. Por ejemplo, Lattice Semiconductor la llama In-system programming (Programación en el sistema). Sin embargo, estos sistemas propietarios están dejando paso al estándar del Joint Test Action Group (JTAG).

FPGAs

Mientras el desarrollo de las PALs se enfocaba hacia las GALs y CPLDs (ver secciones superiores), apareció una corriente de desarrollo distinta. Esta corriente de desarrollo desembocó en un dispositivo basado en la tecnología de matriz de puertas y se le denominó field-programmable gate array (FPGA). Algunos ejemplos de las primeras FPGAs son la matriz 82s100 y el secuenciador 82S105 de Signetics, presentados a finales de los 70. El 82S100 era una matriz de términos AND, y también tenía funciones de biestable.

Las FPGAs utilizan una rejilla de puertas lógicas, similar a la de una matriz de puertas ordinarias, pero la programación en este caso la realiza el cliente, no el fabricante. El término field-programmable (literalmente programable en el campo) se refiere a que la matriz se define fuera de la fábrica, o "en el campo".

Las FPGAs se programan normalmente tras ser soldadas en la placa, en una forma similar a los CPLDs grandes. En las FPGAs más grandes, la configuración es volátil y debe ser reescrita cada vez que se enciende o se necesita una funcionalidad diferente. La configuración se guarda normalmente en una PROM o EEPROM. Las versiones EEPROM pueden ser programadas mediante técnicas como el uso de cables JTAG.

Las FPGAs y los CPLDs son buenas opciones para una misma tarea. Algunas veces la decisión sobre una u otra es más económica que técnica, o puede depender de la preferencia personal o experiencia del ingeniero.

Otras variantes

Actualmente, existe bastante interés en sistemas reconfigurables. Estos sistemas se basan en circuitos microprocesadores y contiene algunas funciones prefijadas y otras que pueden ser alteradas por código en el procesador. Para diseñar sistemas que se auto-alteren, es necesario que los ingenieros aprendan nuevos métodos y que nuevas herramientas de software se desarrollen.

Las PLDs que se venden actualmente, contienen un microprocesador con una función prefijada (el núcleo) rodeado con dispositivos de lógica programable. Estos dispositivos permiten a los diseñadores concentrarse en añadir nuevas características a los diseños sin tener que preocuparse de hacer que funcione el microprocesador.

Almacenamiento de la configuración en las PLDs

Una PLD es una combinación de un dispositivo lógico y una memoria. La memoria se utiliza para almacenar el patrón el que se le ha dado al chip durante la programación. La mayoría de los métodos para almacenar datos en un circuito integrado han sido adaptados para el uso en PLDs. Entre estos se incluyen:

Los antifusibles de silicio son elementos de almacenamiento utilizados en las PAL, el primer tipo de PLD. Estos antifusibles se encargan de formar conexiones mediante la aplicación de voltaje en un área modificada del chip. Se le llama antifusibles porque funcionan de manera opuesta a los fusiles normales, los cuales permiten la conexión hasta que se rompen por exceso de corriente eléctrica.

Las SRAM, o RAM estáticas, son un tipo volátil de memoria, lo que quiere decir que su contenido se pierde cada vez que se desconectan. Las PLDs basadas en SRAM tíenen que ser programadas cada vez que el circuito se enciende. Generalmente esto lo hace otra parte del circuito.

Una célula EPROM es un transistor MOS (metal-óxido-semiconductor) que puede activarse atrapando una carga eléctrica permanentemente en su puerta, cosa que realiza un programador PAL. La carga permanece durante algunos años sólo puede ser eliminada exponiendo al chip a una luz ultravioleta fuerte en un dispositivo llamado borrador EPROM.

Las memorias flash son no volátiles, por lo que retienen sus contenidos incluso cuando se les corta la alimentación. Puede ser borradas y reprogramadas tanto como sea necesario, lo que las hace útiles para las memorias PLD.

A partir de 2005, la mayoría de las CPLDs son del tipo EEPROM y no volátiles. Esto se debe a que son demasiado pequeñas para justificar lo poco conveniente que es la programación interna de celdas SRAM cada vez que se inician, y lo costoso de las células EPROM debido a su encapsulado cerámico con una ventana de cuarzo.

Lenguajes de programación de PLDs

Varios dispositivos de programación de PALs admiten la entrada mediante un formato estándar de archivo, denominados comúnmente como 'archivos JEDEC'. Son análogos a los compiladores software. Los lenguajes utilizados como código fuente para compiladores lógicos se denominan lenguajes de descripción de hardware (HDLs).

PALASM y ABEL se utilizan frecuentemente para dispositivos de baja complejidad, mientras que Verilog y VHDL son lenguajes de descripción de hardware de alto nivel muy populares para dispositivos más complejos.

El más limitado ABEL se usa normalmente por razones históricas, pero para nuevos diseños es más popular VHDL, incluso para diseños de baja complejidad.

Véase también

Referencias

  • Jorge (25 de febrero de 2009). «Dispositivos Lógicos Programables (parte 1)». Consultado el 5 de marzo de 2011. 

Enlaces externos


  •   Datos: Q1063837
  •   Multimedia: Programmable logic devices

lógica, programada, electrónica, computación, tipo, diseño, implementado, chips, permite, reconfiguración, circuitos, simple, cambio, software, incorpora, contrario, lógica, cableada, lógica, programada, basa, dispositivos, lógicos, programables, cuales, tiene. En electronica y computacion la Logica programada es un tipo de diseno implementado en chips que permite la reconfiguracion de los circuitos con el simple cambio del software que incorpora es lo contrario de la logica cableada La logica programada se basa en dispositivos logicos programables PLD los cuales tienen una funcion no establecida al contrario que las puertas logicas que tienen una funcion fija en el momento de su fabricacion Antes de poder utilizar el PLD en un circuito este debe ser programado Indice 1 El uso de ROMs como PLDs 2 Logica programable temprana 3 PAL 4 PLA 5 GALs 5 1 Funcionamiento del GAL 6 CPLDs 7 FPGAs 8 Otras variantes 9 Almacenamiento de la configuracion en las PLDs 10 Lenguajes de programacion de PLDs 11 Vease tambien 12 Referencias 13 Enlaces externosEl uso de ROMs como PLDs EditarAntes de que se inventasen las PLDs los chips de memoria de solo lectura ROM se utilizaban para crear funciones de logica combinacional arbitrarias con un numero determinado de entradas Considerando una ROM con m entradas a las que se denomina lineas de direccion y con n salidas a las que se denomina lineas de datos Cuando se utiliza como memoria la ROM contiene 2 m displaystyle 2 m palabras de n bits Supongamos que las entradas no son direccionadas por una direccion de m bits sino por m senales logicas independientes Teoricamente hay 2 m displaystyle 2 m funciones booleanas posibles de estas m senales pero la estructura de la ROM permite solo producir n de estas funciones en los pines de salida Por lo tanto en este caso la ROM se vuelve un equivalente de n circuitos logicos separados cada uno generando una funcion elegida de las m entradas La ventaja de utilizar una ROM de esta forma es que cualquier funcion concebible de las m entradas puede ser colocada por las n salidas haciendo este el dispositivo logico combinacional de mayor proposito general disponible Tambien las PROMs ROMs programables EPROMs PROMs de borrado por ultravioleta y EEPROMs PROMs de borrado electrico disponibles pueden ser programadas de esta manera con un programador PROM hardware o software Sin embargo existen varias desventajas Son bastante mas lentas que los circuitos logicos dedicados No necesariamente pueden proveer de proteccion ante transiciones logicas asincronas Consumen mayor potencia Solo se utiliza una pequena fraccion de su capacidad en una sola aplicacion un uso ineficiente del espacio Por si solas no pueden ser utilizadas para circuitos de logica secuencial puesto que no contienen biestables Para realizar algunos circuitos secuenciales como maquinas de estado se utilizaba un registro TTL externo Las EPROMs comunes como la 2716 se siguen utilizando a veces de esta forma por gente que tiene como hobby el diseno de circuitos ya que a menudo tienen algunas sueltas A las ROM utilizadas de esta manera se las conoce como la PAL del pobre Logica programable temprana EditarEn 1960 Texas Instruments desarrollo un CI de mascara programable basado en la memoria asociativa de solo lectura ROAM de IBM Este dispositivo el TMS2000 era programado alterando la capa metalica durante la produccion del CI El TMS2000 tenia hasta 28 entradas y 1 38 salidas con 19 biestables JK como memoria Texas Instruments acuno el termino Programmable logic array para este dispositivo En 1973 National Semiconductor introdujo un dispositivo PLA de mascara programable DM7575 con 14 entradas y 8 salidas sin registros de memoria Este era mas popular que el de Texas Instruments pero el coste de hacer la mascara metalica limitaba su uso El dispositivo es significativo por ser la base de la FPLA Field Programmable Logic Array producido por Signetics en 1975 el 82S100 En 1971 General Electric desarrollaba un PLD basado en la nueva tecnologia PROM Este dispositivo experimental mejoro el ROAM de IBM permitiendole realizar logica multinivel Intel acababa de introducir la PROM de puerta flotante borrable por UV por lo que los desarrolladores en General Electric incorporaron esa tecnologia El dispositivo de General Electric era el primer PLD jamas desarrollado antecesora del EPLD de Altera en una decada General Electric obtuvo varias patentes tempranas en PLDs En 1974 General Electric firmo un acuerdo con Monolithic Memories para desarrollar un PLD de mascara programable incorporando las innovaciones de General El dispositivo se bautizo como Programmable Associative Logic Array PALA matriz logica asociativa programable El MMI 5760 fue terminado en 1976 y podia implementar circuitos multinivel o secuenciales de mas de 100 puertas El dispositivo estaba soportado por el entorno de desarrollo de General donde las ecuaciones Booleanas podian ser convertidas a patrones de mascara para configurar el dispositivo El integrado nunca se comercializo hasta ahora debido a lo antes comentado PAL EditarMMI introdujo un dispositivo revolucionario en 1978 la Programmable Array Logic Matriz logica programable La arquitectura era mas sencilla que la FPLA de Signetics porque omitia la matriz OR programable Esto hizo los dispositivos mas rapidos mas pequenos y mas baratos Estaban disponibles en encapsulados de 20 pines y DIP de 300 milesimas de pulgada mientras que las FPLAs venian en encapsulados de 28 pines y DIP de 600 milesimas de pulgada Ciertas publicaciones sobre PALs desmitificaban el proceso de diseno El software de diseno PALASM PAL Assembler ensamblador PAL convertia las ecuaciones Booleanas de los ingenieros en el patron de fusibles requerido para programar el dispositivo Los PAL de MMI pronto fueron distribuidos por National Semiconductor Texas Instruments y AMD Tras el exito de MMI con los PAL de 20 pines AMD introdujo los 22V10 de 24 pines con caracteristicas adicionales Tras comprar a MMI 1987 AMD desarrollo una operacion consolidada como Vantis adquirida por Lattice Semiconductor en 1999 Tambien hay PLAs Programmable Logic Array PLA EditarDefinido en ingles como Programmable Logic Array forma parte de los PLD simples SPLDs Estos dispositivos fueron los primeros chips desarrollados especificamente para implementar circuitos logicos Como los PAL anteriormente vistos disponen de dos planos diferenciados AND y OR En este caso los PLA tienen ambos planos programables lo que hace que su estructura sea ideal para implementar funciones logicas como sumas de productos por el contrario hace que el dispositivo tenga mayor tamano y menor velocidad Por ultimo existen variantes de este tipo de estructura Solo plano AND o plano OR Plano AND con reglamentacion Plano AND y OR con reglamentacion Con registros o registros programables Factores fundamentales de revision Aplicacion de algebra de Boole GALs EditarArticulo principal Generic array logic Lattice GAL 16V8 y 20V8 Una innovacion del PAL fue la matriz logica generica Generic array logic o GAL Ambas fueron desarrolladas por Lattice Semiconductor en 1985 Este dispositivo tiene las mismas propiedades logicas que el PAL pero puede ser borrado y reprogramado La GAL es muy util en la fase de prototipado de un diseno cuando un fallo en la logica puede ser corregido por reprogramacion Las GALs se programan y reprograman utilizando un programador OPAL o utilizando la tecnica de programacion circuital en chips secundarios Un dispositivo similar llamado PEEL programmable electrically erasable logic o logica programable electricamente borrable fue introducido por la International CMOS Funcionamiento del GAL Editar Una GAL permite implementar cualquier expresion en suma de productos con un numero de variables definidas El proceso de programacion consiste en activar o desactivar cada celda E2CMOS con el objetivo de aplicar la combinacion adecuada de variables a cada compuerta AND y obtener la suma de productos Las celdas E2CMOS activadas conectan las variables deseadas o sus complementos con las apropiadas entradas de las puertas AND Las celdas E2CMOS estan desactivadas cuando una variable o su complemento no se utiliza en un determinado producto La salida final de la puerta OR es una suma de productos Cada fila esta conectada a la entrada de una puerta AND y cada columna a una variable de entrada o a su complemento Mediante la programacion se activa o desactiva cada celda E2CMOS y se puede aplicar cualquier combinacion de variables de entrada o sus complementos a una puerta AND para generar cualquier operacion producto que se desee Una celda activada conecta de forma efectiva su correspondiente fila y columna y una celda desactivada desconecta la fila y la columna Celdas se pueden borrar y reprogramar electricamente Una celda E2CMOS tipica puede mantener el estado en que se ha programado durante 20 anos o mas Las macroceldas logicas de salida OLMCs estan formadas por circuitos logicos que se pueden programar como logica combinacional o como logica secuencial Las OLMCs proporcionan mucha mas flexibilidad que la logica de salida fija de una PAL CPLDs EditarArticulo principal CPLD Las PALs y GALs estan disponibles solo en tamanos pequenos equivalentes a unos pocos cientos de puertas logicas Para circuitos logicos mayores se pueden utilizar PLDs complejos o CPLDs Estos contienen el equivalente a varias PAL enlazadas por interconexiones programables todo ello en el mismo circuito integrado Las CPLDs pueden reemplazar miles o incluso cientos de miles de puertas logicas Algunas CPLDs se programan utilizando un programador PAL pero este metodo no es manejable para dispositivos con cientos de pines Un segundo metodo de programacion es soldar el dispositivo en su circuito impreso Las CPLDs contienen un circuito que descodifica la entrada de datos y configura la CPLD para realizar su funcion logica especifica Cada fabricante tiene un nombre propietario para este sistema de programacion Por ejemplo Lattice Semiconductor la llama In system programming Programacion en el sistema Sin embargo estos sistemas propietarios estan dejando paso al estandar del Joint Test Action Group JTAG FPGAs EditarArticulos principales FPGAy Field programmable gate array Mientras el desarrollo de las PALs se enfocaba hacia las GALs y CPLDs ver secciones superiores aparecio una corriente de desarrollo distinta Esta corriente de desarrollo desemboco en un dispositivo basado en la tecnologia de matriz de puertas y se le denomino field programmable gate array FPGA Algunos ejemplos de las primeras FPGAs son la matriz 82s100 y el secuenciador 82S105 de Signetics presentados a finales de los 70 El 82S100 era una matriz de terminos AND y tambien tenia funciones de biestable Las FPGAs utilizan una rejilla de puertas logicas similar a la de una matriz de puertas ordinarias pero la programacion en este caso la realiza el cliente no el fabricante El termino field programmable literalmente programable en el campo se refiere a que la matriz se define fuera de la fabrica o en el campo Las FPGAs se programan normalmente tras ser soldadas en la placa en una forma similar a los CPLDs grandes En las FPGAs mas grandes la configuracion es volatil y debe ser reescrita cada vez que se enciende o se necesita una funcionalidad diferente La configuracion se guarda normalmente en una PROM o EEPROM Las versiones EEPROM pueden ser programadas mediante tecnicas como el uso de cables JTAG Las FPGAs y los CPLDs son buenas opciones para una misma tarea Algunas veces la decision sobre una u otra es mas economica que tecnica o puede depender de la preferencia personal o experiencia del ingeniero Otras variantes EditarActualmente existe bastante interes en sistemas reconfigurables Estos sistemas se basan en circuitos microprocesadores y contiene algunas funciones prefijadas y otras que pueden ser alteradas por codigo en el procesador Para disenar sistemas que se auto alteren es necesario que los ingenieros aprendan nuevos metodos y que nuevas herramientas de software se desarrollen Las PLDs que se venden actualmente contienen un microprocesador con una funcion prefijada el nucleo rodeado con dispositivos de logica programable Estos dispositivos permiten a los disenadores concentrarse en anadir nuevas caracteristicas a los disenos sin tener que preocuparse de hacer que funcione el microprocesador Almacenamiento de la configuracion en las PLDs EditarUna PLD es una combinacion de un dispositivo logico y una memoria La memoria se utiliza para almacenar el patron el que se le ha dado al chip durante la programacion La mayoria de los metodos para almacenar datos en un circuito integrado han sido adaptados para el uso en PLDs Entre estos se incluyen antifusibles de silicio SRAMs Celulas EPROM o EEPROM Memoria flash Los antifusibles de silicio son elementos de almacenamiento utilizados en las PAL el primer tipo de PLD Estos antifusibles se encargan de formar conexiones mediante la aplicacion de voltaje en un area modificada del chip Se le llama antifusibles porque funcionan de manera opuesta a los fusiles normales los cuales permiten la conexion hasta que se rompen por exceso de corriente electrica Las SRAM o RAM estaticas son un tipo volatil de memoria lo que quiere decir que su contenido se pierde cada vez que se desconectan Las PLDs basadas en SRAM tienen que ser programadas cada vez que el circuito se enciende Generalmente esto lo hace otra parte del circuito Una celula EPROM es un transistor MOS metal oxido semiconductor que puede activarse atrapando una carga electrica permanentemente en su puerta cosa que realiza un programador PAL La carga permanece durante algunos anos solo puede ser eliminada exponiendo al chip a una luz ultravioleta fuerte en un dispositivo llamado borrador EPROM Las memorias flash son no volatiles por lo que retienen sus contenidos incluso cuando se les corta la alimentacion Puede ser borradas y reprogramadas tanto como sea necesario lo que las hace utiles para las memorias PLD A partir de 2005 la mayoria de las CPLDs son del tipo EEPROM y no volatiles Esto se debe a que son demasiado pequenas para justificar lo poco conveniente que es la programacion interna de celdas SRAM cada vez que se inician y lo costoso de las celulas EPROM debido a su encapsulado ceramico con una ventana de cuarzo Lenguajes de programacion de PLDs EditarVarios dispositivos de programacion de PALs admiten la entrada mediante un formato estandar de archivo denominados comunmente como archivos JEDEC Son analogos a los compiladores software Los lenguajes utilizados como codigo fuente para compiladores logicos se denominan lenguajes de descripcion de hardware HDLs PALASM y ABEL se utilizan frecuentemente para dispositivos de baja complejidad mientras que Verilog y VHDL son lenguajes de descripcion de hardware de alto nivel muy populares para dispositivos mas complejos El mas limitado ABEL se usa normalmente por razones historicas pero para nuevos disenos es mas popular VHDL incluso para disenos de baja complejidad Vease tambien EditarGate array CPLD Matriz de macrocelulas Matriz de logica programable PAL Field programmable gate array FPGA Circuito integrado de aplicacion especifica ASIC Referencias EditarJorge 25 de febrero de 2009 Dispositivos Logicos Programables parte 1 Consultado el 5 de marzo de 2011 Enlaces externos EditarEsta obra contiene una traduccion derivada de Programmable logic device de la Wikipedia en ingles publicada por sus editores bajo la Licencia de documentacion libre de GNU y la Licencia Creative Commons Atribucion CompartirIgual 3 0 Unported Datos Q1063837 Multimedia Programmable logic devicesObtenido de https es wikipedia org w index php title Logica programada amp oldid 131407025, wikipedia, wiki, leyendo, leer, libro, biblioteca,

español

, española, descargar, gratis, descargar gratis, mp3, video, mp4, 3gp, jpg, jpeg, gif, png, imagen, música, canción, película, libro, juego, juegos