Obsługa rozszerzenia pamięci RAM typu Axlon
From Atariki
| Wersja z dnia 00:27, 22 lut 2016 KMK (Dyskusja | wkład) (→Wykrycie rozszerzenia i obliczenie jego rozmiaru) ← Previous diff |
Wersja z dnia 00:30, 22 lut 2016 KMK (Dyskusja | wkład) (→Wykrycie rozszerzenia i obliczenie jego rozmiaru) Next diff → |
||
| Linia 32: | Linia 32: | ||
| lda ext_b | lda ext_b | ||
| sta bsav,x | sta bsav,x | ||
| - | stx ext_b | + | stx ext_b ;oznaczenie bankow |
| - | dex | + | dex ;koniecznie w kolejnosci malejacej |
| cpx #$ff | cpx #$ff | ||
| bne _p0 | bne _p0 | ||
| Linia 39: | Linia 39: | ||
| inx | inx | ||
| - | _p1 inx | + | _p1 inx ;sprawdzenie numerow bankow |
| beq _x1 | beq _x1 | ||
| stx axlon | stx axlon | ||
| cpx ext_b | cpx ext_b | ||
| - | beq _p1 | + | beq _p1 ;pierwsa niezgodnosc przerywa petle |
| - | _x1 dex | + | _x1 dex ;odliczamy bank podstawowy |
| txa | txa | ||
| tay | tay | ||
| - | ldx #$00 | + | ldx #$00 ;przywrocenie wartosci |
| _p2 stx axlon | _p2 stx axlon | ||
| lda bsav,x | lda bsav,x | ||
| Linia 56: | Linia 56: | ||
| bne _p2 | bne _p2 | ||
| + | stx axlon ;ustaw bank podstawowy | ||
| rts | rts | ||
Wersja z dnia 00:30, 22 lut 2016
Informacje ogólne
Rozszerzenie typu Axlon przeznaczone jest zasadniczo dla komputerów serii 400/800. Podobnie jak w 130XE rozszerzona pamięć podzielona na banki po 16 KB znajduje się w obszarze $4000-$7FFF. Inaczej niż w 130XE nie ma możliwości oddzielnego adresowania dodatkowej pamięci przez CPU i ANTIC.
Rejestr sterujący rozszerzeniem umieszczony jest pod adresem $CFFF. Rejestr ten jest tylko do zapisu.
Trzeba mieć na względzie, że ze względu na niepełne dekodowanie, ten rejestr zajmuje obszar $CFC0-$CFFF oraz - co istotniejsze - $0FC0-$0FFF.
Obsługa jest bardzo prosta: wartość $00 wstawiona do rejestru $CFFF powoduje podłączenie pamięci podstawowej, każda inna - jednego z banków pamięci dodatkowej. To pozwala na instalację w komputerze do 4 MB pamięci dodatkowej (255 banków po 16k - 4080 KB).
Axlon na XL/XE
W 2012 roku Simius zbudował prototypowe rozszerzenie pamięci SIMMius 4 MB pozwalające na użycie trybu Axlon również na XL/XE. Rejestr przełączający znajduje się w pamięci ROM (tj. działa, gdy bit 0 rejestru PORTB jest ustawiony) wyłącznie pod adresem $CFFF i - jak na oryginale - jest tylko do zapisu.
Wykrycie rozszerzenia i obliczenie jego rozmiaru
Poniższa procedura przeprowadza test rozmiaru rozszerzenia pamięci RAM nie niszcząc zawartości tejże pamięci. Procedura musi być ulokowana w całości poza obszarem $4000-$7FFF. Dane wyjściowe:
- liczba dodatkowych banków 16k w rejestrze Y (lub 0, gdy dodatkowe banki nie są dostępne)
Ze względu na prostotę obsługi rozszerzenia nie ma potrzeby generowania listy dostępnych banków, wystarczy obliczyć ich liczbę.
; etykiety
ext_b = $4000 ;cokolwiek z zakresu $4000-$7FFF
axlon = $cfff
; procedura
detect_axlon
ldx #$ff ;zapamiętanie bajtów ext
_p0 stx axlon
lda ext_b
sta bsav,x
stx ext_b ;oznaczenie bankow
dex ;koniecznie w kolejnosci malejacej
cpx #$ff
bne _p0
inx
_p1 inx ;sprawdzenie numerow bankow
beq _x1
stx axlon
cpx ext_b
beq _p1 ;pierwsa niezgodnosc przerywa petle
_x1 dex ;odliczamy bank podstawowy
txa
tay
ldx #$00 ;przywrocenie wartosci
_p2 stx axlon
lda bsav,x
sta ext_b
inx
bne _p2
stx axlon ;ustaw bank podstawowy
rts
;zmienne
bsav .ds 256
