Verilog es un lenguaje de descripción de hardware (HDL, del Inglés Hardware Description Language) usado para modelar sistemas electrónicos. El lenguaje, algunas veces llamado Verilog HDL, soporta el diseño, prueba e implementación de circuitos analógicos, digitales y de señal mixta a diferentes niveles de abstracción.
Historia
Verilog fue inventado por Phil Moorby en 1985 mientras trabajaba en Automated Integrated Design Systems, más tarde renombrada Gateway Design Automation. El objetivo de Verilog era ser un lenguaje de modelado de hardware. Gateway Design Automation fue comprada por Cadence Design Systems en 1990. Cadence ahora tiene todos los derechos sobre los simuladores lógicos de Verilog y Verilog-XL hechos por Gateway.
Estándar abierto
Con el incremento en el éxito de VHDL, Cadence decidió hacer el lenguaje abierto y disponible para estandarización. Cadence transfirió Verilog al dominio público a través de Open Verilog International, actualmente conocida como Accellera. Verilog fue después enviado a la IEEE que lo convirtió en el estándar IEEE 1364-1995, habitualmente referido como Verilog 95.
Verilog 2001
Extensiones a Verilog 95 fueron enviadas a la IEEE para cubrir las deficiencias que los usuarios habían encontrado en el estándar original de Verilog. Estas extensiones se volvieron el estándar IEEE 1364-2001 conocido como Verilog 2001.
Superlog/System Verilog
El advenimiento de los lenguajes de verificación de alto nivel como OpenVera y el lenguaje E de Verisity, impulsaron el desarrollo de Superlog, por Co-Design Automation Inc. Co-Design fue más tarde comprada por Synopsis. Las bases de Superlog y Vera han sido donadas a Accellera. Todo ello ha sido transformado y actualizado en forma de SystemVerilog, que probablemente se convierta en el próximo estándar de la IEEE.
Las últimas versiones del lenguaje incluyen soporte para modelado analógico y de señal mixta. Todos estos están descritos en Verilog-AMS.
Tipo de Programa
Los diseñadores de Verilog querían un lenguaje con una sintaxis similar a la del lenguaje de programación C, de tal manera que le resultara familiar a los ingenieros y así fuera rápidamente aceptada. El lenguaje tiene un preprocesador como C, y la mayoría de palabras reservadas de control como "if", "while", etc, son similares. El mecanismo de formateo en las rutinas de impresión y en los operadores del lenguaje (y su precedencia) son también similares.
A diferencia del lenguaje C, Verilog usa Begin/End en lugar de llaves para definir un bloque de código. Por otro lado la definición de constantes en Verilog requiere la longitud de bits con su base. Verilog no tiene estructuras, apuntadores o funciones recursivas. Finalmente el concepto de tiempo, muy importante en un HDL, no se encuentra en C.
Estructura
El lenguaje difiere de los lenguajes de programación convencionales, en que la ejecución de las sentencias no es estrictamente lineal. Un diseño en Verilog consiste de una jerarquía de módulos. Los módulos son definidos con conjuntos de puertos de entrada, salida y bidireccionales. Internamente un módulo contiene una lista de cables y registros. Las sentencias concurrentes y secuenciales definen el comportamiento del módulo, describiendo las relaciones entre los puertos, cables y registros. Las sentencias secuenciales son colocadas dentro de un bloque begin/end y ejecutadas en orden secuencial, pero todas las sentencias concurrentes y todos los bloques begin/end son ejecutadas en paralelo en el diseño. Un módulo puede contener una o más instancias de otro módulo para definir un sub-comportamiento.
Un subconjunto de sentencias en el lenguaje es sintetizable. Si los módulos en un diseño contienen sólo sentencias sintetizables, se puede usar software para convertir o sintetizar el diseño en una lista de nodos que describe los componentes básicos y los conectores que deben implementarse en hardware. La lista de nodos puede entonces ser transformada en una forma describiendo las celdas estándar de un circuito integrado, por ejemplo ASIC, o una cadena de bits para un dispositivo de lógica programable (PLD) como puede ser una FPGA o un CPLD.
Este lenguaje nos permite la descripción del diseño a diferentes niveles, denominados niveles de abstracción.
Nivel de puerta.
Nivel de transferencia de registro o nivel RTL.
Nivel de comportamiento (Behavioral level)
Como Diseñar en VERILOG
Mediante la sentencia module se define un módulo y se pueden especificar todos sus detalles. Una vez que se ha definido el módulo se puede utilizar (instanciar, instantiate) cuantas veces sea preciso en un diseño. Cada ejemplar del módulo que se utilice (instance) puede estar conectado con otras instancias de forma distinta y puede tener un nombre diferente.
Cada módulo es una unidad lógica que incluye:
• Una interfaz para su conexión con otros módulos
• Una descripción de su contenido mediante la especificación de su estructura interna (módulos que lo constituyen y su forma de interconexión) o mediante la especificación de su comportamiento
Los módulos se conectan mediante cables (nets) que, junto con los registros (registers) son uno de los tipos de datos que utiliza Verilog.
Las nets modelan una conexión eléctrica entre entidades estructurales (módulos). Existen varios tipos de nets: wire, wire-AND, wire-OR, trireg
Ejemplo
Como Diseñar en VERILOG
Mediante la sentencia module se define un módulo y se pueden especificar todos sus detalles. Una vez que se ha definido el módulo se puede utilizar (instanciar, instantiate) cuantas veces sea preciso en un diseño. Cada ejemplar del módulo que se utilice (instance) puede estar conectado con otras instancias de forma distinta y puede tener un nombre diferente.
Cada módulo es una unidad lógica que incluye:
• Una interfaz para su conexión con otros módulos
• Una descripción de su contenido mediante la especificación de su estructura interna (módulos que lo constituyen y su forma de interconexión) o mediante la especificación de su comportamiento
Los módulos se conectan mediante cables (nets) que, junto con los registros (registers) son uno de los tipos de datos que utiliza Verilog.
Las nets modelan una conexión eléctrica entre entidades estructurales (módulos). Existen varios tipos de nets: wire, wire-AND, wire-OR, trireg
Ejemplo
No hay comentarios:
Publicar un comentario