Mikrocontroller - 8051 Interrupts
Interrupts sind die Ereignisse, die das Hauptprogramm vorübergehend anhalten, die Steuerung an die externen Quellen übergeben und deren Aufgabe ausführen. Anschließend wird die Steuerung an das Hauptprogramm übergeben, in dem sie aufgehört hat.
8051 hat 5 Interrupt-Signale, dh INT0, TFO, INT1, TF1, RI / TI. Jeder Interrupt kann durch Setzen von Bits des IE-Registers aktiviert oder deaktiviert werden, und das gesamte Interrupt-System kann durch Löschen des EA-Bits desselben Registers deaktiviert werden.
IE-Register (Interrupt Enable)
Dieses Register ist für das Aktivieren und Deaktivieren des Interrupts verantwortlich. Das EA-Register wird zum Aktivieren von Interrupts auf eins und zum Deaktivieren der Interrupts auf 0 gesetzt. Die Bitfolge und ihre Bedeutung sind in der folgenden Abbildung dargestellt.
EA | IE.7 | Es deaktiviert alle Interrupts. Bei EA = 0 wird kein Interrupt quittiert und EA = 1 aktiviert den Interrupt einzeln. |
- - | IE.6 | Reserviert für zukünftige Verwendung. |
- - | IE.5 | Reserviert für zukünftige Verwendung. |
ES | IE.4 | Aktiviert / deaktiviert den Interrupt der seriellen Schnittstelle. |
ET1 | IE.3 | Aktiviert / deaktiviert den Timer1-Überlauf-Interrupt. |
EX1 | IE.2 | Aktiviert / deaktiviert den externen Interrupt1. |
ET0 | IE.1 | Aktiviert / deaktiviert den Timer0-Überlauf-Interrupt. |
EX0 | IE.0 | Aktiviert / deaktiviert den externen Interrupt0. |
IP-Register (Interrupt Priority)
Wir können die Prioritätsstufen der Interrupts ändern, indem wir das entsprechende Bit im Interrupt Priority (IP) -Register ändern, wie in der folgenden Abbildung gezeigt.
Ein Interrupt mit niedriger Priorität kann nur durch den Interrupt mit hoher Priorität unterbrochen werden, nicht jedoch durch einen anderen Interrupt mit niedriger Priorität.
Wenn zwei Interrupts mit unterschiedlichen Prioritätsstufen gleichzeitig empfangen werden, wird die Anforderung einer höheren Prioritätsstufe bedient.
Wenn die Anforderungen mit denselben Prioritätsstufen gleichzeitig empfangen werden, bestimmt die interne Abfragesequenz, welche Anforderung bearbeitet werden soll.
- - | IP.6 | Reserviert für zukünftige Verwendung. |
- - | IP.5 | Reserviert für zukünftige Verwendung. |
PS | IP.4 | Es definiert die Interrupt-Prioritätsstufe der seriellen Schnittstelle. |
PT1 | IP.3 | Es definiert den Timer-Interrupt mit 1 Priorität. |
PX1 | IP.2 | Es definiert die Prioritätsstufe für externe Interrupts. |
PT0 | IP.1 | Es definiert die Timer0-Interrupt-Prioritätsstufe. |
PX0 | IP.0 | Es definiert den externen Interrupt der Prioritätsstufe 0. |
TCON-Register
Das TCON-Register gibt die Art des externen Interrupts für den Mikrocontroller an.