## IE0411 – Microelectrónica I – 2020

# Tarea Temporización

18 de mayo de 2020

#### Consideraciones generales:

- La entrega de esta tarea consiste en un informe de resultados, los cuales deben ser debidamente justificados.
- Toda imagen con resultados debe tener una buena calidad y debidamente justificada para ser calificada.
- Se deben entregar todos los ejecutables que comprueben el análisis de resultados.
- Como parte de la solución debe incluir un Makefile con su respectivo README que contenga la forma de ejecutar las pruebas.
- Se castigará severamente cualquier intento o asomo de copia durante el examen o en las soluciones.

## **Especificaciones**

Esta tarea consiste en escribir una descripción conductual del contador usando Verilog. Esta descripción servirá como una especificación detallada y formal del funcionamiento del dispositivo diseñado. Como requisito de diseño deberá utilizar al menos un case en la descripción conductual del contador. El contador deberá tener los siguientes modos de operación:

- Cuenta hacia arriba.
- Cuenta hacia abajo.
- Cuenta de tres en tres hacia abajo.
- Carga en paralelo.

Además del contador se deberá crear una libería de compuertas lógicas dentro del archivo  $cmos\_cells.v$  que deben incluir los siguientes módulos:

- Inversor
- NAND 2 entradas
- NOR 2 entradas
- DFF Flip Flop

Como requisito en la descricpción de la compuertas debe incluir los detalles de temporización utilizando el bloque specify en Verilog. Los tiempos a incluir son:

- Tiempo propagación en alto t<sub>pdh</sub>
- lacktriangle Tiempo propagación en bajo  $t_{pdl}$
- lacktriangle Tiempo de preparación o setup  $t_{setup}$
- Tiempo de sostenimiento o hold thold

Los valores de los tiempos deben de obtenerse de la hoja de datos del fabricante de su elección. Las mismas deben incluirse como bibliografía. El informe debe incluir el valor unitario o del lote por cada componente. Cada estudiante tiene libertad de seleccionar los parámetros como la capacitancia de carga, temperatura, valores mínimos o máximos para escoger sus tiempos de propagación, solamente deben cumplir con que la selección sea uniforme para todas las compuertas. Deberán utilizar una escala de referencia en ns con una precisión en ps en la implementación del código.

Utilice yosys para sintetizar su modelo utilizando la librería  $cmos\_cells.lib$ . Luego, guarde la descripción estructural con el nombre  $contador\_synt.v$  e incluya este contador en su top.v para ser verificado. Como parte del procedimiento debe incluir la librería  $cmos\_cells.v$  en su archivo  $contador\_synt.v$  antes de utilizar icarus verilog.

I – 2020 Tarea Temporización

Utilice la estructura de Testbench diseñado en la tarea 3 para verificar el diseño y el netlist generado con yosys.

Realice dos verificaciones:

- Sin tiempos de propagación.
- Con tiempos de propagación.

Para el segundo caso deberá ejecutar la siguiente línea de comando iverilog -o algo -gspecify algo.v para que se consideren los valores de temporización. Todas las pruebas deben iniciar con un periodo de 2 ns para el reloj. Puede aumentar el periodo al siguiente valor permitido, pero no puede saltar entre periodos no consecutivos si encuentra problemas en su contador, el aumento del periodo deberá justificarse técnicamente. Los valores permitidos para el periodo del reloj son:

- 2 ns
- 4 ns
- 20 ns
- 200 ns

#### Especificación de las entradas del contador

- CLK: entrada de reloj del contador. El flanco activo de la señal CLK es el flanco creciente. Entonces, con cada flanco positivo del reloj el contador cambia de estado dependiendo del estado de las señales de MODO y si la señal ENB = 1.
- 2. **ENB**: entrada de habilitación del contador. Si ENB = 1, el contador funciona normalmente respondiendo a los flancos activos de CLK para cambiar de estado de acuerdo a la señal MODO. Si ENB = 0, el contador mantiene su estado actual sin importar los flancos de CLK.
- 3. **D[3:0]**: entrada de datos D consta de cuatro líneas. El valor que tengan las entradas D[3:0] será almacenado en Q[3:0] en el flanco activo de CLK si ENB = 1 y MODO = 11.
- 4. **MODO[1:0]**: entrada de modo que consta de dos líneas y sirve para definir cuál será el próximo estado del contador al llegar el flanco activo del reloj en la entrada CLK. Si el contador se encuentra en el estado Q antes del flanco activo del reloj, luego del flanco activo, su estado será:
  - MODO = 00 -> Q + 1
  - MODO = 01 -> Q 1
  - MODO = 10 > Q 3
  - MODO = 11 -> D

# Especificación de las salidas del contador

- Q[3:0]: salida Q que consta de cuatro líneas que indican el estado presente del contador. El estado del contador cambia con el flanco activo de la señal CLK mientras ENB = 1 y de acuerdo con el modo seleccionado con las líneas MODO[1:0].
- 2. RCO: salida de llevo "Ripple-Carry Out" que indica cuándo el contador llega a su cuenta límite para que la siguiente etapa, en contadores de más de 4 bits, se habilite para que realice su actualización de estado. RCO se debe poner en 1 cuando el MODO = 11 está activo.

#### **Consideraciones**

1. El contador no tiene un estado inicial de cuenta, por lo tanto se debe seleccionar el MODO = 11 antes de cualquier otro modo de cuenta.