NMI
From Atariki
Wersja z dnia 01:38, 2 lis 2005 KMK (Dyskusja | wkład) (→Atari 8-bit) ← Previous diff |
Wersja z dnia 01:38, 2 lis 2005 KMK (Dyskusja | wkład) (→Atari ST i pochodne) Next diff → |
||
Linia 28: | Linia 28: | ||
W komputerach XL/XE, jak to zostało już wyżej napisane, przerwanie NMI RESET jest niewykorzystane (i tym samym nieobsługiwane przez [[XL OS]]), zamiast niego używa się głownego przerwania [[RESET]] (CPU RESET). | W komputerach XL/XE, jak to zostało już wyżej napisane, przerwanie NMI RESET jest niewykorzystane (i tym samym nieobsługiwane przez [[XL OS]]), zamiast niego używa się głownego przerwania [[RESET]] (CPU RESET). | ||
- | ====Atari ST i pochodne==== | + | == Atari ST i pochodne == |
W procesorach Motoroli serii 68k przerwanie niemaskowalne jest to przerwanie o najwyższym priorytecie, którego nie da się zablokować maską przerwań CPU. Autowektor NMI jest to wektor numer 31 o adresie $007C (plus zawartość rejestru [[VBR]]). W Atari serii ST to przerwanie normalnie nie ma żadnego zastosowania. | W procesorach Motoroli serii 68k przerwanie niemaskowalne jest to przerwanie o najwyższym priorytecie, którego nie da się zablokować maską przerwań CPU. Autowektor NMI jest to wektor numer 31 o adresie $007C (plus zawartość rejestru [[VBR]]). W Atari serii ST to przerwanie normalnie nie ma żadnego zastosowania. |
Wersja z dnia 01:38, 2 lis 2005
NMI - ang. Non-Maskable Interrupt - przerwanie niemaskowalne.
Rodzaj przerwania, które w momencie wystąpienia (najpóźniej po zakończeniu wykonywania bieżącego rozkazu) musi być przyjęte i obsłużone przez procesor. A to w odróżnieniu od IRQ, które przyjęte i obsłużone być tylko może.
Atari 8-bit
W procesorze 6502 i 65c02 główny wektor przerwania NMI znajduje się pod adresem $FFFA.
W procesorze 65c816 pod adresem $00FFFA znajduje się wektor przerwania NMI dla trybu emulacji 6502. Gdy procesor jest przełączony w tryb natywny 65c816, adres procedury obsługi NMI jest pobierany spod $00FFEA.
W ośmiobitowym Atari mamy trzy przerwania niemaskowalne: DLI, VBL oraz NMI RESET. Źródłem wszystkich jest układ Antic. Przerwanie NMI RESET jest stosowane w komputerach 400/800, gdzie wywołuje je naciśnięcie klawisza RESET, natomiast w XL/XE klawisz RESET wywołuje przerwanie RESET procesora 6502, a przerwanie NMI RESET Antica jest niewykorzystane.
Priorytety NMI
W procesorach 6502, 65C02 i 65C816 nie ma żadnej koncepcji priorytetów przerwań, ustala je OS na drodze programowej kontrolując po kolei wszystkie możliwe źródła wystąpienia NMI. W Atari priorytet obsługi jest następujący (w kolejności od najwyższego do najniższego):
1) Seria 400/800
- DLI
- NMI RESET
- VBL
2) Seria XL/XE
- DLI
- VBL
W komputerach XL/XE, jak to zostało już wyżej napisane, przerwanie NMI RESET jest niewykorzystane (i tym samym nieobsługiwane przez XL OS), zamiast niego używa się głownego przerwania RESET (CPU RESET).
Atari ST i pochodne
W procesorach Motoroli serii 68k przerwanie niemaskowalne jest to przerwanie o najwyższym priorytecie, którego nie da się zablokować maską przerwań CPU. Autowektor NMI jest to wektor numer 31 o adresie $007C (plus zawartość rejestru VBR). W Atari serii ST to przerwanie normalnie nie ma żadnego zastosowania.