Przerwania

From Atariki

(Różnice między wersjami)
Jump to: navigation, search
Wersja z dnia 19:39, 12 sie 2005
Mikey (Dyskusja | wkład)

← Previous diff
Wersja z dnia 13:19, 13 sie 2005
KMK (Dyskusja | wkład)
(BRK to jest IRQ; oraz inne poprawki)
Next diff →
Linia 1: Linia 1:
-Procesor 6502 obsługuje 4 typy przerwań:+Procesor 6502 obsługuje 3 typy przerwań:
-- sprzętowe przerwanie CHIP RESET +* sprzętowe przerwanie CHIP RESET
-- IRQ (żądanie przerwania - maskowalne)+* [[IRQ]] (żądanie przerwania - maskowalne)
-- NMI (żądanie przerwania - niemaskowalne)+* [[NMI]] (żądanie przerwania - niemaskowalne)
-- programowy rozkaz/żądanie przerwania (rozkaz BRK) 
 +===CHIP RESET===
-'''1.CHIP RESET''' 
- +Przerwanie CHIP RESET jest wywoływane przez podanie procesorowi sygnału RST. Logika na płycie Atari robi to automatycznie po włączeniu zasilania a użytkownik może wywołać to przerwanie naciskając przycisk RESET. Domyślnym zachowaniem systemu po wywołaniu takiego przerwania jest skok do procedury zimnego startu.Procedura zimnego startu wygląda tak:
-Przerwanie CHIP RESET jest wywoływane przez podanie procesorowi sygnału RST. Logika na płycie Atari robi to automatycznie po włączeniu zasilania+
- +
-a użytkownik może wywołać to przerwanie naciskając przycisk RESET. Domyślnym zachowaniem systemu po wywołaniu takiego przerwania jest skok do +
- +
-procedury zimnego startu.Procedura zimnego startu wygląda tak:+
1. Flaga ciepłego startu (WARMST $0008) ustawiana jest na wartość 0 (fałsz - wykonujemy wszak zimny start) 1. Flaga ciepłego startu (WARMST $0008) ustawiana jest na wartość 0 (fałsz - wykonujemy wszak zimny start)
Linia 35: Linia 29:
8. Inicjalizowane są wektory przerwań. 8. Inicjalizowane są wektory przerwań.
-9. Adres najniższego wolnego bajta pamięci (MEMLO $2E7) ustawiany jest na $0700+9. Adres najniższego wolnego bajtu pamięci (MEMLO $2E7) ustawiany jest na $0700
10. Inicjalizowane są wszystkie rezydentne handlery CIO. 10. Inicjalizowane są wszystkie rezydentne handlery CIO.
Linia 45: Linia 39:
13. Jeśli włożony jest kartridż (inny niz diagnostyczny) - zostaje on zainicjalizowany. 13. Jeśli włożony jest kartridż (inny niz diagnostyczny) - zostaje on zainicjalizowany.
-14. Kanał we/wy #0 zostaje otworzony dla edytora ekranowego. Adres najwyższego wolnego bajta pamięci (MEMTOP $2E5) zostaje ustawiony na ostatni +14. Kanał we/wy #0 zostaje otworzony dla edytora ekranowego. MEMTOP ($02E5) zostaje ustawiony na pierwszy bajt po końcu pamięci RAM. Następuje otwarcie ekranu (po tej operacji MEMTOP wskazuje ostatni wolny bajt przed pamięcią ekranu).
-bajt przed pamięcią ekranu. Następuje zainicjowanie ekranu.+
15. Jeśli została ustawiona flaga żądania startu z kasety, następuje procedura startu z kasety. 15. Jeśli została ustawiona flaga żądania startu z kasety, następuje procedura startu z kasety.
-16. Jeśli nie ma kartridża albo nie zabrania on tego, następuje procedura startu z dysku.+16. Jeśli nie ma kartridża albo nie zabrania on tego, następuje procedura startu z dysku, a potem z [[nowe urządzenia|nowych urządzeń]] (to tylko w XL/XE).
17. Flaga zimnego startu zostaje skasowana. 17. Flaga zimnego startu zostaje skasowana.
Linia 62: Linia 55:
-1.Flaga ciepłego startu ustawiana jest na $7F (prawda)+1.Flaga ciepłego startu ustawiana jest na $FF (prawda)
2.Wykonywane są kroki 2-4 procedury zimnego startu. 2.Wykonywane są kroki 2-4 procedury zimnego startu.
Linia 70: Linia 63:
4.Wykonywane są kroki 7-14 procedury zimnego startu. 4.Wykonywane są kroki 7-14 procedury zimnego startu.
-5.Jeśli nastąpił boot z kasety system skacze pod adres zapisany w wektorze $CASINI $0002+5.Jeśli nastąpił boot z kasety system skacze pod adres zapisany w wektorze CASINI $0002
-6.Jeśli nastąpił boot z dysku system skacze pod adres zapisany w wektorze $DOSINI $000C+6.Jeśli nastąpił boot z dysku system skacze pod adres zapisany w wektorze DOSINI $000C
 +===NMI===
-'''2. NMI'''+Przerwania niemaskowalne są to zgłoszenia przerwań których, w przeciwieństwie do przerwań IRQ procesor nie może zignorować (zamaskować). Innymi słowy, procesor zawsze musi zareagować na zgłoszenie takiego przerwania.
- +
-Przerwania niemaskowalne są to zgłoszenia przerwań których, w przeciwieństwie do przerwań IRQ procesor nie może zignorować (zamaskować)+
-Innymi słowy, procesor zawsze musi zareagować na zgłoszenie takiego przerwania. +
- +
W komputerze Atari jedynym źródłem przerwań NMI jest układ ANTIC. W serii 400/800 również naciśnięcie SYSTEM RESET. W komputerze Atari jedynym źródłem przerwań NMI jest układ ANTIC. W serii 400/800 również naciśnięcie SYSTEM RESET.
Linia 86: Linia 76:
Antic zgłasza 2 przerwania NMI - przerwanie DLI oraz przerwanie VBLANK. Antic zgłasza 2 przerwania NMI - przerwanie DLI oraz przerwanie VBLANK.
 +Zob. [[NMI]]
 +
 +===IRQ===
-'''3. IRQ'''+Zob. [[IRQ]]
-'''4. BRK'''+[[Kategoria:Atari 8-bit]]
{{stub}} {{stub}}

Wersja z dnia 13:19, 13 sie 2005

Procesor 6502 obsługuje 3 typy przerwań:

  • sprzętowe przerwanie CHIP RESET
  • IRQ (żądanie przerwania - maskowalne)
  • NMI (żądanie przerwania - niemaskowalne)


CHIP RESET


Przerwanie CHIP RESET jest wywoływane przez podanie procesorowi sygnału RST. Logika na płycie Atari robi to automatycznie po włączeniu zasilania a użytkownik może wywołać to przerwanie naciskając przycisk RESET. Domyślnym zachowaniem systemu po wywołaniu takiego przerwania jest skok do procedury zimnego startu.Procedura zimnego startu wygląda tak:

1. Flaga ciepłego startu (WARMST $0008) ustawiana jest na wartość 0 (fałsz - wykonujemy wszak zimny start)

2. Sprawdzany jest stan kartridża. Jeśli włożono kart diagnostyczny - kontrola przekazywana jest do niego)

3. Określany jest adres konca pamięci RAM

4. Zerowane są rejestry sprzętowe od $D000 do $D4FF (z wyjątkiem obszaru $D100 - $D1FF)

5. Zerowana jest pamięć RAM od adresu $0008 do uprzednio obliczonego adresu końca RAM.

6. Wektor skoku do programu użytkownika (DOSVEC $000A) ustawiany jest na adres procedury MEMO PAD (400/800) albo procedury SELF-TEST (XL/XE)

7. Marginesy ekranu znakowego ustawiane są na wartości 2 i 39

8. Inicjalizowane są wektory przerwań.

9. Adres najniższego wolnego bajtu pamięci (MEMLO $2E7) ustawiany jest na $0700

10. Inicjalizowane są wszystkie rezydentne handlery CIO.

11. Jeśli naciśnięto START, ustawiana jest flaga żądania startu z kasety (CKEY $004A)

12. Tablica urządzeń CIO (HATABS) zostaje zainicjalizowana.

13. Jeśli włożony jest kartridż (inny niz diagnostyczny) - zostaje on zainicjalizowany.

14. Kanał we/wy #0 zostaje otworzony dla edytora ekranowego. MEMTOP ($02E5) zostaje ustawiony na pierwszy bajt po końcu pamięci RAM. Następuje otwarcie ekranu (po tej operacji MEMTOP wskazuje ostatni wolny bajt przed pamięcią ekranu).

15. Jeśli została ustawiona flaga żądania startu z kasety, następuje procedura startu z kasety.

16. Jeśli nie ma kartridża albo nie zabrania on tego, następuje procedura startu z dysku, a potem z nowych urządzeń (to tylko w XL/XE).

17. Flaga zimnego startu zostaje skasowana.

18. Jeśli włożono kartridż, system uruchamia go.

19. Jeśli nie ma kartridża system uruchamia program pod adresem wskazywanym przez DOSVEC.


W przypadku kiedy flaga zimnego startu zostala zmodyfikowana przez załadowany program, przerwanie CHIP RESET może wywołać tzw. ciepły start.


1.Flaga ciepłego startu ustawiana jest na $FF (prawda)

2.Wykonywane są kroki 2-4 procedury zimnego startu.

3.Zerowany jest RAM w obszarach $0010-007F i $0200-$03FF

4.Wykonywane są kroki 7-14 procedury zimnego startu.

5.Jeśli nastąpił boot z kasety system skacze pod adres zapisany w wektorze CASINI $0002

6.Jeśli nastąpił boot z dysku system skacze pod adres zapisany w wektorze DOSINI $000C


NMI

Przerwania niemaskowalne są to zgłoszenia przerwań których, w przeciwieństwie do przerwań IRQ procesor nie może zignorować (zamaskować). Innymi słowy, procesor zawsze musi zareagować na zgłoszenie takiego przerwania.

W komputerze Atari jedynym źródłem przerwań NMI jest układ ANTIC. W serii 400/800 również naciśnięcie SYSTEM RESET.

Antic zgłasza 2 przerwania NMI - przerwanie DLI oraz przerwanie VBLANK.

Zob. NMI

IRQ

Zob. IRQ


Ten artykuł to tylko zalążek. Możesz pomóc rozwojowi Atariki poprzez rozszerzenie go o więcej informacji.

Personal tools