## 0.1 test

For at sikre, at VHDL-koden virkede som ønsket, er koden testet med programmet ModelSim 10.1b, hvor hvert komponent er testet individuelt samt en integreringstest for 2 af komponenterne.

Koden er testet således, at alle linjer er blevet afprøvet, så der ikke er en en linje der vil sende underlig data ud. Ligeledes er der testet flere scenarier, hvor forskellige værdier sendes til og fra de forskellige komponenter.

Grundet den mængde af data der sendes til ram-modulerne for hver frekvens der ønskes afspillet, at der ikke testet nær det antal der sendes over, men blot enkelte, sekventielle værdier, således selve processen er vist funktionel. Hvis man ønskede at teste for, at alle værdier ville blive skrevet korrekt over vil det tage meget lang tid at verificere, bedst illustreret på figur 1.



Figur 1: Mængden af data der skal overføres (y-akse) for en frekvens (x-akse)

Første test er af komponentet *TransportProtocol*, der står for overførelsen af data fra microcontrolleren til ram-modulerne. Herunder ses et wave-udsnit af *TransportProtocol*'s testbench:

På figur 2 foretages der først et reset af komponentet (0-50 ns), hvorefter der skrives hvor mange samples der kommer (60-70 ns), værdierne skrives med 10 ns mellemrum (70-100 ns). Ved 95 ns bliver den sidste værdi overført og det angives hvor mange samples der er overført. Alt dette skrives til  $ram\_cs\_module0$ .

Efter 160 ns aktiveres CS igen og der skrives én ny værdi til ram-modulet. Denne skrives til  $ram\_cs\_module1$ , hvor  $ram\_cs\_module0$  er deaktiveret.

Der testes ligeledes også når der ikke sendes værdier over – altså hvor der ikke skal



Figur 2: Waveforms for TransportProtocol

afspilles noget.

Komponentet RamAccess lagrer de overførte værdier.



Figur 3: Waveforms for RamAccess

På figur 3 foretages der først et reset på 50 ns, chipselect aktiveres og der skrives til adresse 0 med værdien 3 (60-70 ns). Herefter skrives til adresse 1 med værdien 1 (70-90 ns) og fordi *readAddress* ikke ændres læses værdien fra adresse 0 ud (75-95 ns). Læsningsprocessen gentages fra 95 ns og frem.

Dette viser, at *RamAccess* umiddelbart virker som det skal.

Komponentet PlaySound er en smule mere omfattende og det testes sammen med Ra-mAccess for at opnå det bedste resultat.

Den viste sekvens på figur 4 er på 3,5 microsekunder. Først foretages et reset, for at nulstille alle værdier (0-250 ns), hvorefter der skrives nogle dummy-værdier ind i de to ram-moduler (270-350 ns). Herefter vælges læsning fra ram-modul (250-620 ns) og



Figur 4: Waveforms for *Playsound* og *RamAccess* 

værdierne læses og genlæses indtil ram-modul0 vælges (620-2.170 ns). Det nye antal af værdier der skal læses bliver herefter læst ind (2.170-3.500 ns).

Overstående test viser, at der kan læses fra RamAccess når der ligger data deri, samt den kun afspiller det den bliver bedt om igen og igen.