

# 02321 Hardware/Sofware Programmering

### 3 ugers projekt

#### Udarbejdet af:

Gruppe nr. 1



s093485 - Christensen, Anders Jan



s093478 - Hansen, Mathias



s072657 - Tang Khoa Nguyen, Nikolai



s010164 - Mitri Emil Kjær Rebeiz, Sami



s000536 - Vandall Zimsen, Jakob

**DTU Informatik**Institut for Informatik og Matematisk Modellering

Vejledere: Edward Alexandru Todirica Afleveringsfrist: 21. juni 2011 kl. 13:00 Rapporten indeholder 20 sider inkl. forside

Time regnskab

|        | D 1.       | - ·                               | - 1                     |                     |           |         | T 1.  | 7.0      |
|--------|------------|-----------------------------------|-------------------------|---------------------|-----------|---------|-------|----------|
| Dato   | Deltager   | Design                            | Impl.                   | Test                | Dok.      | Andet   | I alt | Kom-     |
|        |            |                                   |                         |                     |           |         |       | menta-   |
|        |            |                                   |                         |                     |           |         |       | rer      |
| 1-3-11 | Mathias    | 2                                 | 4                       |                     |           |         | 6     | Fær-     |
|        |            |                                   |                         |                     |           |         |       | diggø-   |
|        |            |                                   |                         |                     |           |         |       | relse af |
|        |            |                                   |                         |                     |           |         |       | wiring   |
|        |            |                                   |                         |                     |           |         |       | af rat   |
|        |            |                                   |                         |                     |           |         |       | som      |
|        |            |                                   |                         |                     |           |         |       | input    |
|        |            |                                   |                         |                     |           |         |       | device.  |
| 1-3-11 | Anders     | 2                                 | 4                       |                     |           |         | 6     | Block-   |
| 1-5-11 | Anders     |                                   | <b>T</b>                |                     |           |         | 0     | dia-     |
|        |            |                                   |                         |                     |           |         |       |          |
|        |            |                                   |                         |                     |           |         |       | gram +   |
|        |            |                                   |                         |                     |           |         |       | me-      |
|        |            |                                   |                         |                     |           |         |       | mory     |
| 1-3-11 | Nikolai    | 2                                 | 3                       |                     |           |         | 5     | VGA      |
| 1-3-11 | Jakob      | 2                                 | 4                       |                     |           |         | 6     | VGA      |
| 1-3-11 | Sami       | 2                                 | 3                       |                     |           |         | 5     |          |
| 1-4-11 | Mathias    |                                   | 6                       |                     | 1         | 1       | 8     | Inter-   |
|        |            |                                   |                         |                     |           |         |       | face     |
|        |            |                                   |                         |                     |           |         |       | mellem   |
|        |            |                                   |                         |                     |           |         |       | rat og   |
|        |            |                                   |                         |                     |           |         |       | fpga     |
|        |            |                                   |                         |                     |           |         |       | færdigt  |
| 1-4-11 | Anders     |                                   |                         |                     |           |         | 0     |          |
|        |            |                                   |                         |                     |           |         |       | Syg      |
| 1-4-11 | Nikolai    |                                   | 6                       |                     |           |         | 6     | VGA      |
| 1-4-11 | Sami       |                                   |                         |                     |           |         | 0     | Syg      |
| 1-4-11 | Jakob      |                                   | 8                       |                     |           |         | 8     | Vga og   |
|        |            |                                   |                         |                     |           |         |       | Rat      |
| 1-5-11 | Mathias    | 2                                 | 3                       |                     | 2         | 2       | 9     | Me-      |
|        |            |                                   |                         |                     |           |         |       | mory     |
| 1-5-11 | Anders     | 3                                 | 6                       |                     |           |         | 9     | Me-      |
|        |            |                                   |                         |                     |           |         |       | mory +   |
|        |            |                                   |                         |                     |           |         |       | vga      |
| 1-5-11 | Nikolai    | 2                                 | 2                       |                     | 3         |         | 7     | Port-    |
|        |            |                                   |                         |                     |           |         |       | map-     |
|        |            |                                   |                         |                     |           |         |       | ning +   |
|        |            |                                   |                         |                     |           |         |       | Doku-    |
|        |            |                                   |                         |                     |           |         |       | menta-   |
|        |            |                                   |                         |                     |           |         |       |          |
| 1 - 11 | T 1 1      | 2                                 |                         |                     |           |         | 0     | tion     |
| 1-5-11 | Jakob      | 3                                 | 6                       |                     |           |         | 9     | Vga      |
| 1-5-11 | Sami       | 1                                 | 2                       |                     | 4         | 2       | 9     | Me-      |
|        |            |                                   |                         |                     |           |         |       | mory     |
|        |            |                                   |                         |                     |           |         |       | og       |
|        |            |                                   |                         |                     |           |         |       | rapport  |
| 1-6-11 | Mathias    | 4                                 | 4                       |                     |           |         | 8     | me-      |
|        |            |                                   |                         |                     |           |         |       | mory     |
|        |            |                                   |                         |                     |           |         |       | sam-     |
|        |            |                                   |                         |                     |           |         |       | men      |
|        |            |                                   |                         |                     |           |         |       | med      |
|        | Anders s(  |                                   | G <sub>1</sub>          | uppe nr.            | 1         |         |       | lc3 cpu  |
| 1-6-11 | Anders St  | 9 <del>3485 -<sub>1</sub> s</del> | $072657_{\overline{A}}$ | <del>093478 -</del> | s010164 - | s000536 | 8     | me-      |
| 1 0 11 | 1 11 IUC15 | _ <b>_</b>                        |                         |                     |           |         |       |          |
|        |            |                                   |                         |                     |           |         |       | mory     |
|        |            |                                   |                         |                     |           |         |       | sam-     |

#### Akkumuleret timeregnskab

| Mathias | Anders | Nikolai | Jakob | Sami | Total |
|---------|--------|---------|-------|------|-------|
| 119     | 100    | 81      | 114   | 63   | 477   |

| Rol | lefor | delin | g |
|-----|-------|-------|---|
|     |       |       |   |

Analyse/Design

Lorem ipsum: ?

#### LC3 Implementering

VGA samt ROMs til VGA: Primært udarbejdet af Jakob & Anders

Hukommelse: Primært udarbejdet af Anders & Jakob

Rat I/O: Primært udarbejdet af Mathias

**UART:** Primært udarbejdet af Anders & Jakob

Sprites: Primært udarbejdet af Anders & Jakob & Mathias

#### Spil implementering

Spillogik(Instruktioner til LC3): Primært udarbejdet af Mathias

Hardware(Signaler og objekter): Primært udarbejdet af Jakob & Anders

**Test** 

Lorem ipsum: ?

**Dokumentation** 

Lorem ipsum: ?

# Indholds for tegnelse

| 1 | Design                                 | 3          |
|---|----------------------------------------|------------|
|   | 1.1 Design valg                        | 5          |
|   | 1.1.1 Wrapper                          | 5          |
|   | 1.1.2 Padding                          | 5          |
|   | 1.1.3 Tri State Buffer                 | 5          |
|   | 1.1.4 Chip Selector                    | 6          |
|   | 1.2 Ram                                | 6          |
|   | 1.3 VGA                                | 6          |
|   | 1.4 Rat                                | 6          |
|   | 1.5 DIO4 I/O                           | 6          |
|   | 1.6 UART                               | 7          |
|   | 1.7 Grafik                             | 7          |
|   | 1.8 LC3 Instruktioner                  | 7          |
|   | 1.9 Highscore                          | 7          |
| 2 | Diskussion                             | 8          |
| 3 | Videreudvikling                        | 9          |
|   | 3.1 Hvad vi har nået                   | 9          |
| 4 | Konklusion                             | 10         |
|   | 4.1 ET UDKAST!!!                       | 10         |
| K | Kildehenvisninger                      | 10         |
| В | ilag                                   | <b>A-1</b> |
| F | igurer                                 |            |
|   | 1 Simpelt mock-up over systemet        | 1          |
|   | 2 Videreudviklet mock-up over systemet | 2          |
|   | 1.1 Design system                      | 4          |

### Opgave formulering

| 1.1 Design valg        | • |   |   |   |   | • | • | • |   |   | • |   |   |   | • | • |   | 5 |
|------------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 1.1.1 Wrapper          |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   | 5 |
| 1.1.2 Padding          |   |   | • |   | • |   |   |   |   |   |   |   |   |   |   |   |   | 5 |
| 1.1.3 Tri State Buffer |   |   |   |   | • |   |   |   | • | • |   | • | • |   |   |   |   | 5 |
| 1.1.4 Chip Selector.   | • |   |   | • | • |   | • | • | • | • |   |   |   | • | • | • |   | 6 |
| 1.2 Ram                | • |   |   | • |   | • |   |   | • | • |   |   |   | • |   |   |   | 6 |
| 1.3 VGA                | • | • |   | • | • | • | • | • | • | • | • | • | • | • | • | • |   | 6 |
| 1.4 Rat                | • |   |   | • |   |   |   |   |   |   |   |   |   | • |   |   | • | 6 |
| 1.5 DIO4 I/O           | • |   |   | • |   |   |   |   |   |   |   |   |   | • |   |   | • | 6 |
| 1.6 UART               | • | • |   | • |   |   |   |   |   |   |   |   |   | • |   |   |   | 7 |
| 1.7 Grafik             |   | • |   | • |   |   |   |   | • | • |   |   |   | • |   |   |   | 7 |
| 1.8 LC3 Instruktioner  | • | • |   | • |   |   |   |   |   |   |   |   |   | • |   |   |   | 7 |
| 1.9 Highscore          |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   | 7 |

I dette 3 ugers projekt skal der sammensættes en komplet computer, baseret på von Neumann arkitekturen udfra en udleveret implementeret LC3 CPU, computeren implementeres på et Virtex-II Pro FPGA board.

LC3 Cpu'en er leveret til os som en black box, hvortil vi skal tilslutte de andre nødvendige komponenter for at have en komplet kørende computer; memory, vga samt et rat påsat en A/D-converter som I/O til LC3'en. Et eksternt stykke hardware i form af en skærm er også nødvendig.

Såfremt det bliver nødvendigt, kan der være tale om at dele af spillet implementeres på en almindelig PC og med data sendt over seriel forbindelse til LC3 computeren. Derefter udvikles et spil baseret på den implementerede LC3 computer. Det er valgt at udvikle et bil spil, hvor bilen skal styres af et fysisk rat eller tastatur. Målet med spillet er at

undgå forhindringer i form af andre biler, kasser og lignende som indsættes på kørebanen tilfældigt til forskellige tilfældigt tidpunkt.

På figur 1 ses et simpelt mock-up over hvordan spillet kunne se ud, hvor der er indtegnet en simpel baggrund, en bil man styrer samt forhindringer man skal undgå.



Figur 1.1: Simpelt mock-up over systemet

Afhængigt af tiden op til aflevering, påtænkes der at udvide projektet med en eller flere ekstra tilføjelser. Disse tilføjelser kunne f.eks. være at indsætte flere forskellige forhindringer på vejen, benytte forskellige baggrunde, have flere forskellige baner, lave bedre grafik eller at implementere lyd.

På figur 2 på næste side ses et tænkt videreudviklet mock-up over spillet, hvor points og tid også er vist.



Figur 1.2: Videreudviklet mock-up over systemet

Vores mål og krav er, at implementere et minimum af funktionalitet, som beskrevet i den opgave case som ligger til grund for projektet, inden for den givne tidshorisont. Ikraft af vores roller som udviklere, stiler vi naturligvis efter at lave det bedst kørende simulator spil på den bedst kørende LC3 computer. Tiden er dog en afgørende faktor for, hvor meget vi når at implementere ud over vores minimum krav. Vi påtænker at kode hardwaren i VHDL og spillogik i C.

Desuden er det ønskeligt, at bruge viden fra andre af semesterets kurser til projektet, herunder f.eks. implementering af en database til at gemme spiller navne og highscores i spillet, med henvisning til kurset 02344 OOAD og databaser.

## Design

Vores system som overordnet er beskrevet på figur 1.1 på den følgende side, er opbygget af et FPGA board der implementerer en computer kørt af en LC3 CPU. Til computeren er der af eksterne I/O komponenter tilknyttet en skærm, et I/O board<sup>1</sup> samt et rat som essentielt er en variabel modstand. Desuden benyttes der to-vejs seriel kommunikation til en PC til upload af bruger programmer til LC3 computeren samt verificering af disse.

Spillet er først implementeret på PC i C kode, derefter skal indholdet overføres til FPGA board vha. en serial forbindelse. Indholdet af spillet gemmes i block ram på FPGA. En VGA skærm viser "output"altså baggrund ,forgrund (bil, forhindringer), og er opdateret løbende, for at man kan se og følge med i hvad det sker og dermed kan spille. Spillet kan styres direkte fra FPGA board vha. en styrings enhed, denne er et rat der blevet implementeret.

LC-3 system efter vores design består af forskellige komponenter som er sat sammen, dette kan tælles: CPU, rat, MEM, UART og forbindende "busser".

Udover VGA skærm kan man koble flere hardware enheder til når der er behov for det. De kan være lydkort,... o.s.v. CPU har til formål at udføre de beregninger som ligger til grund for hvilke instruktioner som skal udføres, dvs. hvad applikationen "siger" der skal ske hvornår.... MEM bruges generelt til at gemme div. Data, bl.a. de respektive instruktioner som skal udføres ... UART bruges til at "holde" styr på at sende/modtage data instruktioner til/fra komponenterne i computeren .... rattet bruges til at styre bilen, som kører i forgrunden. Figur xx viser vores overordnede system. (OBS! Vi skal selv tegne LC-3 system diagram som ligner denne figur)

Design valg 2.1

<sup>&</sup>lt;sup>1</sup>Digilent DIO4<sup>TM</sup>I/O board

KAPITEL 2. DESIGN 5



Figur 2.1: Design system

KAPITEL 2. DESIGN

#### 2.1.1 Wrapper

Til LC3 systemet valgtes det at bruge wrappers til de elementer der både har et input og et output, dette gjorte det nemmere at samle padding og tristate buffer. Ved at lave en wrapper kunne der sendes signaler videre ned i LC3 systemet fra bussen.

#### 2.1.2 Padding

Padding er en metode hvorved længden af en bitstreng ændres. Da det var nødvendigt at ændre bus adresse længden i f.eks. UART'en fra en længde på 16 bit ned til 8 bit, da det er den længde UART forventer. Dette gøres ved at når UART wrapperen modtager et signal sender den kun de 8 mindst betydende bit videre ned til UART'en at arbejde med, og når et signal modtages fra UART'en paddes der med 0'er foran, så der bliver sendt et signal tilbage til bussen der er konstrueret således '00000000' og UART signal. Derved ender vi med et signal på 16 bit igen, som er den længde bussen arbejder med.

#### 2.1.3 Tri State Buffer

En tri state buffer fungerer således at der bliver sendt et enable signal der et andet signale angiver om der må skrives eller læses fra et element, og derudover sørger for at hvis det ikke er det element der skal bruge signalet, kun vil modtage Z'er der i et signal er en tom værdi. På denne måde er det muligt at styre hvilke elementer der bliver skrevet og læst fra på en given clock cycle.

#### 2.1.4 Chip Selector

Chip selector gør det muligt at lave en kontrol af hvilke adresse der bliver skrevet til, og igennem et I/O adresse register, er det blevet bestem hvilke værdi der har med hvilke signaler at gøre. Ved at tjekke på denne adresse kan man derved bestemme om et signal til tri state bufferen skal være 1 eller 0.

Ram 2.2

LC3 complete system RAM implementering. Til projektet valgtes det at bruge single-port synchronous RAM. Der blev valgte single-port RAM fordi i første omgang var der ikke brug for at skrive til eller læse fra 2 adresser samtidig, som duel-port RAM ville have givet mulighed for. Synchronous tillader at bruge block rammen på FPGA boardet, og ikke CLBs rammen, der er forbeholdt til logic og asynchronous RAM. Til dette projekt var der ingen grund til at bruge asynchronous, da alle udregningerne ikke behøver at

KAPITEL 2. DESIGN 7

blive behandlet sammen clock cycle. Implementeringen af RAM, skete ved at følge bogen og derefter justere længden af adressen så det passede til den størrelse af det designede program der blev kørt på FPGA'en havde. Ved at reducere størrelsen på rammen, sørgede dette for at syntetiseringen af LC3 systemet ikke tog unødvendig langt tid. Der blev dog løbende ændret på adressen længden af hukommelsen, da C kode blev længere, og krævede en større hukommelse.

Til design af rammen blev der brugt følgende design decisions. Der blev lagt en wrapper omkring rammen for at gøre det nemmere at bruge et andet design decicions nemlig padding. Derudover er benyttet en tri state buffer til at afgøre om der skulle læses eller skrives til rammen.

VGA 2.3

Lorem ipsum dolor...

**Rat** 2.4

Det er valgt at benytte et rat som input

DIO4 I/O 2.5

Lorem ipsum dolor...

UART 2.6

UART er en forkortelse for Universal asynchronous reciever and transmitter. UART blev designet ud fra eksemplet i bogen, UART'en var nødvendig for at kunne uploade c kode på LC3 systemet. Implementeringen af denne var kompliceret, men nødvendig da den blev benyttet til test, om kommunikation mellem RAM og den black box CPU der var stillet til rådighed. Til UART'en var design decicions at pakke den ind i wrapper for at gøre padding nemmere. Der blev benyttet en chip selector til at bestemme hvilke af vores I/O signaler der skulle benyttes.

| KAPITEL 2. | DESIGN |
|------------|--------|
|            |        |

| Grafik            | 2.7 |
|-------------------|-----|
| Lorem ipsum dolor |     |
| LC3 Instruktioner | 2.8 |
| Lorem ipsum dolor |     |
| Highscore         | 2.9 |

Lorem ipsum dolor...

8

### Diskussion

| 3 1         | Hyac   | l vi  | har nået  . |  |   |   |  |   |  |  |   |  |  | C | ) |
|-------------|--------|-------|-------------|--|---|---|--|---|--|--|---|--|--|---|---|
| <b>少</b> ∘」 | LIIVUU | 4 V I | mu muci     |  | • | • |  | • |  |  | • |  |  |   | , |

Under 3 uger arbejdet med projekt, har vi lært og oplevet mange nye tinge. Det tales om både gode og svære tilgang.

De gode: • Vi får implementeret vores advandced/udvidelse version af spillet, og det virker som forventning. Bilens form og farver kan tegnes efter vores vilje, den kan styres fra raten. • Point statistik for hver spiller kan vises på skærm vha. en lokale database. Dette er en ekstra tinges som vi har implementeret ved brug af viden fra kurset OOAD Database. •

De svære: • Det tager meget længere tid at implementere hele computeren system og få dem op at køre end vi regner med i starten. Hardware/Vhld delen tog os 2 uger at blive færdig med. • Især UART og MEM var en udfordring for os at implementere, der ligger masse "tricks" bag i. • Efter implementering af hver komponent, har vi det svært at få dem til at "snakke" sammen med LC-3 CPU, der opstod fejl i forskellige steder i vores program, som tog os ekstrem lang tid at finde rundt og rette dem. • For at nå vores tidsplanlægning om deadline for arbejde er vi nødt til at bruge weekenderne på laboratoriet.

| Videreu | dvikling |
|---------|----------|
|---------|----------|

| 10 | <br> |   |   |   |   |  | 「UDKAST!!! | .1 E | 1 |
|----|------|---|---|---|---|--|------------|------|---|
|    | <br> | • | • | • | • |  |            |      | 4 |

### Hvad vi har nået..

4.1

Vi har nået .... baseret på start vanskeligheder men føler os tilfredse med det produkt vi har udviklet. Vi har ..... komponenter der virker og et kørende/næsten kørende produkt og hvis vi havde haft mere tid ville vi have bygget videre på .... (grafikken, spillet generelt etc). Vi tænker at en version 2 af dette spil kunne være med .... (bedre grafik, flere baner, større DB til yderligere data der skal gemems, bedre statistik over f.eks. hændelser i spillet så som antal "sejre"kontra antal spillede spil.. etc.) En videre udvikling kunne også være .... (bedre boards, bedre komponenter, måske noget med spil over netværk, etc)

### Konklusion

#### ET UDKAST!!!

5.1

Vi har med dette projekt fået en bedre forståelse for sammenspillet mellem hardware og software, hvordan de nødvendige komponenter i LC3'en bruges i samspil med et stykke software - her vores simulator spil. Vi har udviklet os fremadrettet mht. at forstå hvad der egentligt sker på komponent niveau når man bruger en computer, der kører noget software. Vi føler os bedre til at kunne abstrahere på forskellige niveauer mht. at "dykke ned"på/i komponent niveau og få et sådant til at fungere, i sammenspil med et stykke software (her vores simulator spil) og bevæge os op og ned mellem de forskellige abstraktions lag iht. low-level/high-level udvikling. Det har været meget interessant at lave/kode de respektive komponenter(så som memory, VGA.. etc) vi har brugt og derefter få dem til at "snakke"sammen med vores spil. Det har været et meget interessant projekt at gå i krig med, det har givet en meget bedre forståelse for hvad der egentligt sker "inden i"en computer, når man som bruger "bare"sidder foran skærmen og bruger den til div. ting. Vores viden er blevet bredere efter dette projekt. Dog er tidsfaktoren en afgørende faktor for udviklingen af produktet kontra ønskede opnåede mål, vi forestiller os at man ude i erhvervslivet har mere tid til udviklingen, men vi er generelt tilfredse med det vi har nået på den givne tid.. :)

BILAG A-1

Bilag

# **I/O Registers**

.1

| Address | Description                     |
|---------|---------------------------------|
| xFE00   | Stdin Status Register           |
| xFE02   | Stdin Data Register             |
| xFE04   | Stdout Status Register          |
| xFE06   | Stdout Data Register            |
| xFE0A   | Switches Data Register          |
| xFE0E   | Buttons Data Register           |
| xFE12   | 7SegDisplay Data Register       |
| xFE16   | Leds Data Register              |
| xFE18   | Steering Wheel Status Register  |
| xFE1A   | Steering Wheel Data Register    |
| xFE1C   | Car VGA X position              |
| xFE1E   | Obstacle 1 VGA X position       |
| xFE20   | Obstacle 1 VGA Y position       |
| xFE22   | Obstacle 2 VGA X position       |
| xFE24   | Obstacle 2 VGA Y position       |
| xFE26   | Obstacle 3 VGA X position       |
| xFE28   | Obstacle 3 VGA Y position       |
| xFE2A   | VGA Refresh Tick register       |
| xFE2C   | Vibrator register               |
| xFE30   | VGA Road movement data register |

| BILAG      | A-3 |
|------------|-----|
|            |     |
| Kildetekst | .2  |

A-4 BILAG

Indholds for tegnelse

Figurer