

### IoB VGA picture controller

-Electronic Systems of Computers-

**Authors:** Daniel David Proaño Guevara - 101229

Pedro Gonçalo da Silva Faria – 102272

**Professor:** Prof. José João Henriques Teixeira de Sousa



- Uses silicon instead of uP power
  - VGA driver
  - 7-segment driver
- Compliant with IoB modules structure
- Allows the selection between 2 pre-loaded images





#### **Other works**

VGA on FPGA is a vastly known issue commonly used for academic purposes

Ramos-Arregu'n [1] proposes a modification to the architecture presented by Digilent for its development boards by generating the pixel coordinate and a pixel enable signal used to display it or not.

The main flaw detected is the generation of a secondary clock in the system that can cause clock domain crossing or delays.





# Top system organization

Developed submodules:

VGA Controller 7 Segment Display Controller Image memory





### TÉCNICO Seven Segments Controller (SSD)



- Software functions
  - ssd\_init: sets the base address and the refresh frequency
  - ssd\_set\_number: writes to the software-accessible register 'data\_in'



- Software functions
  - im\_init: sets the base address
  - im\_set: writes to the software-accessible register 'isel'









#### **VGA**

The module complies with the VESA VGA standards as follows:

| Constants    | Horizontal | Vertical |
|--------------|------------|----------|
| Refresh Rate | @60Hz      |          |
| Image Clock  | @25MHz     |          |
| Total Frame  | 800        | 525      |
| Sync Pulse   | 96         | 2        |
| Front Porch  | 16         | 10       |
| Visible Area | 640        | 480      |
| Back Porch   | 48         | 33       |





- Simple commuter.
  - Detects changes in the inputs and selects a corresponding image.

```
while(1) {
g_input = gpio_get();
if(g_input != g_input_old) {
 if(g_input == 0)
      im set(0);
       ssd_set_number(0x0001);
       printf("\nImage: 0\n");
 } else {
      im_set(1);
       ssd set number(0x0002);
       printf("\nImage: 1\n");
  g_input_old = g_input;
```



#### **Demonstration**

The system has a general testbench.

All the submodules have their own dedicated testbench.







The greatest difficulty for video management in IoB\_SoC is the storage space available, severely capping the system's capabilities.



To generate video, it is suggested to use external memory or buffer a segment of the image in a dual-clock FIFO.



It is demonstrated with this application that the uC serves a better purpose in managing IP than complex computing.

### TÉCNICO Future works







## Questions?