Przerwania

From Atariki

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

← Previous diff
Aktualna wersja
KMK (Dyskusja | wkład)

Linia 1: Linia 1:
==6502== ==6502==
-Procesor [[6502]] obsługuje 3 typy przerwań:+[[Procesor]]y [[6502]] i [[65C02]] obsługują 4 typy przerwań:
* [[IRQ]] (żądanie przerwania - maskowalne) * [[IRQ]] (żądanie przerwania - maskowalne)
* [[RESET]] * [[RESET]]
* [[NMI]] (żądanie przerwania - niemaskowalne) * [[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 drugie nie zostanie obsłużone. Zostało to poprawione w procesorze [[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.
 + 
 +Jest to w zasadzie błąd w oryginalnej dokumentacji 6502, który spowodował, że sygnał NMI podawany przez układy specjalizowane zbudowane na jej podstawie - np. przez ANTIC - jest za krótki w stosunku do rzeczywistych wymagań procesora.
 + 
 +Zostało to poprawione w 65C02 (i jego następcy, 65C816). W przypadku 6502 poprawka może polegać na sztucznym [http://atariage.com/forums/topic/148595-how-can-pokey-irq-timers-mess-up-nmi-timing/page-8#entry1822388 wydłużeniu sygnału NMI].
==65C816== ==65C816==
Linia 13: Linia 18:
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]] (przerwanie programowe)
-* [[COP]] (programowe przerwanie niemaskowalne)+* [[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.
-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]].+==Zobacz też==
 +* [http://pl.wikipedia.org/wiki/Przerwanie Przerwanie] (pl.wiki)
[[Kategoria:Menu Główne]] [[Kategoria:Menu Główne]]
[[Kategoria:Programowanie Atari 8-bit]] [[Kategoria:Programowanie Atari 8-bit]]

Aktualna wersja

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.

Jest to w zasadzie błąd w oryginalnej dokumentacji 6502, który spowodował, że sygnał NMI podawany przez układy specjalizowane zbudowane na jej podstawie - np. przez ANTIC - jest za krótki w stosunku do rzeczywistych wymagań procesora.

Zostało to poprawione w 65C02 (i jego następcy, 65C816). W przypadku 6502 poprawka może polegać na sztucznym wydłużeniu sygnału NMI.

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ż

Personal tools