

**AGSTU****Teknisk rapport**

|                           |                         |              |                                   |
|---------------------------|-------------------------|--------------|-----------------------------------|
| Författare<br>Menyar Hees | Uppgift<br>VGA-prototyp |              |                                   |
| Menyar.hees@gmail.com     | Kontrollerad            | Version<br>1 | Fil<br>Menyar_Hees_vga_controller |

AGSTU

# VGA-kontroller

---

## Validering av VGA-kontroller och VGA-prototyp

**Menyar Hees****2024-12-06**

**Sammanfattning:** Den här rapporten beskriver processen för utveckling, verifiering och validering av en VGA-kontroller. Arbetet innefattar skapandet av en prototyp på FPGA, konstruktion av VHDL-kod, simulering med ModelSim och fysiska tester på DE10-Lite-kortet. Tyngdpunkten ligger på att följa VGA-protokollet och säkerställa korrekt funktionalitet genom testbänkar och verifiering av färgåtergivning.

# Innehållsförteckning

|                                               |    |
|-----------------------------------------------|----|
| Kravspecifikation.....                        | 3  |
| VGA-interfacet på kortet.....                 | 5  |
| Signalbeskrivning.....                        | 5  |
| Funktionalitet.....                           | 5  |
| VGA-protokollet.....                          | 6  |
| Horisontellt svep.....                        | 6  |
| Vertikalt svep.....                           | 6  |
| Testprotokoll.....                            | 7  |
| Verifieringstest (ModelSim).....              | 7  |
| Valideringstest (FPGA).....                   | 7  |
| Konstruktionsbeskrivning.....                 | 8  |
| System arkitektur.....                        | 8  |
| Delsystem.....                                | 8  |
| Klockdelning.....                             | 8  |
| RGB-signaler.....                             | 8  |
| Verifiering.....                              | 9  |
| Testbänk.....                                 | 9  |
| Modelsim.....                                 | 9  |
| Resultat.....                                 | 9  |
| Validering.....                               | 11 |
| Bilder av resultatet.....                     | 11 |
| Resultat av testprotokoll för validering..... | 12 |
| Resultat.....                                 | 13 |
| Bilaga.....                                   | 14 |
| VHDL-fil.....                                 | 14 |
| Do-fil.....                                   | 14 |
| Testbänk.....                                 | 14 |

# Kravspecifikation

Tabell 1. Kravspecifikation från kund.

| Krav id                              | Beskrivning                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Utfört Ja/Nej |
|--------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| <b>Konstruktionskrav</b>             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |               |
|                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Ja            |
| <b>2a</b>                            | Kravspecifikationen är att konstruera en VGA-kontroller, kommentera koden, verifiera med testbänk (före valideringen) och validera koden på DE10-Lite-kortet.                                                                                                                                                                                                                                                                                                                                                | Ja            |
| <b>2b</b>                            | VGA-protokollet ska följas och dela 50 MHz klockan i en process för att få 25 MHz.                                                                                                                                                                                                                                                                                                                                                                                                                           | Ja            |
| <b>2c</b>                            | Antal bitar för färgerna är fritt att välja. Frivilligt att göras generisk.                                                                                                                                                                                                                                                                                                                                                                                                                                  | Ja            |
| <b>Testprotokoll</b>                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |               |
| <b>3</b>                             | Testfall: VGA-protokollets styrsignaler testas med ModelSim. Följande signaler ska verifieras: VGA_HS och VGA_VS.<br>Se bilaga.<br>Validering på FPGA kortet:<br>Testfall 1: Rita en röd fyrkant i övre vänster hörn när KEY(0) trycks ned<br>Testfall 2: Rita en grön fyrkant i nedre vänster hörn när KEY(1) trycks ned<br>Testfall 3: Rita en blå fyrkant i nedre höger hörn när KEY(2) trycks ned<br>Dessa färger ska överlappa varandra och de ska blandas i mitten av skärmen. Se figur 14 i bilaga D. | Ja            |
| <b>VHDL-kod</b>                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |               |
| <b>4</b>                             | Filhuvud, indenterad kod                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Ja            |
| <b>Verifierings-/Valideringskrav</b> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |               |
| <b>5a</b>                            | Verifiera med ModelSim.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Ja            |
| <b>5b</b>                            | Validera på DE1-kortet. Fyll i testprotokollet.                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Ja            |
| <b>6</b>                             | 1) Verifiering, Eget kapitel. <ol style="list-style-type: none"> <li>Testbänken, Teststimuli (som bygger på testprotokollet för programmet)</li> <li>Bilder på resultatet från simuleringen med ModelSim (se bilaga C för exempel)</li> <li>Ifyllt testprotokoll för verifiering</li> </ol> 2) Validering, beskriv resultatet med ett foto. <ol style="list-style-type: none"> <li>Ifyllt testprotokoll för validering (ej samma som verifiering)</li> </ol>                                                 | Ja            |
| <b>Leveranskrav</b>                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |               |
|                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Ja            |



# VGA-interfacet

VGA-gränssnittet på DE10-Lite-kortet används för att ansluta kortet till en skärm via en VGA-kabel. Gränssnittet följer VGA-standarden och innehåller signaler för synkronisering samt överföring av färgdata. Nedan beskrivs de centrala delarna av VGA-gränssnittet på DE10-Lite:

## Synkroniseringssignal

- **VGA\_HS** (Horizontal Sync): Genererar en puls för att synkronisera början av en ny rad. Pulsen definierar det horisontella rasterintervallet.
- **VGA\_VS** (Vertical Sync): Genererar en puls för att synkronisera början av en ny bildruta. Pulsen definierar det vertikala rasterintervallet.

## Färgsignaler

- **VGA\_R[3:0]**: Fyra bitar för röd färgkomponent (nivån av rött i RGB).
- **VGA\_G[3:0]**: Fyra bitar för grön färgkomponent (nivån av grönt i RGB).
- **VGA\_B[3:0]**: Fyra bitar för blå färgkomponent (nivån av blått i RGB).  
Dessa färgsignaler används för att generera en 12-bitars färgpalett som visas på skärmen..

## Funktion och Timing

VGA-signalerna följer ett specifikt timingmönster:

- **Horisontell timing**: Anger längden på en rad inklusive aktiv displaytid, horisontell sync-puls, och vilotid.
- **Vertikal timing**: Anger längden på en bildruta inklusive aktiv displaytid, vertikal sync-puls, och vilotid.

## Beskrivning av VGA-protokollet

VGA-protokollet används för att styra bildskärmar genom horisontella och vertikala synkroniseringssignalerna (VGA\_HS och VGA\_VS) samt RGB-signaler. Protokollet delar upp en bildruta i pixlar, rader och bildramar baserat på följande komponenter:

### Horisontell synkronisering (VGA\_HS)

- **Synkroniseras varje rad.**
- **Består av fyra delar**: Visningsområde, Framre porch, 480 linjer: Synliga data.

## Vertikal synkronisering (VGA\_VS)

- Synkronisera varje bildruta (ram).
- Består av samma fyra delar som den horisontella synkroniseringen men i förhållande till hela bildrutor.

## Pulsdiagram för VGA\_HS och VGA\_VS

Tidsdiagram i relation till horisontella och vertikala räknare (x\_counter och y\_counter):

### 1. VGA\_HS (Horisontell synk)

- **Visningsområde** (x\_counter: 0–639): RGB-data skickas för att rita pixlar.
- **Framre porch** (x\_counter: 640–655): Ingen bilddata, en kort paus.
- **Synkpuls** (x\_counter: 656–751): VGA\_HS sätts till **låg** ('0').
- **Bakre porch** (x\_counter: 752–799): Ingen bilddata, en paus innan nästa rad.

### 2. VGA\_VS (Vertikal synk)

- **Visningsområde** (y\_counter: 0–479): Alla rader i bildrutan visas.
- **Framre porch** (y\_counter: 480–489): Ingen bilddata, en paus.
- **Synkpuls** (y\_counter: 490–491): VGA\_VS sätts till **låg** ('0').
- **Bakre porch** (y\_counter: 492–524): Ingen bilddata innan nästa bildruta.

## Testprotokoll

- **Räknarvärdet:** Simulera upp till hela räckvidden för både x\_counter och y\_counter.
- **Analysverktyg:** Använd ModelSim för att observera **VGA\_HS** och **VGA\_VS** i relation till räknarnas värden i pulsdiagrammet. Se nästa tabell.

Table 1. Testfall för ett testprotokoll som testas i Modilsim

| Testfall | Beskrivning                                                                        | Förutsättningar                               | Förväntat resultat                                                                                   | Status |
|----------|------------------------------------------------------------------------------------|-----------------------------------------------|------------------------------------------------------------------------------------------------------|--------|
| 1        | kontrollera att VGA_HS får korrekt signalnivå vid olika värden av <b>x_counter</b> | Räknarvärdet från 0 till 799 under simulering | - <b>VGA_HS = '1'</b> för x_counter 0–655 och 752–799<br>- <b>VGA_HS = '0'</b> för x_counter 656–751 | Ok     |
| 2        | Kontrollera att VGA_VS får korrekt                                                 | Räknarvärdet från 0 till 524                  | - <b>VGA_VS = '1'</b> för y_counter 0–489 och 492–524                                                | Ok     |

|  |                                                    |                     |                                                |  |
|--|----------------------------------------------------|---------------------|------------------------------------------------|--|
|  | signalnivå vid olika<br>värden av <b>y_counter</b> | under<br>simulering | - <b>VGA_VS = '0'</b> för y_counter<br>490–491 |  |
|--|----------------------------------------------------|---------------------|------------------------------------------------|--|

## Valideringstest (FPGA)

**Testfall 1:** Rita en röd fyrkant i övre vänstra hörnet när KEY(0) trycks ned. Se nästa figur.



Figure 1. Testfall 1

**Testfall 2:** Rita en grön fyrkant i nedre vänstra hörnet när KEY(1) trycks ned. Se nästa figur.



Figure 2. Testfall 2

**Testfall 3:** Rita en blå fyrkant i nedre högra hörnet när KEY(2) trycks ned. Se nästa figur.



# Konstruktionsbeskrivning

## Systemsarkitektur

Systemet består av tre huvudsakliga processer:

- **Klockdelare:** Genererar en 25 MHz klocksignal från den inkommande 50 MHz klockan.
- **Räknare:** Hanterar de horisontella och vertikala räknarna som används för att generera VGA-signaler.
- **Metastabilitetshantering:** Stabilisering av ingångssignalerna genom att använda D-vippor för att undvika metastabilitet.Klockdelning

## Delsystem

- **Klockdelning**  
Klocksignalen delas upp i en process som inverterar klockans tillstånd vid varje stigande flank av den ursprungliga 50 MHz klockan för att skapa en 25 MHz klocka.
- **RGB-signaler**  
RGB-signalerna styrs av de nedtryckta knapparna och representerar färgerna enligt följande:
  - **Röd:** KEY(0)
  - **Grön:** KEY(1)
  - **Blå:** KEY(2)

# Verifiering

## Testbänk

Testbänken är utformad för att simulera VGA-kontrollens funktionalitet. Den innehåller signaler för klocka, återställning och teststimuli (KEY-signaler), samt observerar utgångarna VGA\_HS, VGA\_VS och RGB-signaler (VGA\_R, VGA\_G, VGA\_B). Simuleringen genomfördes i ModelSim för att verifiera att klockdelning, räknare och färgsignaler fungerar som förväntat.

## Modelsim

ModelSim användes för att simulera VGA-kontrollern. Under simuleringen analyserades räknarna **x\_counter** och **y\_counter** för att säkerställa att de räknar korrekt och återställs enligt VGA-timing. Synkroniseringssignalerna **VGA\_HS** och **VGA\_VS** kontrollerades för att bekräfta att de följer de angivna specifikationerna. RGB-signalerna testades genom att aktivera de respektive knapparna och observera simuleringens vågformer.



Figure 3. Plusdiagramet visar HS och VS

