Mikroprozessor - 8086 Interrupts
Interruptist die Methode zum Erstellen eines vorübergehenden Stopps während der Programmausführung und ermöglicht Peripheriegeräten den Zugriff auf den Mikroprozessor. Der Mikroprozessor reagiert auf diesen Interrupt mit einemISR (Interrupt Service Routine), ein kurzes Programm, mit dem der Mikroprozessor in den Umgang mit dem Interrupt eingewiesen wird.
Das folgende Bild zeigt die Arten von Interrupts, die wir in einem 8086-Mikroprozessor haben -
Hardware-Interrupts
Hardware-Interrupt wird von jedem Peripheriegerät verursacht, indem ein Signal über einen bestimmten Pin an den Mikroprozessor gesendet wird.
Der 8086 verfügt über zwei Hardware-Interrupt-Pins, dh NMI und INTR. NMI ist ein nicht maskierbarer Interrupt und INTR ist ein maskierbarer Interrupt mit niedrigerer Priorität. Ein weiterer zugeordneter Interrupt-Pin ist INTA, die als Interrupt-Bestätigung bezeichnet wird.
NMI
Es ist ein einzelner nicht maskierbarer Interrupt-Pin (NMI) mit höherer Priorität als der maskierbare Interrupt-Anforderungs-Pin (INTR) und vom Interrupt Typ 2.
Wenn dieser Interrupt aktiviert ist, finden diese Aktionen statt -
Vervollständigt die aktuelle Anweisung, die gerade ausgeführt wird.
Schiebt die Flag-Registerwerte auf den Stapel.
Schiebt den CS-Wert (Codesegment) und den IP-Wert (Befehlszeiger) der Rücksprungadresse auf den Stapel.
IP wird aus dem Inhalt der Wortposition 00008H geladen.
CS wird aus dem Inhalt der nächsten Wortstelle 0000AH geladen.
Interrupt-Flag und Trap-Flag werden auf 0 zurückgesetzt.
INTR
Der INTR ist ein maskierbarer Interrupt, da der Mikroprozessor nur unterbrochen wird, wenn Interrupts unter Verwendung des Befehls zum Setzen eines Interrupt-Flags aktiviert werden. Es sollte nicht mit der Anweisung zum Löschen des Interrupt-Flags aktiviert werden.
Der INTR-Interrupt wird über einen E / A-Port aktiviert. Wenn der Interrupt aktiviert und NMI deaktiviert ist, schließt der Mikroprozessor zuerst die aktuelle Ausführung ab und sendet zweimal '0' an den INTA-Pin. Die erste '0' bedeutet, dass INTA das externe Gerät anweist, sich fertig zu machen, und während der zweiten '0' empfängt der Mikroprozessor das 8-Bit, beispielsweise X, von der programmierbaren Interrupt-Steuerung.
Diese Maßnahmen werden vom Mikroprozessor ergriffen -
Vervollständigt zuerst die aktuelle Anweisung.
Aktiviert die INTA-Ausgabe und empfängt den Interrupt-Typ, z. B. X.
Der Flag-Registerwert, der CS-Wert der Rücksprungadresse und der IP-Wert der Rücksprungadresse werden auf den Stapel übertragen.
Der IP-Wert wird aus dem Inhalt der Wortposition X × 4 geladen
CS wird aus dem Inhalt der nächsten Wortstelle geladen.
Interrupt-Flag und Trap-Flag werden auf 0 zurückgesetzt
Software-Interrupts
Einige Anweisungen werden an der gewünschten Stelle in das Programm eingefügt, um Interrupts zu erzeugen. Diese Interrupt-Anweisungen können verwendet werden, um die Funktion verschiedener Interrupt-Handler zu testen. Es beinhaltet -
INT- Befehl mit Typennummer unterbrechen
Es ist eine 2-Byte-Anweisung. Das erste Byte liefert den Operationscode und das zweite Byte die Nummer des Interrupt-Typs. Es gibt 256 Interrupt-Typen unter dieser Gruppe.
Die Ausführung umfasst die folgenden Schritte:
Der Flag-Registerwert wird auf den Stapel übertragen.
Der CS-Wert der Rücksprungadresse und der IP-Wert der Rücksprungadresse werden auf den Stapel übertragen.
IP wird aus dem Inhalt des Wortorts 'Typnummer' × 4 geladen
CS wird aus dem Inhalt der nächsten Wortstelle geladen.
Interrupt Flag und Trap Flag werden auf 0 zurückgesetzt
Die Startadresse für den Interrupt vom Typ 0 lautet 000000H, für den Interrupt vom Typ 1 00004H, ähnlich wie für den Interrupt vom Typ 00 00008H und …… usw. Die ersten fünf Zeiger sind dedizierte Interrupt-Zeiger. dh -
TYPE 0 Interrupt repräsentiert die Division durch Nullsituation.
TYPE 1 Interrupt repräsentiert die einstufige Ausführung während des Debuggens eines Programms.
TYPE 2 Interrupt repräsentiert einen nicht maskierbaren NMI-Interrupt.
TYPE 3 Interrupt steht für Break-Point-Interrupt.
TYPE 4 Interrupt steht für Überlauf-Interrupt.
Die Interrupts von Typ 5 bis Typ 31 sind für andere fortschrittliche Mikroprozessoren reserviert, und Interrupts von 32 bis Typ 255 sind für Hardware- und Software-Interrupts verfügbar.
INT 3-Break Point Interrupt-Anweisung
Es ist ein 1-Byte-Befehl mit dem Op-Code CCH. Diese Anweisungen werden in das Programm eingefügt, sodass der Prozessor, wenn er dort ankommt, die normale Programmausführung stoppt und der Haltepunktprozedur folgt.
Die Ausführung umfasst die folgenden Schritte:
Der Flag-Registerwert wird auf den Stapel übertragen.
Der CS-Wert der Rücksprungadresse und der IP-Wert der Rücksprungadresse werden auf den Stapel übertragen.
IP wird aus dem Inhalt der Wortposition 3 × 4 = 0000CH geladen
CS wird aus dem Inhalt der nächsten Wortstelle geladen.
Interrupt Flag und Trap Flag werden auf 0 zurückgesetzt
INTO - Unterbrechung bei Überlaufanweisung
Es ist eine 1-Byte-Anweisung und ihre Mnemonik INTO. Der Op-Code für diese Anweisung lautet CEH. Wie der Name schon sagt, handelt es sich um einen bedingten Interrupt-Befehl, dh er ist nur aktiv, wenn das Überlauf-Flag auf 1 gesetzt ist und zum Interrupt-Handler verzweigt, dessen Interrupt-Typ-Nummer 4 ist. Wenn das Überlauf-Flag zurückgesetzt wird, wird die Ausführung mit dem fortgesetzt nächste Anweisung.
Die Ausführung umfasst die folgenden Schritte:
Flag-Register-Werte werden auf den Stapel übertragen.
Der CS-Wert der Rücksprungadresse und der IP-Wert der Rücksprungadresse werden auf den Stapel übertragen.
IP wird aus dem Inhalt der Wortposition 4 × 4 = 00010H geladen
CS wird aus dem Inhalt der nächsten Wortstelle geladen.
Interrupt-Flag und Trap-Flag werden auf 0 zurückgesetzt