Przerwania
From Atariki
Wersja z dnia 10:53, 28 wrz 2012 Xxl (Dyskusja | wkład) ← Previous diff |
Wersja z dnia 00:50, 24 mar 2016 KMK (Dyskusja | wkład) Next diff → |
||
Linia 6: | Linia 6: | ||
* [[RESET]] | * [[RESET]] | ||
* [[NMI]] (żądanie przerwania - niemaskowalne) | * [[NMI]] (żądanie przerwania - niemaskowalne) | ||
- | * [[BRK]] (przerwanie programowe) | + | * [[BRK]] (przerwanie programowe, wektorowane jako IRQ) |
W procesorze 6502 jest błąd polegający na tym, że jeśli przerwanie NMI i IRQ wystąpią jednocześnie, to pierwsze nie zostanie obsłużone. Zostało to poprawione w 65C02 (i jego następcy, 65C816). | W procesorze 6502 jest błąd polegający na tym, że jeśli przerwanie NMI i IRQ wystąpią jednocześnie, to pierwsze nie zostanie obsłużone. Zostało to poprawione w 65C02 (i jego następcy, 65C816). |
Wersja z dnia 00:50, 24 mar 2016
6502
Procesory 6502 i 65C02 obsługują 4 typy przerwań:
- IRQ (żądanie przerwania - maskowalne)
- RESET
- NMI (żądanie przerwania - niemaskowalne)
- BRK (przerwanie programowe, wektorowane jako IRQ)
W procesorze 6502 jest błąd polegający na tym, że jeśli przerwanie NMI i IRQ wystąpią jednocześnie, to pierwsze nie zostanie obsłużone. Zostało to poprawione w 65C02 (i jego następcy, 65C816).
65C816
Procesor 65C816 obsługuje sześć typów przerwań:
- IRQ (żądanie przerwania - maskowalne)
- RESET
- NMI (żądanie przerwania - niemaskowalne)
- ABORT
- BRK (przerwanie programowe)
- COP (przerwanie programowe)
W odpowiedzi na przerwanie procesor automatycznie kasuje znacznik D rejestru znaczników (przełącza ALU z trybu dziesiętnego w binarny), czego 6502 nie robi. Przerwanie RESET powoduje dodatkowo ustawienie znacznika E, czyli przełączenie procesora w tryb emulacji 6502.
Różnica między obydwoma przerwaniami programowymi polega na tym, że BRK jest wektorowane oddzielnie w trybie natywnym, a w trybie emulacji jako IRQ, natomiast COP używa własnego wektora w obydwu trybach.
Zobacz też
- Przerwanie (pl.wiki)