Proyecto Trabajo Desarrollo de un reloj en tiempo real

con Nexys 4 v V3023

Grupo

Revisado por: Alfonso Chacón Rodríguez Página Actualizado en: 6/11/2016 Revisado en: 8/11/2016 Diseñadores Keylor Mena Venegas

> Luis Leon Vega Luis Merayo Gatica

1/18

## Resumen

Se debe realizar un controlador para realizar la lectura y escritura del módulo RTC V3023. Los datos del sistema deben poder ser desplegados en un monitor LCD mediante el protocolo VGA. Ante ello, se debe realizar un controlador para el RTC y para la VGA. Asimismo, se deben poder ajustar la hora, activar la alarma y el cronómetro de forma descendente mediante botones e interruptores dispuestos en la FPGA Nexys 4.

## Introduccion

Este proyecto consiste en realizar un controlador de módulos RTC (Real Time Controller), específicamente para el módulo V3023. Este controlador será capaz de escribir y leer dicho módulo para obtener parámetros de reloj, cronómetro y alarma.

Asimismo, para poder desplegar la información relevante de los parámetros anteriores, se conectará un monitor LCD mediante el protocolo VGA. Por otro lado, para poder programar y dar instrucciones al circuito, se deberán usar los botones señalados en el instructivo y algunos interruptores.

Finalmente, el conjunto es un circuito que permita controlar el módulo y comunicar al usuario mediante los botones y el monitor LCD, donde él podrá recibir la información relevante y poder modificar dicha información.

#### Objetivos 1.

- Diseñar un controlador de RTC que permita leerlo y programarlo mediante una interfaz de usuario consistente en botones incorporados dentro de la FPGA (Nexys 4) y un monitor comunicado a través del protocolo VGA.
- Investigar el funcionamiento del módulo RTC y el protocolo de comunicación del mismo.
- Diseñar un controlador para el módulo RTC, cuyo bus de datos y direcciones estén multiplexados.
- Cumplir con las reglas de temporizado del sistema, en especial, con el protocolo de comunicación del módulo RTC.
- Combinar el controlador de RTC con un controlador VGA para poder desplegar la información del módulo al usuario. Este módulo VGA será adaptado del proyecto anterior.
- Desarrollar un banco de pruebas (testbench) para poder emular el comportamiento del módulo RTC con la finalidad de comprobar el funcionamiento del circuito controlador.

#### 2. Descripción del sistema

El sistema se puede dividir en cuatro subsistemas, para facilitar el diseño dividimos el sistema en 4 grandes partes, el controlador de la pantalla, el controlador para el RTC, el control de usuario y una memoria principal. Éstos subsistemas, pueden ser desarrollados de manera separada siempre que se tenga el cuidado necesario con los datos que comparten entre los bloques, para este efecto se desarrollo

| Proyecto      | 1                                     | Página          | 2/18                |
|---------------|---------------------------------------|-----------------|---------------------|
| Trabajo       | Desarrollo de un reloj en tiempo real | Actualizado en: | 6/11/2016           |
|               | con Nexys 4 y V3023                   | Revisado en:    | 8/11/2016           |
| Grupo         | 8                                     | Diseñadores     | Keylor Mena Venegas |
| Revisado por: | Alfonso Chacón Rodríguez              |                 | Luis Leon Vega      |
|               |                                       |                 | Luis Meravo Gatica  |

una memoria con 2 registros que se actualizan entre ellos al activar banderas. En la Fig. 1 se puede observar la composición general del sistema.



Figura 1: Diagrama de modulos principales del sistema.

## 2.1. Controlador de la pantalla

Para el periférico de despliegue de datos se ha solicitado emplear un monitor LCD controlado mediante el protocolo VGA (Video Graphics Array), con la finalidad de aprovechar el desarrollo del proyecto anterior y adaptando algunas cosas para poder incorporar datos dentro de la imagen que se desplegará en el monitor. Este diseño está basado en el mismo implementado para el proyecto anterior, con la salvedad de que, en este diseño, los registros no son actualizados de forma autónoma y son modificados por el microcontrolador PicoBlaze. Esto varía la salida del bus Adr en el diseño anterior y se cambia por el PortID.

### 2.1.1. Diagrama de primer nivel

Para efectos del circuito, este debe admitir datos de las variables del tiempo emitidas por el Picoblaze, que son emitidos por el PortID y el DataOUT del mismo microcontrolador. Para ello, se ha puesto un banco de 16 registros (11 aprovechados) direccionados mediante un bus de direcciones de 4 bits y 8 bits de datos. Asimismo, se deben colocar las entradas y salidas pertinentes del protocolo, que son las salidas de sincronía y las salidas de color. Asimismo, este circuito recibe la señal de IRQ procedente de la RTC para poder señalar el cúlmino de la cuenta del timer.

A como es posible observar en la figura 2, existen dos buses que permiten obtener la información que será desplegada en la pantalla. El bus "PortID" permite direccionar el registro de la memoria de datos

| Proyecto      | 1                                     | Página          | 3/18                |
|---------------|---------------------------------------|-----------------|---------------------|
| Trabajo       | Desarrollo de un reloj en tiempo real | Actualizado en: | 6/11/2016           |
|               | con Nexys 4 y V3023                   | Revisado en:    | 8/11/2016           |
| Grupo         | 8                                     | Diseñadores     | Keylor Mena Venegas |
| Revisado por: | Alfonso Chacón Rodríguez              |                 | Luis Leon Vega      |
|               |                                       |                 | Luis Merayo Gatica  |



Figura 2: Diagrama de primer nivel VGA

al registro que va a ser refrescado y el bus "DataINrecopila la información del registro direccionado mediante "PortID". Esta comunicación es de solo lectura y solo será efectuada durante la sincronía vertical, que no contiene imagen para evitar glitches y cambios en el registro inesperados que vayan a afectar la nitidez de la imagen.

Asimismo, este circuito tiene un bus de salida "DataOUT" que es multiplexado hacia el Picoblaze para avisar de los períodos de sincronía vertical para poder actualizar la VGA.

Para concluir este apartado, la interfaz se definirá mediante imágenes para cargar una interfaz agradable al usuario, esto aprovechando la capacidad de síntesis de memoria ROM en el entorno de Xilinx.

#### 2.1.2. Diagrama de segundo nivel

Adentrando en el diseño, se pueden identificar tres grandes bloques que componen el control de pantalla, donde es posible generar los datos, generar las señales de posición y sincronía y las señales de los colores. Como es posible apreciar en la figura 3, el primer bloque es el de Çontadores y generadores sincronía", que permite generar las señales de sincronización del monitor LCD y, además, generar la posición de la pantalla en la que se ubica el cursor. Esto último es clave para la etapa de "Generador de datos", que decidirá los datos que serán pintados y las memorias que serán consultadas.

El bloque "Generador de datos" permitirá producir las señales de color primitivo (2 bits por color) de la imagen que será pintada en la pantalla con base a los datos que se registren mediante los buses "PortIDz "DataIN", cuyos datos se almacenarán en un buffer de memoria de video. Basado en los datos de este buffer, se determinará el dato que se ilustrará (número) mediante un posicionamiento en memoria. Los datos que saldrán en la dirección serán generados por un contador de 12 dígitos y su proceso de incremento estará condicionado por el VSync para poder actualizar el buffer en momentos de sincronía (Pasado hacia el microcontrolador), donde se no pintan pixeles. Por otro lado, las posiciones de memoria serán determinantes para consultar la memoria ROM que contendrá la interfaz y los números.

Proyecto Página 4/18Trabajo Desarrollo de un reloj en tiempo real Actualizado en: 6/11/2016 con Nexys 4 v V3023 Revisado en: 8/11/2016 Grupo Diseñadores Keylor Mena Venegas Revisado por: Alfonso Chacón Rodríguez Luis Leon Vega

Luis Merayo Gatica



Figura 3: Diagrama de primer nivel VGA

Por otro lado, el Çontrol de salida" permite decodificar el color en 2 bits en 4 bits mediante el duplicado. Asimismo, apaga los bits de salida en caso de entrar en etapa de sincronía, indicado mediante la entrada de "Blank". Esto evitará enviar datos en caso de ubicarse en un proceso de tiempo prohibido en la pantalla.

### 2.1.3. Diagrama de tercer nivel

Profundizando aún más en el diseño, los bloques se pueden descomponer más haciendo evidente la presencia de una memoria ROM que contiene la información de la interfaz gráfica de usuario, que está subdividida en la memoria ROM de interfaz y la memoria ROM de los números, ya que todo el entorno es visual (véase figura 4).

Asimismo, el generador de datos está compuesto por un direccionador de memoria mediante punteros y un banco de registros que ayudan a tener los datos estables para su uso. Dependiendo de la posición del cursor en la pantalla (CntX) y (CntY) y los datos de los registros, es posible direccionar a un campo específico de la memoria ROM de números y hacer el intercambio entre ROM de interfaz y ROM de números.

Por otro lado, se encuentran los contadores y generadores de sincronía, que están compuestos por dos contadores y un bloque combinacional. El primer contador gobierna el conteo horizontal (CntX) y, a su vez, regula la velocidad de conteo descartando los 2 primeros bits menos significativos, por lo cual, el contador es de 12 bits para abarcar las 800 líneas horizontales. Este contador envía una señal de conteo al contador vertical, quien gobierna la posición vertical (CntY). El bloque combinacional permite generar las señales VSync y HSync dependiendo de la magnitud del conteo CntX y CntY, así como, la señal de Blank, donde no debe existir señal de color por encima de 0V.

Proyecto Trabajo Desarrollo de un reloj en tiempo real con Nexys 4 y V3023

Grupo Revisado por: Alfonso Chacón Rodríguez

Página 5/18Actualizado en: 6/11/2016 Revisado en: 8/11/2016 Diseñadores Keylor Mena Venegas Luis Leon Vega

Luis Merayo Gatica



Figura 4: Diagrama de primer nivel VGA



Figura 5: Diagrama de primer nivel VGA

| Proyecto      | 1                                     | Página          | 6/18                |
|---------------|---------------------------------------|-----------------|---------------------|
| Trabajo       | Desarrollo de un reloj en tiempo real | Actualizado en: | 6/11/2016           |
|               | con Nexys 4 y V3023                   | Revisado en:    | 8/11/2016           |
| Grupo         | 8                                     | Diseñadores     | Keylor Mena Venegas |
| Revisado por: | Alfonso Chacón Rodríguez              |                 | Luis Leon Vega      |
|               |                                       |                 | Luis Meravo Gatica  |

El Control de salida permite, a como se explicó en el apartado anterior, expandir los bits de color para poder generar una señal de 12 bits de color. Asimismo, es gobernado por el Blank que pone en ceros todos los bits de color en tiempos de zona prohibida.

Para finalizar, las memorias tienen un dimensionamiento de 307200 espacios de memoria para albergar la interfaz de usuario (640X480) (figura 5) y de 24000 espacios para albergar las imágenes de los números (figura 6). Los datos de estas memorias serán generadas por un script de Matlab y se cargarán mediante un archivo de texto con 6 bits.



Figura 6: Diagrama de primer nivel VGA

Cabe destacar que, la interfaz tiene espacios azules para indicarle al sistema de punteros cuando debe hacer cambio de imagen por un número. Esto se hizo con la finalidad de ahorrar espacio en la Nexys y optimizar el código, ya que existieron problemas debido al rendimiento en tiempo de todo el bloque VGA.

Proyecto **Página** 7/18Trabajo Desarrollo de un reloj en tiempo real Actualizado en: 6/11/2016 con Nexys 4 v V3023 Revisado en: 8/11/2016 Grupo Diseñadores Keylor Mena Venegas Revisado por: Alfonso Chacón Rodríguez Luis Leon Vega Luis Merayo Gatica

#### 2.2. Control de usuario

Para poder controlar el acceso del usuario, que se comunica por medio de 7 botones, 3 interruptores que indican que se quiere cambiar, el reloj, el timer o la alarma, y para moverse entre los registros de datos y aumentar o disminuir sus valores.

### 2.2.1. Diagrama de primer nivel

el control de usuario posee 3 interruptores y 4 botones para que el usuario elija los datos y que desea cambiar. Ademas posee entradas y salidas de memoria para poder alterar los registros y escribirlos en la rtc. Se puede notar esto en la figura 7.



Figura 7: Diagrama de primer nivel del control de usuario.

#### 2.2.2. Diagrama de segundo nivel

En este diagrama mostrado en la Fig. 8 se muestra como se pretende realizar el control de usuario, el cual consiste en tan solo dos bloques.

Consiste un un control de acceso que controla el cambio de los valores de los registros y el control de sus direcciones en el registro. El registro estará en la memoria de coneccion esta memoria controla la actualización de los registros por medio de señales de control, esta es la señal de control, con esta se controla la salida memoria in y memoria out.

### 2.3. Controlador del RTC

Para la implementación de esta interfaz que va a permitir la comunicación entre la FPGA y el RTC, se desarrolló 7 bloques principales divididos en una jerarquía de 3 niveles, se puede ver en la figura 9. Existen 3 bloques principales uno de inicialización, un while true, que permite la lectura continua de los datos de la rtc, y una de programación que permite actualizar los cambios del control de usuario.

Ademas existen 2 bloques que permiten un bloque que permite leer y escribir datos, esta activa un control que esta basado en los tiempos de la figura 10 y la figura 11, como se puede notar existen muchas similitudes entre ambos ciclos, para esto llamaremos a esta diferencia çiclo" de esta manera podemos armar el cuadro de figura 12

| Proyecto      | 1                                     | Página          | 8/18                |
|---------------|---------------------------------------|-----------------|---------------------|
| Trabajo       | Desarrollo de un reloj en tiempo real | Actualizado en: | 6/11/2016           |
|               | con Nexys 4 y V3023                   | Revisado en:    | 8/11/2016           |
| Grupo         | 8                                     | Diseñadores     | Keylor Mena Venegas |
| Revisado por: | Alfonso Chacón Rodríguez              |                 | Luis Leon Vega      |
|               |                                       |                 | Luis Merayo Gatica  |



Figura 8: Diagrama de segundo nivel del Teclado.

Este diagrama muestra los cambios que deben ocurrir según los tiempos del timer dentro del modulo, al llegar el tiempo final saca una bandera indicando el final.



Figura 9: jerarquía de la RTC.

### 2.3.1. nivel 1 control RTC

Para este nivel se requiere la entrada y salida de datos al registro de memoria de coneccion y tiene las salidas necesarias para controlar la RTC, esto se nota en la figura 13.

| Proyecto      | 1                                     | Página          | 9/18                |
|---------------|---------------------------------------|-----------------|---------------------|
| Trabajo       | Desarrollo de un reloj en tiempo real | Actualizado en: | 6/11/2016           |
|               | con Nexys 4 y V3023                   | Revisado en:    | 8/11/2016           |
| Grupo         | 8                                     | Diseñadores     | Keylor Mena Venegas |
| Revisado por: | Alfonso Chacón Rodríguez              |                 | Luis Leon Vega      |
|               |                                       |                 | Luis Merayo Gatica  |

### Ciclo de escritura



Figura 10: Diagrama de tiempos completo del ciclo de escritura.

### Ciclo de lectura



Figura 11: Diagrama de tiempos completo del ciclo de lectura.

Proyecto
Trabajo
Desarrollo de un reloj en tiempo real
con Nexys 4 y V3023
Revisado
Grupo
8 Diseñado

Revisado por: Alfonso Chacón Rodríguez

Página10/18Actualizado en:6/11/2016Revisado en:8/11/2016DiseñadoresKeylor Mena VenegasLuis Leon VegaLuis Merayo Gatica

### Control de salida (ciclo , dato, r, w)

|     | CS | AD    | DS     | WR    | Dato | R1 | W1 |
|-----|----|-------|--------|-------|------|----|----|
| 0   | 1  | ciclo | 1      | 1     | 0    | 0  | 0  |
| 10  | 0  | 1     | ~ciclo | 1     | 0    | 0  | 0  |
| 60  | 0  | 1     | ~ciclo | 1     | Dato | R  | W  |
| 120 | 1  | 1     | ~ciclo | 1     | Dato | R  | W  |
| 140 | 1  | 1     | 1      | ciclo | Dato | R  | W  |
| 150 | 1  | ciclo | 1      | ciclo | 0    | 0  | 0  |

Figura 12: cuadro de tiempos del control de salida.

#### 2.3.2. nivel 2 RTC

Como se menciono antes existen 6 maquina de estados agrupados en 3 jerarquías.

La primera maquina de estados es la de inicializacion, esta tiene un bit de entrada para su inicializacion. Ademas posee salidas de datos y dirección y bits W y R, que siempre están en cero y se conectan a las maquinas de lectura y escritura respectivamente, esto responde al flujo de la figura 14.

La maquina encargada del proceso while true responde al flujo de la figura, esta tiene un bit para la iniciación de la maquina y un bit que indica que finalizo el proceso, de igual manera un bit que indica que la maquina de estados siguiente termino su proceso para que esta salte entre estados y igual que la maquina pasada tiene las señales W y R y la salida de datos y dirección.

Siguiendo la jerarquía, existen 2 maquinas, escritura y lectura, estas respetan los flujos de la figura 15 y 16, estas tienen las entradas de datos y dirección y la señal r y w respectivamente y tiene solo una salida de datos y r y w de esta manera las maquina controla que dato sale, si la dirección y o el dato, ademas tiene el bit de ciclo que determina si esta en el ciclo de escritura o lectura, como se nota en los flujos, el bit de ciclo no depende de la maquina, sino de la parte del programa donde esta se encuentre.

Por ultimo el control de salida responde al cuadro de la figura 12 a este le entra, el bit de activación que sale de la maquina de escritura o lectura, y entran los datos del ciclo y dato que salen dependiendo del tiempo; internamente este tiene un timer, con el fin de llevar el tiempo desde la activación, y dependiendo del tiempo que transcurre genera los cambios de la figura 12.

Proyecto
Trabajo
Desarrollo de un reloj en tiempo real
con Nexys 4 y V3023
Grupo
8

Revisado por:

Página11/18Actualizado en:6/11/2016Revisado en:8/11/2016DiseñadoresKeylor Mena VenegasLuis Leon VegaLuis Merayo Gatica



Alfonso Chacón Rodríguez

Figura 13: nivel 1 del RTC



Figura 14: flujo de datos de la maquina de estados de inicializacion

Proyecto
Trabajo
Desarrollo de un reloj en tiempo real
con Nexys 4 y V3023
Grupo
8

Alfonso Chacón Rodríguez

Revisado por:

Página12/18Actualizado en:6/11/2016Revisado en:8/11/2016DiseñadoresKeylor Mena VenegasLuis Leon VegaLuis Merayo Gatica



Figura 15: flujo de datos de la maquina de lectura



Figura 16: flujo de datos de la maquina de Escritura

**Proyecto** Página 13/18Trabajo Desarrollo de un reloj en tiempo real Actualizado en: 6/11/2016 con Nexys 4 v V3023 Revisado en: 8/11/2016 Grupo Diseñadores Keylor Mena Venegas Revisado por: Alfonso Chacón Rodríguez Luis Leon Vega Luis Merayo Gatica

### 2.4. ROM de Instrucciones

# 3. Datos y resultados

### 3.1. Simulaciones

Para el diseño del controlador VGA, se tenía que verificar el funcionamiento de la misma con respecto a los datos consultados a la memoria de registros de la RTC. Para ello, se ha realizado una simulación para verificar la funcionalidad del controlador VGA. Para este caso, la simulación de comprobación consta de dos partes importantes: la simulación en ISim y la traducción de los datos brindados para graficarlos en un script de Matlab.

Previo a simular, se tomará el punto de decenas en el día, que se encuentra en el punto en Y 130, de acuerdo con la imagen ??. Seguidamente, se verificará el cambio en el script de Matlab en comparativa con los datos que ingresaron e la figura 23.

```
Parametros de punteros
// UbicaciÃ's del punto (1,1)
parameter FechaY1 = 130;
parameter HoraY1 = 288;
parameter IndicadoresY1 = 370;
// Parametros en X
parameter DDavX = 132;
parameter UDayX = 174;
parameter DMonthX = 232;
parameter UMonthX = 274:
parameter DYearX = 416;
parameter UYearX = 458;
parameter DRHourX = 38;
parameter URHourX = 80;
parameter DRMinuteX = 128;
parameter URMinuteX = 170;
parameter DRSecondX = 218;
parameter URSecondX = 260;
parameter DCHourX = 339;
parameter UCHourX = 381;
parameter DCMinuteX = 429;
parameter UCMinuteX = 471;
parameter DCSecondX = 519;
parameter UCSecondX = 561;
parameter ActivadoX = 338;
parameter FinalizadoX = 500;
// UbicaciÃ3n del punto (1,H)
parameter FechaY2 = 190;
parameter HoraY2 = 348;
parameter IndicadoresY2 = 388;
```

Figura 17: Punteros de memoria

Proyecto Página 14/18Trabajo Desarrollo de un reloj en tiempo real Actualizado en: 6/11/2016 con Nexys 4 y V3023 Revisado en: 8/11/2016 Grupo Diseñadores Keylor Mena Venegas Revisado por: Luis Leon Vega Alfonso Chacón Rodríguez Luis Merayo Gatica



Figura 18: Transiciones de datos.



Figura 19: Tiempo de pulso HSync - Se cumple

| Proyecto      | 1                                     | Página          | 15/18               |
|---------------|---------------------------------------|-----------------|---------------------|
| Trabajo       | Desarrollo de un reloj en tiempo real | Actualizado en: | 6/11/2016           |
|               | con Nexys 4 y V3023                   | Revisado en:    | 8/11/2016           |
| Grupo         | 8                                     | Diseñadores     | Keylor Mena Venegas |
| Revisado por: | Alfonso Chacón Rodríguez              |                 | Luis Leon Vega      |
|               |                                       |                 | Luis Merayo Gatica  |



Figura 20: Tiempos en HSync - Porches

### 3.2. Mediciones

Es importante considerar el consumo de potencia de la implementación del diseño en la FPGA y el área ocupada dentro del Artix7, chip de FPGA que trae integrada la FPGA Nexys 4. En la Tabla 1 es posible observar algunos parámetros de consumo de potencia (obtenidos por medio del XPower Analizer) y los recursos brindados por la conclusión de la síntesis:

Cuadro 1: Consumo de recursos de la FPGA

| Recurso         | Consumo                |
|-----------------|------------------------|
| Potencia        | 89mW                   |
| Slices ocupadas | 1 %                    |
| Registros       | ;1 %                   |
| MUX             | 3%                     |
| IO              | 14%                    |
| LUTs lógicos    | 1%                     |
| LUT FF          | 1419                   |
| DSP48E1         | 1 %                    |
| Reloj Máximo    | $111.592 \mathrm{MHz}$ |

Proyecto Página 16/186/11/2016 Trabajo Desarrollo de un reloj en tiempo real Actualizado en: con Nexys 4 y V3023 Revisado en: 8/11/2016 Keylor Mena Venegas Grupo Diseñadores Revisado por: Luis Leon Vega Alfonso Chacón Rodríguez Luis Merayo Gatica



Figura 21: Tiempos en HSync en general

Proyecto Trabajo Desarrollo de un reloj en tiempo real con Nexys 4 y V3023 Grupo

Revisado por:

Alfonso Chacón Rodríguez

Página 17/18Actualizado en: 6/11/2016 Revisado en: 8/11/2016 Diseñadores Keylor Mena Venegas Luis Leon Vega Luis Merayo Gatica



Figura 22: Tiempos en VSync



Figura 23: Tiempos en HSync en general

Página Proyecto 18/18 Trabajo Desarrollo de un reloj en tiempo real Actualizado en: 6/11/2016 con Nexys 4 y V3023 Revisado en: 8/11/2016 Grupo Diseñadores Keylor Mena Venegas Revisado por: Alfonso Chacón Rodríguez Luis Leon Vega Luis Merayo Gatica

- 4. Análisis de datos y resultados
- 5. Hoja de datos de unidades desarrolladas
- 6. Conclusiones y recomendaciones
- 6.1. Conclusiones
- 6.2. Recomendaciones