Rejestry GTIA
From Atariki
Wersja z dnia 15:35, 12 cze 2011 Krótki (Dyskusja | wkład) (Przeróbka składni tabeli z HTML na MediaWiki) ← Previous diff |
Wersja z dnia 17:08, 29 wrz 2011 Mono (Dyskusja | wkład) (cienie trig) Next diff → |
||
Linia 71: | Linia 71: | ||
|id="GRAFP2"|$D00F (W)||GRAFP2|| | |id="GRAFP2"|$D00F (W)||GRAFP2|| | ||
|- | |- | ||
- | |id="TRIG0"|$D010 (R)||TRIG0||Stan spustu joysticka nr 0 (0 - wciśnięty). | + | |id="TRIG0"|$D010 (R)||TRIG0||Stan spustu joysticka nr 0 (0 - wciśnięty). Cień w TRIG0S ($0284). |
|- | |- | ||
|id="GRAFP3"|$D010 (W)||GRAFP3|| | |id="GRAFP3"|$D010 (W)||GRAFP3|| | ||
|- | |- | ||
- | |id="TRIG1"|$D011 (R)||TRIG1||Stan spustu joysticka nr 1 (0 - wciśnięty). | + | |id="TRIG1"|$D011 (R)||TRIG1||Stan spustu joysticka nr 1 (0 - wciśnięty). Cień w TRIG1S ($0285). |
|- | |- | ||
|id="GRAFM"|$D011 (W)||GRAFM|| | |id="GRAFM"|$D011 (W)||GRAFM|| | ||
|- | |- | ||
|id="TRIG2"|$D012 (R)||TRIG2|| | |id="TRIG2"|$D012 (R)||TRIG2|| | ||
- | W [[400/800]] stan spustu joysticka nr 2 (0 - wciśnięty). W [[XEGS]] wskazuje fakt podłączenia klawiatury (1 - podłączona). W pozostałych [[XL]] i [[XE]] rejestr nieużywany. | + | W [[400/800]] stan spustu joysticka nr 2 (0 - wciśnięty). W [[XEGS]] wskazuje fakt podłączenia klawiatury (1 - podłączona). W pozostałych [[XL]] i [[XE]] rejestr nieużywany. Cień w TRIG2S ($0286). |
|- | |- | ||
|id="COLPM0"|$D012 (W)||COLPM0|| | |id="COLPM0"|$D012 (W)||COLPM0|| | ||
Linia 86: | Linia 86: | ||
|- | |- | ||
|id="TRIG3"|$D013 (R)||TRIG3|| | |id="TRIG3"|$D013 (R)||TRIG3|| | ||
- | W [[400/800]] stan spustu joysticka nr 3 (0 - wciśnięty). W [[XL]] i [[XE]] sygnalizuje stan zewnętrznego [[cartridge]]'a (1 - włożony do gniazda) podpiętego pod linię RD5 (mapowanie $A000-$BFFF). Nie wskaże, czy włożono cartridge, który jest podpięty tylko (!) pod linię RD4 (mapowanie $8000-$9FFF). | + | W [[400/800]] stan spustu joysticka nr 3 (0 - wciśnięty). W [[XL]] i [[XE]] sygnalizuje stan zewnętrznego [[cartridge]]'a (1 - włożony do gniazda) podpiętego pod linię RD5 (mapowanie $A000-$BFFF). Nie wskaże, czy włożono cartridge, który jest podpięty tylko (!) pod linię RD4 (mapowanie $8000-$9FFF). Cień w TRIG3S ($0287). |
W komputerach SECAM (w przeciwieństwie do PAL i NTSC) stan tego rejestru nie ustala się natychmiast po aktywacji (włożeniu) kartridża, ale dopiero podczas pierwszych sześciu [[cykl koloru|cykli koloru]] po impulsie synchronizacji poziomej kończącym bieżącą linię skaningową. Powoduje to kłopoty, jeśli program zapisany na kartridżu może odłączać pamięć ROM kartridża w celu uzyskania dostępu do znajdującego się "pod nią" RAM-u. Takim kartridżem jest [[SpartaDOS X]]. Przyczyną jest fakt, że procedura [[SYSVBL]] (a ściślej: jej druga faza) zawiera kod sprawdzający zgodność stanu TRIG3 i jego cienia GINTLK ($03FA), i jeśli się nie zgadzają, zawiesza komputer. | W komputerach SECAM (w przeciwieństwie do PAL i NTSC) stan tego rejestru nie ustala się natychmiast po aktywacji (włożeniu) kartridża, ale dopiero podczas pierwszych sześciu [[cykl koloru|cykli koloru]] po impulsie synchronizacji poziomej kończącym bieżącą linię skaningową. Powoduje to kłopoty, jeśli program zapisany na kartridżu może odłączać pamięć ROM kartridża w celu uzyskania dostępu do znajdującego się "pod nią" RAM-u. Takim kartridżem jest [[SpartaDOS X]]. Przyczyną jest fakt, że procedura [[SYSVBL]] (a ściślej: jej druga faza) zawiera kod sprawdzający zgodność stanu TRIG3 i jego cienia GINTLK ($03FA), i jeśli się nie zgadzają, zawiesza komputer. |
Wersja z dnia 17:08, 29 wrz 2011
GTIA został wykorzystany w małych Atari oraz w konsolach Atari 5200. W obu systemach rejestry GTIA zostały zmapowane na różnych stronach pamięci - w komputerach na stronie $D0, w konsoli na stronie $C0. W tabeli podane są adresy właściwe dla komputerów 400/800/XL/XE.
Lista rejestrów
Adres | Etykieta | Opis | ||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
$D000 (R) | KOLM0PF, M0PF | |||||||||||||||||||
$D000 (W) | HPOSP0 |
Pozycja pozioma gracza nr 0, mierzona w cyklach koloru. Można wpisywać wartości od 0 (skrajna lewa) do 255 (skrajna prawa) pamiętając jednak o tym, że skrajne pozycje znajdują się poza obszarem wyświetlanym na ekranie przeciętnego monitora. W praktyce zakres pozycji, w jakich duszek jest widoczny, rozciąga się od wartości 32 do 216. Standardowe pole gry zajmuje pozycje 48 do 208, zwężone odpowiednio mniej, a rozszerzone odpowiednio więcej. | ||||||||||||||||||
$D001 (R) | KOLM1PF, M1PF | |||||||||||||||||||
$D001 (W) | HPOSP1 | Pozycja pozioma gracza nr 1. Patrz HPOSP0. | ||||||||||||||||||
$D002 (R) | KOLM2PF, M2PF | |||||||||||||||||||
$D002 (W) | HPOSP2 | Pozycja pozioma gracza nr 2. Patrz HPOSP0. | ||||||||||||||||||
$D003 (R) | KOLM3PF, M3PF | |||||||||||||||||||
$D003 (W) | HPOSP3 | Pozycja pozioma gracza nr 3. Patrz HPOSP0. | ||||||||||||||||||
$D004 (R) | KOLP0PF, P0PF | |||||||||||||||||||
$D004 (W) | HPOSM0 | Pozycja pozioma pocisku nr 0. Patrz HPOSP0. | ||||||||||||||||||
$D005 (R) | KOLP1PF, P1PF | |||||||||||||||||||
$D005 (W) | HPOSM1 | Pozycja pozioma pocisku nr 1. Patrz HPOSP0. | ||||||||||||||||||
$D006 (R) | KOLP2PF, P2PF | |||||||||||||||||||
$D006 (W) | HPOSM2 | Pozycja pozioma pocisku nr 2. Patrz HPOSP0. | ||||||||||||||||||
$D007 (R) | KOLP3PF, P3PF | |||||||||||||||||||
$D007 (W) | HPOSM3 | Pozycja pozioma pocisku nr 3. Patrz HPOSP0. | ||||||||||||||||||
$D008 (R) | KOLM0P, M0PL | |||||||||||||||||||
$D008 (W) | SIZEP0 | |||||||||||||||||||
$D009 (R) | KOLM1P, M1PL | |||||||||||||||||||
$D009 (W) | SIZEP1 | |||||||||||||||||||
$D00A (R) | KOLM2P, M2PL | |||||||||||||||||||
$D00A (W) | SIZEP2 | |||||||||||||||||||
$D00B (R) | KOLM3P, M3PL | |||||||||||||||||||
$D00B (W) | SIZEP3 | |||||||||||||||||||
$D00C (R) | KOLP0P, P0PL | |||||||||||||||||||
$D00C (W) | SIZEM | |||||||||||||||||||
$D00D (R) | KOLP1P, P1PL | |||||||||||||||||||
$D00D (W) | GRAFP0 | |||||||||||||||||||
$D00E (R) | KOLP2P, P2PL | |||||||||||||||||||
$D00E (W) | GRAFP1 | |||||||||||||||||||
$D00F (R) | KOLP3P, P3PL | |||||||||||||||||||
$D00F (W) | GRAFP2 | |||||||||||||||||||
$D010 (R) | TRIG0 | Stan spustu joysticka nr 0 (0 - wciśnięty). Cień w TRIG0S ($0284). | ||||||||||||||||||
$D010 (W) | GRAFP3 | |||||||||||||||||||
$D011 (R) | TRIG1 | Stan spustu joysticka nr 1 (0 - wciśnięty). Cień w TRIG1S ($0285). | ||||||||||||||||||
$D011 (W) | GRAFM | |||||||||||||||||||
$D012 (R) | TRIG2 |
W 400/800 stan spustu joysticka nr 2 (0 - wciśnięty). W XEGS wskazuje fakt podłączenia klawiatury (1 - podłączona). W pozostałych XL i XE rejestr nieużywany. Cień w TRIG2S ($0286). | ||||||||||||||||||
$D012 (W) | COLPM0 |
Kolor gracza i pocisku nr 0. Bity 7-4 wybierają kolor, bity 3-1 odcień, a bit 0 jest nieużywany, a więc wybór jest z palety 128 kolorów. Rejestr odświeżany jest przez procedurę SYSVBL, która kopiuje tu zawartość cienia COLPM0S $02C0 za każdym wystąpieniem przerwania VBL. | ||||||||||||||||||
$D013 (R) | TRIG3 |
W 400/800 stan spustu joysticka nr 3 (0 - wciśnięty). W XL i XE sygnalizuje stan zewnętrznego cartridge'a (1 - włożony do gniazda) podpiętego pod linię RD5 (mapowanie $A000-$BFFF). Nie wskaże, czy włożono cartridge, który jest podpięty tylko (!) pod linię RD4 (mapowanie $8000-$9FFF). Cień w TRIG3S ($0287). W komputerach SECAM (w przeciwieństwie do PAL i NTSC) stan tego rejestru nie ustala się natychmiast po aktywacji (włożeniu) kartridża, ale dopiero podczas pierwszych sześciu cykli koloru po impulsie synchronizacji poziomej kończącym bieżącą linię skaningową. Powoduje to kłopoty, jeśli program zapisany na kartridżu może odłączać pamięć ROM kartridża w celu uzyskania dostępu do znajdującego się "pod nią" RAM-u. Takim kartridżem jest SpartaDOS X. Przyczyną jest fakt, że procedura SYSVBL (a ściślej: jej druga faza) zawiera kod sprawdzający zgodność stanu TRIG3 i jego cienia GINTLK ($03FA), i jeśli się nie zgadzają, zawiesza komputer. Metoda obejścia tego problemu:
sei ;zablokuj drugą fazę SYSVBL ... ;tu przełączenie pamięci sta wsync ;odczekujemy 2 linie na ustalenie sie stanu trig3 sta wsync lda trig3 sta gintlk cli
| ||||||||||||||||||
$D013 (W) | COLPM1 |
Kolor gracza i pocisku nr 1. Bity 7-4 wybierają kolor, bity 3-1 odcień, a bit 0 jest nieużywany, a więc wybór jest z palety 128 kolorów. Rejestr odświeżany jest przez procedurę SYSVBL, która kopiuje tu zawartość cienia COLPM1S $02C1 za każdym wystąpieniem przerwania VBL. | ||||||||||||||||||
$D014 (R) | PAL |
Znacznik systemu TV. Znaczenie bitów:
Wynika z tego, że w systemie PAL i SECAM wartość rejestru to $01, a w NTSC $0F. | ||||||||||||||||||
$D014 (W) | COLPM2 |
Kolor gracza i pocisku nr 2. Bity 7-4 wybierają kolor, bity 3-1 odcień, a bit 0 jest nieużywany, a więc wybór jest z palety 128 kolorów. Rejestr odświeżany jest przez procedurę SYSVBL, która kopiuje tu zawartość cienia COLPM2S $02C2 za każdym wystąpieniem przerwania VBL. | ||||||||||||||||||
$D015 (W) | COLPM3 |
Kolor gracza i pocisku nr 3. Bity 7-4 wybierają kolor, bity 3-1 odcień, a bit 0 jest nieużywany, a więc wybór jest z palety 128 kolorów. Rejestr odświeżany jest przez procedurę SYSVBL, która kopiuje tu zawartość cienia COLPM3S $02C3 za każdym wystąpieniem przerwania VBL. | ||||||||||||||||||
$D016 (W) | COLPF0 | |||||||||||||||||||
$D017 (W) | COLPF1 | |||||||||||||||||||
$D018 (W) | COLPF2 | |||||||||||||||||||
$D019 (W) | COLPF3 | |||||||||||||||||||
$D01A (W) | COLBAK, COLBK | |||||||||||||||||||
$D01B (W) | GTIACTL, PRIOR |
Rejestr cień: GTIACTLS (GPRIOR) $026F
| ||||||||||||||||||
$D01C (W) | VDELAY |
Bity 0-3 oznaczają pociski o numerach 0-3, bity 4-7 graczy o numerach 0-3. Ustawienie bitu powoduje, ze pozycja pionowa odpowiedniego obiektu zwiększa się o jedną linię skaningową obrazu (czyli obiekt na ekranie obniża się o jedną linię). Służy to do zwiększenia płynności ruchu pionowego obiektów w rozdzielczości dwuliniowej, patrz DMACTL. | ||||||||||||||||||
$D01D (W) | PMCNTL, GRACTL |
Ustawienie bitu 0 powoduje włączenie wyświetlania pocisków, bitu 1 - włączenie wyświetlania graczy. Bit 2 odpowiada za działanie rejestrów TRIG0-3: jego ustawienie powoduje, że po wciśnięciu spustu joysticka rejestr "zatrzaskuje się" i pokazuje cały czas, że spust jest wciśnięty, nawet jeśli już nie jest. Zwolnienie następuje dopiero po skasowaniu bitu 2 omawianego tu rejestru. Mechanizm ten służy do łapania stanów spustów joysticka bez konieczności ich nieustannego monitorowania. | ||||||||||||||||||
$D01E (W) | HITCLR |
Zapis dowolnej wartości pod ten adres kasuje stany rejestrów kolizji. | ||||||||||||||||||
$D01F (R/W) | CONSOL |
Bity 0-3 tego rejestru reprezentują stan nóżek S0-S3 układu GTIA, a pozostałe bity sa niewykorzystane. Znaczenie:
"Jednobitowe wyjście dźwiękowe" wykorzystywane jest do generowania kliku klawiatury oraz dźwięku brzęczyka systemowego urządzenia "E:" (zob. CIO). W serii 400/800 służy do tego osobny głośniczek, w XL i XE natomiast jest to podłączone do ogólnego wyjścia audio. Przed odczytaniem stanu linii wejściowych (czyli stanu klawiszy START, SELECT, OPTION) odpowiednie bity rejestru CONSOL trzeba ustawić na zero. Normalnie jednak nie ma potrzeby tego czynić w programie, gdyż robi to systemowa procedura SYSVBL. |
Ten artykuł to tylko zalążek. Możesz pomóc rozwojowi Atariki poprzez rozszerzenie go o więcej informacji.