Przerwania
From Atariki
(Różnice między wersjami)
												
			
			| 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ń:
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.
