

# Niskopoziomowa emulacja sprzętowa implementacja architektury systemowej konsoli Game Boy

Patryk Michalak

20 lutego 2026

## **Streszczenie**

Your abstract.

# Spis treści

|                                                                         |           |
|-------------------------------------------------------------------------|-----------|
| <b>1 Wstęp</b>                                                          | <b>4</b>  |
| 1.1 Opis problemu . . . . .                                             | 4         |
| 1.2 Emulatory . . . . .                                                 | 4         |
| 1.3 Założenia i cel pracy . . . . .                                     | 4         |
| 1.4 Grupa docelowa . . . . .                                            | 5         |
| <b>2 Analiza architektury systemowej konsoli Game Boy</b>               | <b>5</b>  |
| 2.1 Specyfikacja techniczna . . . . .                                   | 5         |
| 2.2 Procesor i SoC . . . . .                                            | 5         |
| 2.2.1 Model czasowy systemu . . . . .                                   | 5         |
| 2.3 Zestaw Instrukcji . . . . .                                         | 6         |
| 2.3.1 Instrukcje transferu danych . . . . .                             | 6         |
| 2.3.2 Instrukcje arytmetyczne . . . . .                                 | 6         |
| 2.3.3 Instrukcje logiczne i bitowe . . . . .                            | 8         |
| 2.3.4 Instrukcje przesunięć i rotacji . . . . .                         | 8         |
| 2.3.5 Instrukcje sterowania przepływem programu . . . . .               | 8         |
| 2.4 Mapowanie pamięci w konsoli Game Boy . . . . .                      | 8         |
| 2.4.1 Ogólny układ przestrzeni adresowej . . . . .                      | 9         |
| 2.4.2 Pamięć programu i bankowanie ROM . . . . .                        | 9         |
| 2.4.3 Pamięć wideo . . . . .                                            | 9         |
| 2.4.4 Pamięć robocza i obszar echo . . . . .                            | 9         |
| 2.4.5 Mapowanie urządzeń wejścia/wyjścia . . . . .                      | 9         |
| 2.4.6 Pamięć wysokiej prędkości . . . . .                               | 9         |
| 2.4.7 Znaczenie architektury mapowania pamięci . . . . .                | 9         |
| 2.5 System przerwań w konsoli Game Boy . . . . .                        | 10        |
| 2.5.1 Źródła przerwań . . . . .                                         | 10        |
| 2.5.2 Rejestry sterujące systemem przerwań . . . . .                    | 10        |
| 2.5.3 Mechanizm obsługi przerwania . . . . .                            | 10        |
| 2.5.4 Priorytety przerwań . . . . .                                     | 10        |
| 2.5.5 Rola systemu przerwań w architekturze konsoli . . . . .           | 11        |
| 2.6 Płyta główna . . . . .                                              | 11        |
| 2.6.1 Jednostka centralna . . . . .                                     | 11        |
| 2.6.2 Pamięć operacyjna i pamięć wideo . . . . .                        | 11        |
| 2.6.3 Układ graficzny . . . . .                                         | 12        |
| 2.6.4 Układ dźwiękowy . . . . .                                         | 12        |
| 2.6.5 Interfejs kartridżu . . . . .                                     | 12        |
| 2.6.6 Układy wejścia i wyjścia . . . . .                                | 12        |
| 2.7 Kartridże systemu Game Boy . . . . .                                | 12        |
| 2.7.1 Kartridże bez kontrolera banków pamięci (ROM Only) . . . . .      | 12        |
| 2.7.2 Kartridże z kontrolerem MBC1 . . . . .                            | 13        |
| 2.7.3 Kartridże z kontrolerem MBC2 . . . . .                            | 13        |
| 2.7.4 Kartridże z kontrolerem MBC3 . . . . .                            | 13        |
| 2.7.5 Kartridże z kontrolerem MBC5 . . . . .                            | 13        |
| 2.7.6 Kartridże specjalizowane . . . . .                                | 13        |
| 2.7.7 Struktura fizyczna kartridżu . . . . .                            | 13        |
| <b>3 Model działania systemu Game Boy</b>                               | <b>14</b> |
| 3.1 Cykl pracy procesora . . . . .                                      | 14        |
| 3.1.1 Model cyklu rozkazowego . . . . .                                 | 14        |
| 3.1.2 Synchronizacja z zegarem systemowym . . . . .                     | 14        |
| 3.1.3 Dostęp do pamięci i operacje magistrali . . . . .                 | 14        |
| 3.1.4 Obsługa przerwań . . . . .                                        | 14        |
| 3.1.5 Znaczenie cyklu pracy dla działania systemu . . . . .             | 14        |
| 3.2 Magistrala pamięciowa i charakterystyka działania pamięci . . . . . | 15        |
| 3.2.1 Organizacja magistrali pamięciowej . . . . .                      | 15        |
| 3.2.2 Mapowanie przestrzeni adresowej . . . . .                         | 15        |
| 3.2.3 Rodzaje pamięci w systemie . . . . .                              | 15        |
| 3.2.4 Charakterystyka operacji pamięciowych . . . . .                   | 15        |
| 3.2.5 Rola systemu pamięci w działaniu konsoli . . . . .                | 15        |

|       |                                                    |    |
|-------|----------------------------------------------------|----|
| 3.3   | Generowanie klatki obrazu . . . . .                | 16 |
| 3.3.1 | Format zapisu grafiki w pamięci VRAM . . . . .     | 16 |
| 3.3.2 | Renderowanie tła . . . . .                         | 16 |
| 3.3.3 | Pamięć OAM i reprezentacja obiektów . . . . .      | 16 |
| 3.3.4 | Renderowanie obiektów . . . . .                    | 16 |
| 3.3.5 | DMA i bezpośredni transfer danych do OAM . . . . . | 17 |
| 3.3.6 | Znaczenie procesu generowania obrazu . . . . .     | 17 |
| 3.4   | System przerwań . . . . .                          | 17 |
| 3.4.1 | Warunki występowania przerwań . . . . .            | 17 |
| 3.4.2 | Rodzaje przerwań . . . . .                         | 17 |
| 3.4.3 | Przebieg obsługi przerwania . . . . .              | 18 |
| 3.4.4 | Funkcje realizowane przez przerwanie . . . . .     | 18 |
| 3.4.5 | Znaczenie mechanizmu przerwań . . . . .            | 18 |

# 1 Wstęp

## 1.1 Opis problemu

Konsola *Game Boy*, wyprodukowana przez firmę *Nintendo* i wprowadzona na rynek japoński 21 kwietnia 1989 roku, stała się jednym z najbardziej rozpoznawalnych urządzeń w historii elektronicznej rozrywki. *Game Boy* odniósła znaczący sukces komercyjny – w ciągu pierwszych lat od premiery sprzedano ponad 20 milionów egzemplarzy. W kolejnych latach konsola została wprowadzona na rynki zachodnie, gdzie również zdobyła dużą popularność. Łączna sprzedaż wszystkich wariantów urządzenia uczyniła ją jedną z najlepiej sprzedających się konsol przenośnych w historii.

Gry dla konsoli były dystrybuowane w postaci wymiennych kartridżów (Game Pak), zawierających pamięć ROM z kodem programu, danymi graficznymi oraz dźwiękowymi. W niektórych przypadkach kartridż wyposażone były dodatkowo w pamięć RAM oraz baterię podtrzymującą stan gry. Architektura sprzętowa konsoli opierała się na 8-bitowym procesorze taktowanym częstotliwością około 4,19 MHz, a obraz generowany był w rozdzielcości  $160 \times 144$  pikseli przy czterech poziomach szarości.

Wraz z zakończeniem produkcji konsoli przez *Nintendo* dostęp do oryginalnego sprzętu stał się ograniczony. Znaczna część tytułów wydanych wyłącznie na tę platformę nie została oficjalnie przeniesiona na nowsze systemy. W konsekwencji wiele gier pozostaje dostępnych jedynie poprzez zachowane egzemplarze konsoli oraz kartridże, co utrudnia ich użytkowanie oraz archiwizację.

## 1.2 Emulatory

Jednym z rozwiązań problemu ograniczonej dostępności oryginalnego sprzętu są emulatory, czyli programy komputerowe umożliwiające odtworzenie funkcjonalności danego systemu sprzętowego w środowisku wirtualnym. Emulator odwzorowuje działanie procesora, pamięci, układów graficznych oraz urządzeń wejścia/wyjścia w sposób pozwalający na uruchamianie oryginalnego oprogramowania.

Emulatory znajdują zastosowanie nie tylko w środowisku graczy, lecz również w badaniach nad architekturą systemów komputerowych, analizie kompatybilności oprogramowania oraz cyfrowej archiwizacji dziedzictwa technologicznego. Umożliwiają one zachowanie historycznej wartości gier i systemów, które w przeciwnym razie mogłyby zostać utracone wraz z degradacją fizycznych nośników.

Wyróżnia się dwa podstawowe podejścia do emulacji:

- **Emulacja pełna** – polegająca na wiernym odwzorowaniu wszystkich kluczowych komponentów sprzętowych systemu, w tym procesora, pamięci, grafiki oraz dźwięku.
- **Emulacja częściowa** – obejmująca jedynie wybrane elementy systemu, co może ograniczać kompatybilność z oryginalnym oprogramowaniem.

W kontekście niniejszej pracy przyjęto założenie realizacji emulacji pełnej w zakresie podstawowej funkcjonalności konsoli.

## 1.3 Założenia i cel pracy

Celem niniejszej pracy jest zaprojektowanie oraz implementacja emulatora konsoli Game Boy w języku programowania C++, z wykorzystaniem biblioteki Raylib do obsługi warstwy graficznej i wejścia użytkownika. Projekt zakłada odwzorowanie podstawowych mechanizmów działania oryginalnej architektury sprzętowej w stopniu umożliwiającym uruchamianie wybranej klasy gier.

Zakres pracy obejmuje:

- implementację emulacji procesora oraz mapy pamięci konsoli,
- odwzorowanie mechanizmu wyświetlania obrazu,
- obsługę wejścia użytkownika z wykorzystaniem klawiatury,
- możliwość wczytywania obrazów ROM typu *ROM Only*,
- zapewnienie wieloplatformowości (Windows, Linux, macOS).

W ramach projektu przyjęto ograniczenie do obsługi podstawowego typu kartридża zawierającego wyłącznie pamięć ROM, bez dodatkowych kontrolerów pamięci (MBC). Emulator przeznaczony jest do uruchamiania cyfrowych kopii gier pozyskanych przez użytkownika z posiadanych nośników.

Poprawność działania systemu zostanie zweryfikowana poprzez porównanie wyników emulacji z publicznie dostępnymi testami zgodności opracowanymi przez społeczność dokumentującą architekturę konsoli.

## 1.4 Grupa docelowa

Odbiorcami opracowanego systemu są użytkownicy posiadający legalne kopie gier przeznaczonych na konsolę Game Boy, zainteresowani ich uruchamianiem na współczesnych komputerach osobistych. Emulator może stanowić również narzędzie edukacyjne dla osób zainteresowanych architekturą systemów wbudowanych oraz mechanizmami niskopoziomowego działania sprzętu.

# 2 Analiza architektury systemowej konsoli Game Boy

## 2.1 Specyfikacja techniczna

Nintendo Research And Development 1, pod przewodnictwem Gunpei Yokoi i Satoru Okady, zaprojektowało 8-bitową konsolę Game Boya. Charakteryzuje się wyświetlaczem matrycowym o rozdzielcości 160x144 pikseli, D-padem, czterema przyciskami gry i jednym głośnikiem. Używa stworzonych na potrzebe konsoli kartridżów ‘GamePak’. Zasilany był przez 4 baterie AA. Gracze mogli korzystać z kabla Game Link Cable do połączenia dwóch Game Boyów dla rozgrywki wieloosobowej bądź transferu danych dla wspierających gier. Chociaż wyświetlacz monochromatyczny był gorszy niż u konkurencji, umożliwił on bardziej tanie i długotrwałe życie baterii. [2]

## 2.2 Procesor i SoC

Procesorem Gameboya był specjalnie wytworzony na potrzeby konsoli 8-bitowy procesor SM83 firmy Sharp. [4]. Procesor był mieszaną dwóch innych procesorów - 8080 firmy Intel i Z80 firmy Zilog. Procesor znajdował się na płytce wraz innymi komponentami takimi jak pamięć RAM i ROM. Cała płytnka jest określana jako SoC (System on Chip) i oryginalny Game Boy zawierał DMG-CPU znany także jako Sharp LR35902 [1]. SoC był wpinany do płyty głównej, która zawierała dodatkową pamięć RAM i Video RAM (VRAM) jak i łączyła się z innymi komponentami jak ekran, głośnik czy kontroler.

### 2.2.1 Model czasowy systemu

Działanie konsoli Game Boy oparte jest na synchronicznym modelu czasowym, w którym wszystkie główne komponenty systemu — procesor, układ graficzny oraz timery sprzętowe — pracują w oparciu o wspólne źródło taktowania. Nominalna częstotliwość zegara systemowego wynosi 4,194304 MHz, co determinuje tempo wykonywania instrukcji procesora oraz przebieg cykli pracy pozostałych bloków funkcjonalnych.

**Cykle maszynowe procesora** Procesor wykonuje instrukcje w jednostkach zwanych cyklami maszynowymi (ang. *machine cycles*), z których każdy obejmuje określoną liczbę taktów zegara systemowego. Czas wykonania instrukcji zależy od jej złożoności i wynosi zazwyczaj od jednego do kilku cykli maszynowych. Model czasowy procesora ma charakter deterministyczny, co oznacza, że liczba cykli wymaganych do wykonania danej instrukcji jest stała i niezależna od kontekstu wykonania.

**Synchronizacja z układem graficznym** Układ graficzny pracuje równolegle z procesorem i cyklicznie przechodzi przez zdefiniowane fazy generowania obrazu. Każda ramka obrazu składa się z sekwencji linii skanowania, a przebieg ich przetwarzania wyznacza rytm pracy całego systemu. W określonych fazach generowania obrazu dostęp procesora do wybranych obszarów pamięci wideo jest ograniczony, co stanowi bezpośrednią konsekwencję współdzielenia zasobów pamięci pomiędzy jednostkami systemu.

**System timerów sprzętowych** Konsola wyposażona jest w sprzętowe układy odmierzania czasu, których działanie jest bezpośrednio powiązane z zegarem systemowym. Timery te generują zdarzenia okresowe wykorzystywane do synchronizacji logiki programu, pomiaru czasu oraz inicjowania przerwań sprzętowych. Ich konfiguracja pozwala na wybór różnych częstotliwości zliczania poprzez dzielenie sygnału zegarowego.

**Znaczenie modelu czasowego** Ścisłe powiązanie pracy wszystkich komponentów z jednym źródłem taktowania zapewnia deterministyczny charakter działania systemu. W konsekwencji poprawność działania oprogramowania zależy nie tylko od sekwencji wykonywanych instrukcji, lecz również od ich dokładnego rozmieszczenia w czasie względem zdarzeń sprzętowych. Model czasowy stanowi zatem istotny element architektury systemowej konsoli i odgrywa kluczową rolę w implementacji wiernych emulatorów platformy. Procesor zawiera osiem 8-bitowych rejestrów: A,B,C,D,E,F,H,L. Rejestry mogą łączyć się w 16-bitowe rejesty: AF, BC, DE, HL . Rejestr F jest używany jako flagi procesora w wypadku operacji arytmetycznych:

- Bit 7 - Zero (Z), jeśli operacja zwróciła zero
- Bit 6 - Negacja (N), używana gdy ostatnia operacją była porównaniem bądź odejmowaniem
- Bit 5 - Half Carry (H), jeśli doszło do przesunięcia na bicie 3
- Bit 4 - Carry (C), jeśli doszło do przesunięcia na bicie 7

Bitы od 3 do 0 są nieużywane i zawsze powinny być zerowane. Rejestr A jest używany jako akumulator w operacjach arytmetycznych.

## 2.3 Zestaw Instrukcji

Zestaw rozkazów (instruction set architecture, ISA) stanowi rozwinięcie koncepcji znanych z mikroprocesorów rodziny Z80, z licznymi uproszczeniami i modyfikacjami dostosowanymi do zastosowań w systemie przenośnym. Wszystkie rozkazy można systematycznie sklasyfikować na poszczególne grupy .

### 2.3.1 Instrukcje transferu danych

Instrukcje tej grupy odpowiadają za przemieszczanie informacji pomiędzy rejestrami, pamięcią oraz natychmiastowymi wartościami liczbowymi. Do najważniejszych operacji należą:

- **LD (Load)** – realizuje kopiowanie danych pomiędzy rejestrami ogólnego przeznaczenia (A, B, C, D, E, H, L), parami rejestrów oraz komórkami pamięci adresowanymi bezpośrednio lub pośrednio.
- **LDH** – specjalizowana forma transferu do i z obszaru pamięci o wysokim adresie (High RAM).
- **PUSH / POP** – zapis i odczyt danych na stosie, z wykorzystaniem wskaźnika stosu SP.

Instrukcje transferu nie modyfikują danych źródłowych (z wyjątkiem operacji stosowych), a ich podstawową funkcją jest reorganizacja informacji w przestrzeni rejistro-pamięciowej procesora.

### 2.3.2 Instrukcje arytmetyczne

Instrukcje arytmetyczne realizują operacje matematyczne na liczbach całkowitych. W SM83 operacje te wykonywane są głównie na akumulatorze A. Do kluczowych operacji należą:

- **ADD / ADC** – dodawanie bez i z uwzględnieniem flagi przeniesienia,
- **SUB / SBC** – odejmowanie bez i z uwzględnieniem przeniesienia,
- **INC / DEC** – inkrementacja i dekrementacja rejestrów oraz komórek pamięci,
- **DAA** – korekcja wyniku dodawania do postaci BCD,
- **CP** – porównanie wartości bez zapisu wyniku (modyfikowane są jedynie flagi).

Instrukcje te aktualizują rejestr flag (Z, N, H, C), który odzwierciedla właściwości wyniku operacji.

## Game Boy CPU (SM83) instruction set (JSON)

|    | x0                | x1                | x2                  | x3                   | x4                | x5                   | x7               | x8                  | x9                   | xA               | xB                 | xC                 | xD               | xE                   | xF               |                   |
|----|-------------------|-------------------|---------------------|----------------------|-------------------|----------------------|------------------|---------------------|----------------------|------------------|--------------------|--------------------|------------------|----------------------|------------------|-------------------|
| 0x | NOP<br>1 4        | LD BC,n16<br>3 32 | LD [BC] A<br>1 8    | INC BC<br>1 4        | DEC B<br>1 4      | LDB,n8<br>2 8        | RLOCA<br>1 8     | LD [a16],SP<br>3 20 | ADD HL,BC<br>1 8     | LD A,[BC]<br>1 8 | DEC BC<br>1 8      | INC C<br>1 4       | DEC C<br>1 4     | LD C,n8<br>2 8       | RRCA<br>1 0 0 C  |                   |
| 1x | STOP,n8<br>2 4    | LD DE,n16<br>3 32 | LD [DE] A<br>1 8    | INC D<br>1 4         | DEC D<br>1 4      | LDD,n8<br>2 8        | RLA<br>1 8       | JR e8<br>2 12       | ADD HL,DE<br>1 8     | LD A,[DE]<br>1 8 | DEC DE<br>1 8      | INC E<br>1 4       | DEC E<br>1 4     | LD E,n8<br>2 8       | RRA<br>1 0 0 C   |                   |
| 2x | JR NZ,n8<br>2 128 | LD HL,n16<br>3 32 | LD [HL] A<br>1 8    | INC H<br>1 4         | DEC H<br>1 4      | LHD,n8<br>2 8        | DAA<br>1 8       | JR Z,e8<br>2 128    | ADD HL,HL<br>1 8     | LD A,[HL]<br>1 8 | DEC HL<br>1 8      | INC L<br>1 4       | DEC L<br>1 4     | LD L,n8<br>2 8       | CPL<br>1 1 1 C   |                   |
| 3x | JR NC,n8<br>2 128 | LD SP,n16<br>3 32 | LD [HL] A<br>1 8    | INC [HL] A<br>1 8    | DEC [HL] A<br>1 8 | LD [HL],SCF<br>2 12  | JRC,e8<br>2 128  | ADD HL,SP<br>1 8    | LD A,[HL]<br>1 8     | DEC SP<br>1 8    | INC A<br>1 4       | DEC A<br>1 4       | LD A,n8<br>2 8   | CCF<br>1 0 0 C       |                  |                   |
| 4x | LD B,B<br>1 4     | LD B,C<br>1 4     | LD B,D<br>1 4       | LD B,E<br>1 4        | LD B,F<br>1 4     | LD B,G<br>1 4        | LD B,H<br>1 4    | LD B,I<br>1 4       | LD C,B<br>1 4        | LD C,D<br>1 4    | LD C,E<br>1 4      | LD C,G<br>1 4      | LD C,H<br>1 4    | LD C,A<br>1 4        | LD C,A<br>1 4    |                   |
| 5x | LD D,B<br>1 4     | LD D,C<br>1 4     | LD D,D<br>1 4       | LD D,E<br>1 4        | LD D,F<br>1 4     | LD D,G<br>1 4        | LD D,H<br>1 4    | LD D,I<br>1 4       | LD E,B<br>1 4        | LD E,D<br>1 4    | LD E,E<br>1 4      | LD E,G<br>1 4      | LD E,H<br>1 4    | LD E,L<br>1 4        | LD E,A<br>1 4    |                   |
| 6x | LD H,B<br>1 4     | LD H,C<br>1 4     | LD H,D<br>1 4       | LD H,E<br>1 4        | LD H,F<br>1 4     | LD H,G<br>1 4        | LD H,I<br>1 4    | LD H,J<br>1 4       | LD L,B<br>1 4        | LD L,D<br>1 4    | LD L,E<br>1 4      | LD L,G<br>1 4      | LD L,H<br>1 4    | LD L,I<br>1 4        | LD L,A<br>1 4    |                   |
| 7x | LD H[8],L<br>1 8  | LD H[8],C<br>1 8  | LD H[8],D<br>1 8    | LD H[8],E<br>1 8     | LD H[8],F<br>1 8  | LD H[8],G<br>1 8     | LD H[8],I<br>1 8 | HALT<br>1 4         | LD H[8],A<br>1 8     | LD H[8],B<br>1 8 | LD H[8],C<br>1 8   | LD H[8],D<br>1 8   | LD H[8],E<br>1 8 | LD H[8],F<br>1 8     | LD H[8],A<br>1 8 |                   |
| 8x | ADD A,B<br>1 8    | ADD A,C<br>1 8    | ADD A,D<br>1 8      | ADD A,E<br>1 8       | ADD A,F<br>1 8    | ADD A,G<br>1 8       | ADD A,H<br>1 8   | ADD A,I<br>1 8      | ADC A,B<br>1 8       | ADC A,C<br>1 8   | ADC A,D<br>1 8     | ADC A,G<br>1 8     | ADC A,H<br>1 8   | ADC A,L<br>1 8       | ADC A,M<br>1 8   |                   |
| 9x | SUB A,B<br>1 8    | SUB A,C<br>1 8    | SUB A,D<br>1 8      | SUB A,E<br>1 8       | SUB A,F<br>1 8    | SUB A,G<br>1 8       | SUB A,H<br>1 8   | SUB A,I<br>1 8      | SBC A,B<br>1 8       | SBC A,C<br>1 8   | SBC A,D<br>1 8     | SBC A,G<br>1 8     | SBC A,H<br>1 8   | SBC A,L<br>1 8       | SBC A,M<br>1 8   |                   |
| Ax | AND A,B<br>1 8    | AND A,C<br>1 8    | AND A,D<br>1 8      | AND A,E<br>1 8       | AND A,F<br>1 8    | AND A,G<br>1 8       | AND A,H<br>1 8   | AND A,I<br>1 8      | XOR A,B<br>1 8       | XOR A,C<br>1 8   | XOR A,D<br>1 8     | XOR A,G<br>1 8     | XOR A,H<br>1 8   | XOR A,L<br>1 8       | XOR A,M<br>1 8   |                   |
| Bx | OR A,B<br>1 8     | OR A,C<br>1 8     | OR A,D<br>1 8       | OR A,E<br>1 8        | OR A,F<br>1 8     | OR A,G<br>1 8        | OR A,H<br>1 8    | OR A,I<br>1 8       | CPA,B<br>1 8         | CPA,C<br>1 8     | CPA,D<br>1 8       | CPA,G<br>1 8       | CPA,H<br>1 8     | CPA,L<br>1 8         | CPA,M<br>1 8     |                   |
| Cx | RET NZ<br>1 208   | POP BC<br>3 1612  | JP NZ,n16<br>3 1612 | JP a16<br>3 2412     | PUSH BC<br>1 16   | CALL NZ,n16<br>1 208 | PUSH BC<br>1 16  | RST 300<br>2 000    | RET 2<br>2 000       | RET 2<br>2 000   | RET<br>1 16        | JP Z,a16<br>3 1612 | PREFIX<br>1 4    | CALL Z,a16<br>3 2412 | CALL 16<br>3 24  |                   |
| Dx | RET NC<br>1 208   | POP DE<br>3 1612  | JP NC,n16<br>3 2412 | CALL NC,n16<br>1 208 | PUSH DE<br>1 16   | SUB DE<br>1 8        | PUSH DE<br>1 16  | RST 310<br>2 000    | RET C<br>2 000       | RET C<br>2 000   | RET<br>1 16        | JP C,a16<br>3 1612 | PREFIX<br>1 4    | CALL C,a16<br>3 2412 | CALL 16<br>3 24  |                   |
| E  | LDH[8],A<br>1 8   | POP HL<br>1 12    | LDH[8],C<br>1 8     | —                    | —                 | PUSH ANA,n8<br>1 16  | RDH[8],A<br>1 16 | RST 320<br>2 000    | ADD SP, #8<br>2 000  | JP PH<br>1 16    | LDH[8],A<br>1 8    | —                  | —                | XOR A,B<br>1 8       | RST 328<br>2 000 |                   |
| Fx | LDH[8],A<br>1 8   | POP AF<br>1 12    | LDH[8],C<br>1 8     | DI<br>1 4            | —                 | PUSH AF<br>1 16      | ORA,n8<br>2 000  | RST 320<br>2 000    | LDH SP + #8<br>2 000 | LD SP, H<br>1 16 | LO A,[a16]<br>3 16 | EI<br>1 4          | —                | —                    | CP A,n8<br>2 8   | RST 338<br>2 11 C |

Rysunek 1: Tablica rozmieszczenia instrukcji: [3]

## Prefixed (\$CB \$xx)

|    | x0            | x1            | x2            | x3            | x4            | x5            | x6            | x7            | x8            | x9            | xA            | xB            | xC            | xD            | xE            | xF |
|----|---------------|---------------|---------------|---------------|---------------|---------------|---------------|---------------|---------------|---------------|---------------|---------------|---------------|---------------|---------------|----|
| 0x | RLC,B<br>2 8  | RLG,D<br>2 8  | RLG,E<br>2 8  | RLG,F<br>2 8  | RLG,G<br>2 8  | RLG,H<br>2 8  | RLG,I<br>2 8  | RLG,J<br>2 8  | RRC,B<br>2 8  | RRC,C<br>2 8  | RRC,D<br>2 8  | RRC,E<br>2 8  | RRC,F<br>2 8  | RRC,G<br>2 8  | RRC,H<br>2 8  |    |
| 1x | RL,R<br>2 8   | RL,C<br>2 8   | RL,D<br>2 8   | RL,E<br>2 8   | RL,F<br>2 8   | RL,G<br>2 8   | RL,H<br>2 8   | RL,I<br>2 8   | RRB,B<br>2 8  | RRB,C<br>2 8  | RRB,D<br>2 8  | RRB,E<br>2 8  | RRB,F<br>2 8  | RRB,G<br>2 8  | RRB,H<br>2 8  |    |
| 2x | SLA,B<br>2 8  | SLA,D<br>2 8  | SLA,E<br>2 8  | SLA,F<br>2 8  | SLA,G<br>2 8  | SLA,H<br>2 8  | SLA,I<br>2 8  | SLA,J<br>2 8  | SRA,B<br>2 8  | SRA,C<br>2 8  | SRA,D<br>2 8  | SRA,E<br>2 8  | SRA,F<br>2 8  | SRA,G<br>2 8  | SRA,H<br>2 8  |    |
| 3x | SHAD,B<br>2 8 | SHAD,C<br>2 8 | SHAD,D<br>2 8 | SHAD,E<br>2 8 | SHAD,F<br>2 8 | SHAD,G<br>2 8 | SHAD,H<br>2 8 | SHAD,I<br>2 8 | SHAP,B<br>2 8 | SHAP,C<br>2 8 | SHAP,D<br>2 8 | SHAP,E<br>2 8 | SHAP,F<br>2 8 | SHAP,G<br>2 8 | SHAP,H<br>2 8 |    |
| 4x | BIT0,B<br>2 8 | BIT0,C<br>2 8 | BIT0,D<br>2 8 | BIT0,E<br>2 8 | BIT0,F<br>2 8 | BIT0,G<br>2 8 | BIT0,H<br>2 8 | BIT0,I<br>2 8 | BIT1,B<br>2 8 | BIT1,C<br>2 8 | BIT1,D<br>2 8 | BIT1,E<br>2 8 | BIT1,F<br>2 8 | BIT1,G<br>2 8 | BIT1,H<br>2 8 |    |
| 5x | BIT2,B<br>2 8 | BIT2,C<br>2 8 | BIT2,D<br>2 8 | BIT2,E<br>2 8 | BIT2,F<br>2 8 | BIT2,G<br>2 8 | BIT2,H<br>2 8 | BIT2,I<br>2 8 | BIT3,B<br>2 8 | BIT3,C<br>2 8 | BIT3,D<br>2 8 | BIT3,E<br>2 8 | BIT3,F<br>2 8 | BIT3,G<br>2 8 | BIT3,H<br>2 8 |    |
| 6x | BIT4,B<br>2 8 | BIT4,C<br>2 8 | BIT4,D<br>2 8 | BIT4,E<br>2 8 | BIT4,F<br>2 8 | BIT4,G<br>2 8 | BIT4,H<br>2 8 | BIT4,I<br>2 8 | BIT5,B<br>2 8 | BIT5,C<br>2 8 | BIT5,D<br>2 8 | BIT5,E<br>2 8 | BIT5,F<br>2 8 | BIT5,G<br>2 8 | BIT5,H<br>2 8 |    |
| 7x | BIT6,B<br>2 8 | BIT6,C<br>2 8 | BIT6,D<br>2 8 | BIT6,E<br>2 8 | BIT6,F<br>2 8 | BIT6,G<br>2 8 | BIT6,H<br>2 8 | BIT6,I<br>2 8 | BIT7,B<br>2 8 | BIT7,C<br>2 8 | BIT7,D<br>2 8 | BIT7,E<br>2 8 | BIT7,F<br>2 8 | BIT7,G<br>2 8 | BIT7,H<br>2 8 |    |
| 8x | RES0,B<br>2 8 | RES0,C<br>2 8 | RES0,D<br>2 8 | RES0,E<br>2 8 | RES0,F<br>2 8 | RES0,G<br>2 8 | RES0,H<br>2 8 | RES0,I<br>2 8 | RES1,B<br>2 8 | RES1,C<br>2 8 | RES1,D<br>2 8 | RES1,E<br>2 8 | RES1,F<br>2 8 | RES1,G<br>2 8 | RES1,H<br>2 8 |    |
| 9x | RES2,B<br>2 8 | RES2,C<br>2 8 | RES2,D<br>2 8 | RES2,E<br>2 8 | RES2,F<br>2 8 | RES2,G<br>2 8 | RES2,H<br>2 8 | RES2,I<br>2 8 | RES3,B<br>2 8 | RES3,C<br>2 8 | RES3,D<br>2 8 | RES3,E<br>2 8 | RES3,F<br>2 8 | RES3,G<br>2 8 | RES3,H<br>2 8 |    |
| Ax | RES4,B<br>2 8 | RES4,C<br>2 8 | RES4,D<br>2 8 | RES4,E<br>2 8 | RES4,F<br>2 8 | RES4,G<br>2 8 | RES4,H<br>2 8 | RES4,I<br>2 8 | RES5,B<br>2 8 | RES5,C<br>2 8 | RES5,D<br>2 8 | RES5,E<br>2 8 | RES5,F<br>2 8 | RES5,G<br>2 8 | RES5,H<br>2 8 |    |
| Bx | RES6,B<br>2 8 | RES6,C<br>2 8 | RES6,D<br>2 8 | RES6,E<br>2 8 | RES6,F<br>2 8 | RES6,G<br>2 8 | RES6,H<br>2 8 | RES6,I<br>2 8 | RES7,B<br>2 8 | RES7,C<br>2 8 | RES7,D<br>2 8 | RES7,E<br>2 8 | RES7,F<br>2 8 | RES7,G<br>2 8 | RES7,H<br>2 8 |    |
| Cx | SET0,B<br>2 8 | SET0,C<br>2 8 | SET0,D<br>2 8 | SET0,E<br>2 8 | SET0,F<br>2 8 | SET0,G<br>2 8 | SET0,H<br>2 8 | SET0,I<br>2 8 | SET1,B<br>2 8 | SET1,C<br>2 8 | SET1,D<br>2 8 | SET1,E<br>2 8 | SET1,F<br>2 8 | SET1,G<br>2 8 | SET1,H<br>2 8 |    |
| Dx | SET2,B<br>2 8 | SET2,C<br>2 8 | SET2,D<br>2 8 | SET2,E<br>2 8 | SET2,F<br>2 8 | SET2,G<br>2 8 | SET2,H<br>2 8 | SET2,I<br>2 8 | SET3,B<br>2 8 | SET3,C<br>2 8 | SET3,D<br>2 8 | SET3,E<br>2 8 | SET3,F<br>2 8 | SET3,G<br>2 8 | SET3,H<br>2 8 |    |
| E  | SET4,B<br>2 8 | SET4,C<br>2 8 | SET4,D<br>2 8 | SET4,E<br>2 8 | SET4,F<br>2 8 | SET4,G<br>2 8 | SET4,H<br>2 8 | SET4,I<br>2 8 | SET5,B<br>2 8 | SET5,C<br>2 8 | SET5,D<br>2 8 | SET5,E<br>2 8 | SET5,F<br>2 8 | SET5,G<br>2 8 | SET5,H<br>2 8 |    |
| Fx | SET6,B<br>2 8 | SET6,C<br>2 8 | SET6,D<br>2 8 | SET6,E<br>2 8 | SET6,F<br>2 8 | SET6,G<br>2 8 | SET6,H<br>2 8 | SET6,I<br>2 8 | SET7,B<br>2 8 | SET7,C<br>2 8 | SET7,D<br>2 8 | SET7,E<br>2 8 | SET7,F<br>2 8 | SET7,G<br>2 8 | SET7,H<br>2 8 |    |

Rysunek 2: Tablica rozmieszczenia instrukcji po opcjedzie 0xCB: [3]

### 2.3.3 Instrukcje logiczne i bitowe

Grupa ta obejmuje operacje algebry Boole'a oraz manipulacje pojedynczymi bitami. Do najważniejszych należą:

- **AND, OR, XOR** – operacje logiczne na akumulatorze,
- **CPL** – negacja bitowa zawartości akumulatora,
- **BIT** – test wybranego bitu,
- **SET / RES** – ustawienie lub wyzerowanie wskazanego bitu.

Instrukcje bitowe umożliwiają precyzyjną kontrolę struktur danych, co jest szczególnie istotne w systemach o ograniczonych zasobach pamięci.

### 2.3.4 Instrukcje przesunięć i rotacji

Operacje tej kategorii realizują przesunięcia bitowe oraz rotacje z lub bez udziału flagi przeniesienia:

- **RL, RLC** – rotacja w lewo,
- **RR, RRC** – rotacja w prawo,
- **SLA, SRA, SRL** – przesunięcia arytmetyczne i logiczne,
- **SWAP** – zamiana pół bajtów w rejestrze.

Instrukcje te są użyteczne zarówno w obliczeniach arytmetycznych, jak i w przetwarzaniu danych binarnych.

### 2.3.5 Instrukcje sterowania przepływem programu

Instrukcje sterujące odpowiadają za zmianę kolejności wykonywania programu:

- **JP** – skok bezwarunkowy lub warunkowy,
- **JR** – skok względny o ograniczonym zasięgu,
- **CALL / RET** – wywołanie i powrót z podprogramu,
- **RST** – szybkie wywołanie procedury o stałym adresie.

Warunkowość operacji zależy od stanu flag procesora, co umożliwia implementację struktur decyzyjnych.

Do tej grupy należą instrukcje wpływające na stan globalny procesora:

- **NOP** – brak operacji,
- **HALT** – zatrzymanie pracy CPU do momentu wystąpienia przerwania,
- **STOP** – tryb niskiego poboru energii,
- **DI / EI** – dezaktywacja i aktywacja systemu przerwań,
- **SCF / CCF** – manipulacja flagą przeniesienia.

Instrukcje te mają kluczowe znaczenie dla zarządzania energią oraz obsługi zdarzeń asynchronicznych.

## 2.4 Mapowanie pamięci w konsoli Game Boy

Architektura pamięci konsoli Game Boy oparta jest na 16-bitowej przestrzeni adresowej o rozmiarze  $2^{16} = 65\,536$  bajtów (64 KB). Procesor systemu, zgodny z modyfikowaną architekturą Sharp LR35902, wykorzystuje jednolitą przestrzeń adresową, w której różne zakresy adresów są przypisane do odmiennych typów pamięci oraz rejestrów sprzętowych. Taki model organizacji pamięci określany jest jako *memory-mapped I/O* i umożliwia bezpośrednią komunikację procesora z układami peryferyjnymi poprzez operacje odczytu i zapisu w odpowiednich obszarach adresowych.

| Zakres adresów | Rozmiar | Przeznaczenie                                 |
|----------------|---------|-----------------------------------------------|
| 0000-3FFF      | 16 KB   | Stała pamięć ROM banku 0                      |
| 4000-7FFF      | 16 KB   | Przełączalny bank ROM                         |
| 8000-9FFF      | 8 KB    | Pamięć wideo (VRAM)                           |
| A000-BFFF      | 8 KB    | Zewnętrzna pamięć RAM w kartridżu             |
| C000-CFFF      | 4 KB    | Wewnętrzna pamięć robocza (WRAM bank 0)       |
| D000-DFFF      | 4 KB    | Wewnętrzna pamięć robocza (bank przełączalny) |
| E000-FDFF      | 7.5 KB  | Obszar echo pamięci WRAM                      |
| FE00-FE9F      | 160 B   | Pamięć atrybutów obiektów (OAM)               |
| FEAO-FEFF      | 96 B    | Obszar niedostępny                            |
| FF00-FF7F      | 128 B   | Rejestry wejścia/wyjścia                      |
| FF80-FFFE      | 127 B   | Pamięć szybka (HRAM)                          |
| FFFF           | 1 B     | Rejestr przerwań (IE)                         |

Tabela 1: Mapa pamięci konsoli Game Boy [5]

#### 2.4.1 Ogólny układ przestrzeni adresowej

Przestrzeń adresowa Game Boya podzielona jest na segmenty o ustalonej funkcji sprzętowej. Tabela 1 przedstawia standardowy schemat mapowania pamięci.

#### 2.4.2 Pamięć programu i bankowanie ROM

Dolne 32 KB przestrzeni adresowej przeznaczone jest na pamięć tylko do odczytu (ROM) zawartą w kartridżu. Pierwsze 16 KB (0000-3FFF) stanowi bank stały, natomiast zakres 4000-7FFF obsługuje mechanizm przełączania banków pamięci, realizowany przez kontroler MBC (Memory Bank Controller). Dzięki temu możliwe jest adresowanie programów o rozmiarze znacznie przekraczającym 64 KB.

#### 2.4.3 Pamięć wideo

Obszar 8000-9FFF odpowiada pamięci VRAM, wykorzystywanej przez układ graficzny do przechowywania danych kafelków graficznych oraz map tła. Dostęp do tej pamięci jest ograniczony w określonych fazach cyklu wyświetlania obrazu, co wynika z synchronizacji procesora z kontrolerem LCD.

#### 2.4.4 Pamięć robocza i obszar echo

Wewnętrzna pamięć robocza WRAM zajmuje zakres C000-DFFF. Dodatkowo obszar E000-FDFF stanowi tzw. echo WRAM, czyli lustrzane odwzorowanie części pamięci roboczej. Jego obecność wynika z uproszczeń sprzętowych i nie jest zalecana do programowego wykorzystania.

#### 2.4.5 Mapowanie urządzeń wejścia/wyjścia

Zakres FF00-FF7F zawiera rejesty sterujące sprzętem, w tym kontrolerem dźwięku, systemem przerwań, timerami oraz interfejsem wejściowym. Operacje zapisu i odczytu w tych adresach odpowiadają bezpośrednim operacjom na urządzeniach peryferyjnych.

#### 2.4.6 Pamięć wysokiej prędkości

Obszar FF80-FFFE, określany jako HRAM (High RAM), to niewielki fragment szybkiej pamięci roboczej o krótkim czasie dostępu. Ze względu na swoje właściwości jest on często wykorzystywany do przechowywania zmiennych o krytycznym znaczeniu czasowym.

#### 2.4.7 Znaczenie architektury mapowania pamięci

Przyjęty model mapowania pamięci umożliwia efektywne współdzielenie przestrzeni adresowej przez kod programu, dane oraz układy sprzętowe. Rozwiążanie to upraszcza konstrukcję systemu, lecz jednocześnie wymaga ścisłej kontroli dostępu do poszczególnych segmentów pamięci przez oprogramowanie systemowe i aplikacyjne.

## 2.5 System przerwań w konsoli Game Boy

System przerwań w konsoli Game Boy realizuje mechanizm asynchronicznej obsługi zdarzeń sprzętowych, umożliwiając procesorowi reagowanie na zdarzenia wewnętrzne i zewnętrzne bez konieczności ciągłego odpytywania urządzeń peryferyjnych. Architektura ta stanowi kluczowy element synchronizacji pracy jednostki centralnej z układami graficznymi, licznikami czasu oraz interfejsem wejściowym.

### 2.5.1 Źródła przerwań

Konsola Game Boy obsługuje pięć podstawowych źródeł przerwań sprzętowych. Każdemu z nich przypisany jest odrębny wektor przerwania oraz odpowiedni bit w rejestrach sterujących. Zestaw źródeł przerwań przedstawiono w tabeli 2.

| Bit | Nazwa przerwania | Funkcja                             |
|-----|------------------|-------------------------------------|
| 0   | V-Blank          | Zakończenie rysowania ramki obrazu  |
| 1   | LCD STAT         | Zdarzenia kontrolera LCD            |
| 2   | Timer            | Przepełnienie timera systemowego    |
| 3   | Serial           | Zakończenie transmisji szeregowej   |
| 4   | Joypad           | Zmiana stanu kontrolera wejściowego |

Tabela 2: Źródła przerwań w konsoli Game Boy[5]

Przerwanie V-Blank pełni szczególną rolę, ponieważ wyznacza bezpieczny moment aktualizacji pamięci wideo. Przerwanie LCD STAT umożliwia reakcję na szczegółowe stany pracy kontrolera wyświetlania, natomiast przerwanie timera wykorzystywane jest do odmierzania czasu oraz synchronizacji logiki programu.

### 2.5.2 Rejestry sterujące systemem przerwań

Obsługa przerwań realizowana jest poprzez dwa rejesty mapowane w przestrzeni adresowej:

- IE (Interrupt Enable, adres FFFF) — określa, które źródła przerwań są aktywne.
- IF (Interrupt Flag, adres FF0F) — przechowuje informację o zgłoszonych przerwaniach.

Każdy bit w obu rejestrach odpowiada jednemu źródłu przerwania. Zgłoszenie przerwania polega na ustawieniu odpowiedniego bitu w rejestrze IF. Jeżeli odpowiadający mu bit w rejestrze IE jest ustawiony oraz globalna obsługa przerwań jest włączona, procesor inicjuje procedurę obsługi przerwania.

### 2.5.3 Mechanizm obsługi przerwania

Po wykryciu aktywnego przerwania procesor wykonuje następującą sekwencję działań:

1. zakończenie bieżącej instrukcji,
2. zapis aktualnej wartości licznika programu na stosie,
3. wyłączenie globalnej obsługi przerwań,
4. skok pod adres wektora przerwania.

Adresy wektorów przerwań są stałe i przypisane do konkretnych źródeł zdarzeń. Po zakończeniu procedury obsługi przerwania wykonywana jest instrukcja powrotu, która przywraca poprzedni stan wykonania programu.

### 2.5.4 Priorytety przerwań

W przypadku jednoczesnego zgłoszenia wielu przerwań stosowany jest ustalony porządek priorytetów. Najwyższy priorytet posiada przerwanie V-Blank, a najniższy przerwanie kontrolera wejściowego. Taki schemat zapewnia deterministyczną obsługę zdarzeń związanych z generowaniem obrazu, które są krytyczne dla poprawnego działania systemu.

### 2.5.5 Rola systemu przerwań w architekturze konsoli

System przerwań stanowi podstawowy mechanizm synchronizacji komponentów sprzętowych konsole Game Boy. Dzięki niemu możliwe jest efektywne współdziałanie procesora z kontrolerem graficznym, licznikami czasu oraz urządzeniami wejścia/wyjścia przy zachowaniu deterministycznego modelu wykonania programu. Mechanizm ten ma istotne znaczenie zarówno dla projektowania oprogramowania systemowego, jak i dla implementacji emulatorów platformy.

## 2.6 Płyta główna

Płyta główna konsoli Game Boy stanowi podstawowy element konstrukcyjny systemu, integrujący wszystkie kluczowe układy elektroniczne odpowiedzialne za przetwarzanie danych, generowanie obrazu, obsługę dźwięku oraz zarządzanie energią. Ze względu na przenośny charakter urządzenia, konstrukcja płyty została zaprojektowana z naciskiem na energooszczędność, prostotę architektury oraz wysoką niezawodność.



Rysunek 3: Zdjęcie płyty głównej oryginalnego GameBoy'a z opisami komponentów[1]



Rysunek 4: Schemat płyty głównej konsoli GameBoy[1]

### 2.6.1 Jednostka centralna

Centralnym elementem płyty głównej jest układ DMG-CPU, stanowiący zintegrowany system typu System on Chip (SoC). W przeciwieństwie do klasycznych konstrukcji mikrokomputerowych, w których poszczególne funkcje realizowane są przez oddzielne układy scalone, DMG-CPU integruje w jednej strukturze półprzewodnikowej jednostkę obliczeniową, kontroler pamięci, układ graficzny, generator dźwięku oraz logikę sterującą systemem.

Rdzeń obliczeniowy układu bazuje na architekturze 8-bitowej z 16-bitową przestrzenią adresową i realizuje wykonywanie programu oraz zarządzanie przepływem danych pomiędzy komponentami systemu. Integracja funkcji w jednym układzie pozwoliła na ograniczenie liczby połączeń na płycie głównej, zmniejszenie poboru energii oraz zwiększenie niezawodności urządzenia.

DMG-CPU odpowiada również za synchronizację pracy podsystemów, obsługę przerwań sprzętowych, sterowanie dostępem do pamięci operacyjnej i wideo oraz koordynację komunikacji z interfejsem kartridża i urządzeniami wejścia-wyjścia. Zastosowanie architektury SoC stanowiło kluczowy element miniaturyzacji konsoli oraz umożliwiło osiągnięcie wysokiej efektywności energetycznej przy zachowaniu pełnej funkcjonalności systemu.

### 2.6.2 Pamięć operacyjna i pamięć wideo

Na płycie głównej znajdują się układy pamięci pełniące różne funkcje w architekturze systemu:

- **WRAM (Work RAM)** – pamięć operacyjna wykorzystywana przez procesor do przechowywania danych roboczych oraz stosu.
- **VRAM (Video RAM)** – pamięć przeznaczona do przechowywania danych graficznych, takich jak mapy kafli, wzorce znaków oraz informacje o sprite'ach.

Pamięci te współpracują bezpośrednio z procesorem oraz układem generowania obrazu, zapewniając sprawną wymianę danych niezbędnych do działania systemu.

### **2.6.3 Układ graficzny**

Funkcje generowania obrazu realizowane są przez zintegrowany kontroler LCD, który odpowiada za przetwarzanie danych graficznych i sterowanie wyświetlaczem ciekłokrystalicznym. Układ ten obsługuje system kafli (tile-based graphics), renderowanie sprite'ów oraz synchronizację obrazu z odświeżaniem ekranu. Kontroler LCD współpracuje bezpośrednio z pamięcią wideo oraz procesorem, tworząc kompletny tor przetwarzania grafiki.

### **2.6.4 Układ dźwiękowy**

System dźwiękowy konsoli jest zintegrowany z architekturą płyty głównej i składa się z generatorów fal dźwiękowych sterowanych programowo. Układ ten umożliwia generowanie kilku kanałów audio, w tym fal prostokątnych, szumu oraz próbek o ograniczonej rozdzielczości. Sygnał audio kierowany jest następnie do wzmacniacza i głośnika lub wyjścia słuchawkowego. Ze względu skomplikowania, komponent układu dźwiękowego nie będzie uwzględniany.

### **2.6.5 Interfejs kartridża**

Na płycie głównej znajduje się złącze kartridża umożliwiające komunikację z zewnętrznym nośnikiem oprogramowania. Interfejs ten zapewnia:

- dostęp do pamięci programu,
- komunikację z dodatkowymi układami w kartridżu,
- możliwość rozszerzenia funkcjonalności systemu.

Zastosowanie wymiennych kartridży umożliwiło modularną architekturę systemu oraz łatwą dystrybucję oprogramowania.

### **2.6.6 Układy wejścia i wyjścia**

Płyta główna integruje również komponenty odpowiedzialne za komunikację z użytkownikiem oraz otoczeniem:

- kontroler przycisków sterujących,
- interfejs komunikacyjny (port szeregowy),
- sterowanie wyświetlaczem LCD,
- wzmacniacz audio.

Układy te zapewniają interakcję użytkownika z systemem oraz obsługę sygnałów wejściowych i wyjściowych.

Płyta główna konsoli Game Boy stanowi przykład zwartej i funkcjonalnej integracji elementów elektronicznych w systemie o ograniczonych zasobach sprzętowych. Zastosowanie zintegrowanych układów scalonych, zoptymalizowane zarządzanie energią oraz modułowa struktura pamięci i interfejsów umożliwiły stworzenie wydajnego, przenośnego systemu rozrywkowego. Analiza budowy płyty głównej pozwala dostrzec kompromis pomiędzy funkcjonalnością, energooszczędnością a prostotą konstrukcji, charakterystyczny dla projektowania urządzeń przenośnych końca XX wieku.

## **2.7 Kartridże systemu Game Boy**

Kartridże stanowią podstawowy nośnik oprogramowania dla konsoli Game Boy oraz element rozbierający funkcjonalność systemu. Oprócz pamięci programu zawierają one układy logiczne odpowiedzialne za zarządzanie pamięcią, zapisywanie danych użytkownika oraz, w niektórych przypadkach, dodatkowe funkcje sprzętowe. Różnorodność konstrukcji kartridżów wynikała z konieczności obsługi gier o rosnącej złożoności przy zachowaniu ograniczeń architektury systemu.

### **2.7.1 Kartridże bez kontrolera banków pamięci (ROM Only)**

Najprostszy typ kartridża zawiera wyłącznie pamięć ROM z programem gry. Konstrukcja ta nie umożliwia przełączania banków pamięci ani zapisu danych użytkownika. Ze względu na ograniczoną pojemność stosowana była głównie w prostszych produkcjach we wczesnym okresie rozwoju systemu.

### **2.7.2 Kartridże z kontrolerem MBC1**

Kontroler Memory Bank Controller 1 (MBC1) umożliwia przełączanie banków pamięci ROM oraz, opcjonalnie, banków pamięci RAM. Układ ten pozwalał na znaczące zwiększenie maksymalnego rozmiaru programu. Kartridże tego typu występowały w kilku wariantach:

- MBC1 + RAM,
- MBC1 + RAM + bateria podtrzymująca zapis danych.

### **2.7.3 Kartridże z kontrolerem MBC2**

MBC2 integruje funkcję przełączania banków ROM z niewielką, wbudowaną pamięcią RAM przeznaczoną do zapisu danych gry. W odróżnieniu od innych kontrolerów, pamięć RAM jest integralną częścią układu i nie występuje jako oddzielny komponent. Kartridże te standardowo wyposażone były w baterię podtrzymującą zapis.

### **2.7.4 Kartridże z kontrolerem MBC3**

MBC3 rozszerza funkcjonalność poprzednich kontrolerów o zegar czasu rzeczywistego (RTC). Rozwiązywanie to umożliwiało implementację mechanik zależnych od upływu czasu rzeczywistego. Warianty konstrukcyjne obejmowały:

- MBC3 + RAM,
- MBC3 + RAM + bateria,
- MBC3 + RAM + bateria + RTC.

### **2.7.5 Kartridże z kontrolerem MBC5**

MBC5 wprowadza rozszerzony system adresowania pamięci ROM oraz obsługę większych pojemności pamięci RAM. Układ ten był stosowany w późniejszych produkcjach o dużej objętości danych. Warianty obejmowały:

- MBC5 + RAM,
- MBC5 + RAM + bateria,
- MBC5 + RAM + bateria + silnik wibracyjny (Rumble).

### **2.7.6 Kartridże specjalizowane**

Oprócz standardowych kontrolerów banków pamięci produkowano kartridże wyposażone w dodatkowe układy funkcjonalne rozszerzające możliwości systemu. Do najważniejszych należą:

- kartridże z czujnikiem ruchu,
- kartridże z pamięcią EEPROM,
- kartridże z dodatkowymi układami logicznymi sterującymi akcesoriami,
- kartridże diagnostyczne i testowe wykorzystywane w procesie produkcyjnym.

### **2.7.7 Struktura fizyczna kartridża**

Typowy kartridż składa się z płytki drukowanej zawierającej układ ROM, opcjonalną pamięć RAM, kontroler banków pamięci oraz element podtrzymywania zasilania pamięci zapisu. Komunikacja z konsolą odbywa się za pośrednictwem złącza krawędziowego, które zapewnia dostęp do magistrali adresowej, magistrali danych oraz linii sterujących.

### 3 Model działania systemu Game Boy

#### 3.1 Cykl pracy procesora

Procesor zastosowany w konsoli Game Boy jest 8-bitową jednostką opartą na zmodyfikowanej architekturze zbliżonej do Z80. Jego działanie jest determinowane przez cykl zegara systemowego oraz mechanizm wykonywania instrukcji w modelu sekwencyjnym. Zrozumienie cyklu pracy procesora jest kluczowe dla analizy działania całego systemu, ponieważ CPU koordynuje komunikację pomiędzy pamięcią, układem graficznym oraz urządzeniami wejścia/wyjścia.

##### 3.1.1 Model cyklu rozkazowego

Podstawowy cykl pracy procesora można opisać jako powtarzającą się sekwencję trzech etapów:

1. pobranie instrukcji z pamięci,
2. dekodowanie instrukcji,
3. wykonanie instrukcji.

W pierwszym etapie procesor odczytuje kod operacji spod adresu wskazywanego przez licznik programu (PC). Następnie licznik programu zostaje inkrementowany, a pobrana wartość trafia do wewnętrznego rejestru instrukcji.

W drugim etapie następuje interpretacja kodu operacji oraz ustalenie wymaganych operandów. Proces dekodowania determinuje, czy instrukcja wymaga dodatkowych danych z pamięci oraz jakie jednostki funkcjonalne procesora zostaną zaangażowane w jej wykonanie.

Trzeci etap obejmuje właściwe wykonanie operacji arytmetycznej, logicznej lub sterującej. W zależności od typu instrukcji może to obejmować operacje na rejestrach, dostęp do pamięci lub zmianę przepływu sterowania programu.

##### 3.1.2 Synchronizacja z zegarem systemowym

Procesor pracuje synchronicznie z zegarem systemowym, którego częstotliwość determinuje tempo wykonywania operacji. Każda instrukcja wymaga określonej liczby cykli zegara do wykonania. Czas realizacji instrukcji nie jest stały i zależy od jej złożoności oraz liczby operacji pamięciowych.

Istotnym elementem synchronizacji jest współdzielenie magistrali danych z innymi komponentami systemu. Dostęp do pamięci jest realizowany w ścisłe określonych momentach cyklu zegara, co zapewnia spójność transmisji danych pomiędzy CPU a pozostałymi układami.

##### 3.1.3 Dostęp do pamięci i operacje magistrali

Procesor komunikuje się z pamięcią poprzez magistralę adresową i magistralę danych. W trakcie cyklu rozkazowego mogą wystąpić operacje odczytu lub zapisu pamięci. Operacje te są wykonywane sekwencyjnie i blokują dostęp do magistrali dla innych komponentów na czas trwania transferu.

Mapowanie pamięci odgrywa istotną rolę w cyklu pracy procesora, ponieważ różne zakresy adresowe odpowiadają różnym typom zasobów systemowych, takim jak pamięć operacyjna, pamięć video oraz rejesty sterujące urządzeń peryferyjnych.

##### 3.1.4 Obsługa przerwań

Cykl pracy procesora może zostać przerwany przez mechanizm przerwań sprzętowych. Wystąpienie przerwania powoduje czasowe wstrzymanie wykonywania bieżącego programu oraz zapis aktualnego stanu procesora na stosie.

Po zaakceptowaniu przerwania procesor przechodzi do procedury obsługi przerwania wskazanej w tablicy wektorów przerwań. Po zakończeniu obsługi następuje przywrócenie poprzedniego stanu procesora i kontynuacja wykonywania programu od miejsca przerwania.

##### 3.1.5 Znaczenie cyklu pracy dla działania systemu

Deterministyczny charakter cyklu pracy procesora umożliwia precyzyjną synchronizację z układem graficznym oraz pozostałymi komponentami systemu. W szczególności liczba cykli zegara zużywana przez instrukcję wpływa bezpośrednio na generowanie obrazu oraz obsługę zdarzeń wejścia/wyjścia.

Analiza cyklu pracy procesora stanowi podstawę do modelowania działania systemu oraz jest niezbędna przy implementacji oprogramowania emulującego działanie konsoli.

## **3.2 Magistrala pamięciowa i charakterystyka działania pamięci**

System pamięci konsoli Game Boy opiera się na wspólnej przestrzeni adresowej obsługiwanej przez procesor oraz na zestawie wyspecjalizowanych obszarów pamięci o odmiennych funkcjach. Komunikacja pomiędzy jednostką centralną a zasobami pamięciowymi realizowana jest za pomocą magistrali adresowej, magistrali danych oraz sygnałów sterujących, które determinują kierunek i tryb transferu informacji.

### **3.2.1 Organizacja magistrali pamięciowej**

Magistrala adresowa umożliwia wskazanie konkretnej komórki pamięci w przestrzeni adresowej systemu. Procesor generuje adres, który identyfikuje zasób, z którego ma nastąpić odczyt danych lub do którego ma zostać wykonany zapis. Magistrala danych służy do przesyłania właściwych informacji pomiędzy procesorem a wskazanym komponentem systemu.

Operacje pamięciowe są synchronizowane z zegarem systemowym. W każdym cyklu dostępu do pamięci następuje ustalenie adresu, aktywacja sygnału sterującego oraz transfer danych. Ze względu na współdzielenie magistrali przez różne komponenty systemu dostęp do niej jest ścisłe kontrolowany, co zapobiega konfliktom transmisji.

### **3.2.2 Mapowanie przestrzeni adresowej**

Przestrzeń adresowa systemu jest podzielona na logiczne segmenty odpowiadające różnym typom zasobów sprzętowych. Poszczególne zakresy adresów są przypisane do pamięci programu, pamięci operacyjnej, pamięci wideo oraz rejestrów sterujących urządzeń peryferyjnych.

Mapowanie pamięci pełni funkcję mechanizmu integrującego różnorodne komponenty sprzętowe w jednolitą przestrzeń adresową. Dzięki temu procesor może komunikować się z układami systemowymi za pomocą standardowych operacji odczytu i zapisu, bez konieczności stosowania odrębnych instrukcji wejścia/wyjścia.

### **3.2.3 Rodzaje pamięci w systemie**

W architekturze systemu można wyróżnić kilka podstawowych typów pamięci:

- pamięć programu (ROM), zawierająca kod wykonywalny oraz dane statyczne,
- pamięć operacyjna (RAM), wykorzystywana do przechowywania danych tymczasowych,
- pamięć wideo (VRAM), przeznaczona do przechowywania danych graficznych,
- rejstry urządzeń peryferyjnych odwzorowane w przestrzeni adresowej.

Każdy z wymienionych typów pamięci charakteryzuje się odmiennym przeznaczeniem funkcjonalnym oraz sposobem dostępu. W szczególności pamięć wideo jest współdzielona z układem graficznym, co wprowadza ograniczenia czasowe w dostępie do niej przez procesor.

### **3.2.4 Charakterystyka operacji pamięciowych**

Operacje pamięciowe wykonywane przez procesor obejmują odczyt danych, zapis danych oraz transfery blokowe realizowane sekwencyjnie. Czas trwania operacji zależy od rodzaju pamięci oraz liczby cykli zegara wymaganych do realizacji transferu.

Dostęp do pamięci może być ograniczony przez stan systemu, w szczególności przez aktywność układów współdzielących magistralę. W określonych fazach pracy systemu wybrane obszary pamięci mogą być czasowo niedostępne dla procesora lub dostępne jedynie w określonych warunkach synchronizacji.

### **3.2.5 Rola systemu pamięci w działaniu konsoli**

Architektura pamięci stanowi podstawę wymiany informacji pomiędzy wszystkimi komponentami systemu. Determinuje ona sposób wykonywania programu, obsługi grafiki oraz komunikacji z urządzeniami wejścia/wyjścia.

Jednolita przestrzeń adresowa oraz deterministyczny model dostępu do pamięci umożliwiają przewidywalne działanie systemu w czasie rzeczywistym. Właściwości te mają istotne znaczenie zarówno dla analizy architektury sprzętowej, jak i dla implementacji oprogramowania odwzorowującego działanie systemu.

### 3.3 Generowanie klatki obrazu

Generowanie obrazu w konsoli Game Boy jest realizowane przez układ graficzny (PPU), który współpracuje z pamięcią wideo oraz pamięcią atrybutów obiektów. Proces ten przebiega cyklicznie i jest ściśle zsynchronizowany z zegarem systemowym oraz działaniem procesora. Obraz powstaje poprzez sekwencyjne renderowanie tła, a następnie nakładanie obiektów ruchomych zapisanych w pamięci OAM.

#### 3.3.1 Format zapisu grafiki w pamięci VRAM

Podstawową jednostką reprezentacji obrazu w systemie jest tzw. kafel (ang. tile). Każdy kafel reprezentuje fragment obrazu o wymiarach  $8 \times 8$  pikseli. Dane kafli przechowywane są w pamięci wideo (VRAM) w postaci uporządkowanej tablicy bajtów.

Każdy wiersz kafla kodowany jest przy użyciu dwóch bajtów, które reprezentują dwubitową informację o kolorze każdego piksela w wierszu. Pierwszy bajt zawiera najmniej znaczące bity wartości koloru, natomiast drugi bajt zawiera bity najbardziej znaczące. Odczyt odpowiadających sobie bitów z obu bajtów pozwala określić indeks koloru dla pojedynczego piksela.

Układ graficzny interpretuje dane kafli na podstawie mapy tła, która przechowuje indeksy kafli oraz ich rozmieszczenie na ekranie. Dzięki temu możliwe jest wielokrotne wykorzystanie tych samych danych graficznych w różnych miejscach obrazu.

#### 3.3.2 Renderowanie tła

Proces generowania klatki rozpoczyna się od renderowania tła. Układ graficzny przetwarza mapę tła linia po linii, odczytując odpowiednie indeksy kafli oraz ich dane z pamięci VRAM. Dla każdej linii obrazu wyznaczany jest odpowiedni fragment kafla, który następnie przekształcany jest w wartości kolorów pikseli.

Renderowanie odbywa się w sposób deterministyczny i jest zsynchronizowane z aktualną pozycją skanowania ekranu. W wyniku tego procesu powstaje podstawowa warstwa obrazu, która stanowi bazę dla dalszego etapu renderowania.

#### 3.3.3 Pamięć OAM i reprezentacja obiektów

OAM (Object Attribute Memory) jest wyspecjalizowanym obszarem pamięci przeznaczonym do przechowywania informacji o obiektach ruchomych, określanych jako sprite'y. Pamięć ta zawiera zestaw rekordów opisujących właściwości graficzne oraz położenie obiektów wyświetlanych na ekranie.

Każdy wpis w pamięci OAM zawiera:

- współrzędną pionową obiektu na ekranie,
- współrzędną poziomą obiektu,
- indeks kafla opisującego grafikę obiektu,
- zestaw atrybutów określających sposób renderowania.

Atrybuty obiektu mogą obejmować informacje o priorytecie wyświetlania, odbiciu lustrzanym oraz wyborze palety kolorów. Układ graficzny odczytuje zawartość pamięci OAM podczas procesu generowania obrazu i wykorzystuje ją do nałożenia obiektów na wcześniej wyrenderowane tło.

#### 3.3.4 Renderowanie obiektów

Po wygenerowaniu warstwy tła układ graficzny przystępuje do renderowania obiektów zapisanych w pamięci OAM. Dla każdej linii obrazu wybierane są obiekty znajdujące się w jej obszarze, a następnie ich dane graficzne są pobierane z pamięci VRAM.

Renderowanie obiektów polega na nałożeniu ich pikseli na istniejący obraz tła zgodnie z regułami priorytetu. W przypadku kolizji pikseli o różnych źródłach decyzja o widoczności zależy od atrybutów obiektu oraz wartości koloru tła.

### **3.3.5 DMA i bezpośredni transfer danych do OAM**

W celu usprawnienia transferu danych do pamięci OAM system wykorzystuje mechanizm DMA (Direct Memory Access). Mechanizm ten umożliwia bezpośrednie kopiowanie bloków danych z określonego obszaru pamięci do pamięci OAM bez konieczności wykonywania instrukcji kopiowania przez procesor.

Transfer DMA polega na automatycznym odczycie kolejnych bajtów ze źródłowego obszaru pamięci oraz ich zapisie do kolejnych komórek pamięci OAM. W trakcie operacji DMA procesor ma ograniczony dostęp do magistrali pamięci, co zapewnia spójność przesyłanych danych.

Zastosowanie mechanizmu bezpośredniego transferu bajtów umożliwia szybkie aktualizowanie danych obiektów, co jest szczególnie istotne w systemach czasu rzeczywistego, gdzie konieczna jest synchronizacja zmian graficznych z generowaniem kolejnych klatek obrazu.

### **3.3.6 Znaczenie procesu generowania obrazu**

Proces generowania klatki obrazu stanowi wynik ścisłej współpracy pamięci video, pamięci OAM oraz układu graficznego. Deterministyczny charakter renderowania oraz uporządkowany dostęp do danych umożliwiają przewidywalne odwzorowanie stanu systemu graficznego w każdej chwili pracy konsoli.

Zrozumienie sposobu generowania obrazu ma istotne znaczenie dla analizy architektury systemu oraz implementacji oprogramowania emulującego działanie układu graficznego.

## **3.4 System przerwań**

Mechanizm przerwań w konsoli Game Boy umożliwia asynchroniczną reakcję procesora na zdarzenia sprzętowe zachodzące w systemie. Zamiast ciągłego odpytywania stanu urządzeń peryferyjnych, procesor może wykonywać program główny, a w momencie wystąpienia określonego zdarzenia przejść do dedykowanej procedury obsługi przerwania. Rozwiążanie to zwiększa efektywność wykorzystania czasu procesora oraz zapewnia deterministyczną obsługę zdarzeń czasowych.

### **3.4.1 Warunki występowania przerwań**

Przerwanie może zostać wygenerowane przez układ sprzętowy po spełnieniu określonego warunku logicznego, takiego jak zakończenie operacji wejścia/wyjścia, osiągnięcie zadanego stanu licznika czasowego lub zmiana stanu kontrolera wejściowego. Aby przerwanie zostało obsłużone, muszą zostać spełnione trzy warunki:

1. źródło przerwania zgłosi żądanie,
2. odpowiedni typ przerwania jest odblokowany w rejestrze maskującym,
3. globalny mechanizm obsługi przerwań w procesorze jest aktywny.

Jeżeli wszystkie warunki są spełnione, procesor kończy wykonywanie bieżącej instrukcji, zapisuje aktualny stan wykonania programu oraz przechodzi do procedury obsługi przerwania.

### **3.4.2 Rodzaje przerwań**

System przewiduje zestaw sprzętowych źródeł przerwań odpowiadających kluczowym funkcjom konsoli:

- przerwanie synchronizacji pionowej obrazu (V-Blank),
- przerwanie związane ze stanem układu graficznego (LCD STAT),
- przerwanie licznika czasowego (Timer),
- przerwanie zakończenia transmisji szeregowej,
- przerwanie kontrolera wejścia użytkownika (Joypad).

Każdy typ przerwania posiada przypisany wektor, czyli stały adres w pamięci programu, pod którym rozpoczyna się procedura jego obsługi. Priorytet przerwań jest ustalony sprzętowo i determinuje kolejność ich obsługi w przypadku jednoczesnego wystąpienia kilku zdarzeń.

### **3.4.3 Przebieg obsługi przerwania**

Obsługa przerwania przebiega według ścisłe określonej sekwencji działań wykonywanych przez procesor:

1. zakończenie wykonywania bieżącej instrukcji,
2. zapis aktualnej wartości licznika programu na stosie,
3. czasowe zablokowanie dalszych przerwań,
4. przejście do adresu procedury obsługi przerwania,
5. wykonanie kodu obsługi zdarzenia,
6. przywrócenie poprzedniego stanu programu i kontynuacja wykonania.

Zapis stanu programu na stosie umożliwia powrót do przerwanego miejsca po zakończeniu obsługi. Instrukcja powrotu z przerwania przywraca licznik programu oraz ponownie aktywuje globalny mechanizm przerwań.

### **3.4.4 Funkcje realizowane przez przerwania**

Przerwania pełnią w systemie rolę mechanizmu synchronizującego działanie procesora z procesami zachodzącymi w układach peryferyjnych. Do najważniejszych funkcji realizowanych za ich pomocą należą:

- synchronizacja zmian graficznych z cyklem generowania obrazu,
- odmierzanie czasu oraz generowanie zdarzeń okresowych,
- obsługa transmisji danych pomiędzy komponentami systemu,
- reagowanie na działania użytkownika.

W szczególności przerwanie synchronizacji pionowej umożliwia bezpieczną aktualizację danych graficznych w pamięci wideo w momentach, gdy układ graficzny nie odczytuje danych do generowania obrazu. Mechanizm przerwań zapewnia tym samym spójność danych oraz stabilność działania systemu w czasie rzeczywistym.

### **3.4.5 Znaczenie mechanizmu przerwań**

Zastosowanie przerwań pozwala na efektywne zarządzanie współbieżnymi zdarzeniami w systemie o ograniczonych zasobach sprzętowych. Deterministyczna obsługa zdarzeń oraz priorytetyzacja źródeł przerwań stanowią podstawę prawidłowego działania konsoli oraz umożliwiają implementację oprogramowania wymagającego precyzyjnej synchronizacji czasowej.

## **Bibliografia**

- [1] Rodrigo Copetti. *Game Boy Architecture - A Practical Analysis*. URL: <https://www.copetti.org/writings/consoles/game-boy/> (term. wiz. 15.02.2025).
- [2] *Game Boy*. Wikipedia. URL: [https://en.wikipedia.org/wiki/Game\\_Boy](https://en.wikipedia.org/wiki/Game_Boy) (term. wiz. 16.02.2025).
- [3] *Game Boy Opcode Tables*. URL: <https://gbdev.io/gb-opcodes/optables/> (term. wiz. 15.02.2025).
- [4] Gekkio. *Game Boy: Complete Technical Reference*. URL: <https://gekkio.fi/files/gb-docs/gbctr.pdf> (term. wiz. 15.02.2025).
- [5] *Pan Docs - Game Boy Technical Reference*. URL: <https://gbdev.io/pandocs/> (term. wiz. 15.02.2025).