Przerwania

From Atariki

(Różnice między wersjami)
Jump to: navigation, search
Wersja z dnia 05:32, 21 gru 2005
KMK (Dyskusja | wkład)

← Previous diff
Wersja z dnia 20:23, 6 sie 2006
Miker (Dyskusja | wkład)
(usunięto powtarzające się linki)
Next diff →
Linia 7: Linia 7:
* [[NMI]] (żądanie przerwania - niemaskowalne) * [[NMI]] (żądanie przerwania - niemaskowalne)
-W procesorze 6502 jest błąd polegający na tym, że jeśli przerwanie NMI i IRQ wystąpią jednocześnie, to drugie 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 drugie nie zostanie obsłużone. Zostało to poprawione w 65C02 (i jego następcy, 65C816).
==65C816== ==65C816==
Linia 13: Linia 13:
Procesor [[65C816]] obsługuje sześć typów przerwań: Procesor [[65C816]] obsługuje sześć typów przerwań:
-* [[IRQ]] (żądanie przerwania - maskowalne)+* IRQ (żądanie przerwania - maskowalne)
-* [[RESET]]+* RESET
-* [[NMI]] (żądanie przerwania - niemaskowalne)+* NMI (żądanie przerwania - niemaskowalne)
* [[ABORT]] * [[ABORT]]
* [[BRK]] (programowe przerwanie maskowalne) * [[BRK]] (programowe przerwanie maskowalne)
* [[COP]] (programowe przerwanie niemaskowalne) * [[COP]] (programowe przerwanie niemaskowalne)
-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. Przerwanie [[BRK]] jest wektorowane oddzielnie tylko w trybie natywnym procesora, natomiast w trybie emulacji jest traktowane jako [[IRQ]].+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. Przerwanie BRK jest wektorowane oddzielnie tylko w trybie natywnym procesora, natomiast w trybie emulacji jest traktowane jako IRQ.
[[Kategoria:Menu Główne]] [[Kategoria:Menu Główne]]
[[Kategoria:Programowanie Atari 8-bit]] [[Kategoria:Programowanie Atari 8-bit]]

Wersja z dnia 20:23, 6 sie 2006

6502

Procesory 6502 i 65C02 obsługują 3 typy przerwań:

  • IRQ (żądanie przerwania - maskowalne)
  • RESET
  • NMI (żądanie przerwania - niemaskowalne)

W procesorze 6502 jest błąd polegający na tym, że jeśli przerwanie NMI i IRQ wystąpią jednocześnie, to drugie 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 (programowe przerwanie maskowalne)
  • COP (programowe przerwanie niemaskowalne)

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. Przerwanie BRK jest wektorowane oddzielnie tylko w trybie natywnym procesora, natomiast w trybie emulacji jest traktowane jako IRQ.

Personal tools