Interrupt Request

Interrupt Request
Redundanz Die Artikel Interrupt und Unterbrechungsanforderung überschneiden sich thematisch. Hilf mit, die Artikel besser voneinander abzugrenzen oder zu vereinigen. Beteilige dich dazu an der Diskussion über diese Überschneidungen. Bitte entferne diesen Baustein erst nach vollständiger Abarbeitung der Redundanz. Nachtigall 14:54, 5. Mai 2007 (CEST)

Eine Unterbrechungsanforderung oder englisch Interrupt Request (IRQ) löst eine Unterbrechung der Prozessbearbeitung eines Prozessors im System aus. In der Regel wird diese von Geräten im System durch eine Busleitung mit Namen IRQ signalisiert und der Prozessor reagiert mit einer Programmumschaltung oder englisch „context switch“ und führt die Unterbrechungsroutine aus. Nach deren Beendigung wird IRQ zurückgesetzt und die unterbrochene Aufgabe fortgesetzt. Eine Alternative Methode zu diesem Zweck ist das Polling.

Beispielsweise generiert die Tastatur einen Interrupt Request, wenn der Benutzer eine Taste gedrückt hat. Die Unterbrechungsroutine kann nun das jeweilige Zeichen von der Tastatursteuerung lesen und es an die jeweilige Anwendung weiterleiten.

Weitere Beispiele, in denen Geräte einen Interrupt Request generieren können:

  • Netzwerkkarte: wenn Daten empfangen wurden und im Puffer bereitliegen
  • Festplatte: wenn die vorher angeforderten Daten gelesen wurden und abholbereit sind (das Lesen von der Festplatte dauert relativ lange)
  • Grafikkarte: wenn das aktuelle Bild fertig gezeichnet wurde
  • Soundkarte: wenn wieder Sound-Daten zum Abspielen benötigt werden, bevor der Puffer leer wird.

Inhaltsverzeichnis

Interrupts und Polling

Interrupts ermöglichen das effiziente Reagieren auf Ereignisse. Die CPU kann unabhängig von den Geräten den Programmcode abarbeiten, wird beim Eintreffen eines Ereignisses unterbrochen, behandelt es entsprechend, und führt die unterbrochene Aufgabe fort.

Die Alternative, in einer Schleife auf das Ereignis zu warten oder regelmäßig ein Gerät nach einem bestimmten Ereignis abzufragen (Polling), benötigt sehr viel mehr Prozessor-Zeit, da ein großer Teil der Abfragen negative Ergebnisse liefern wird. Diese Methode wird jedoch in Systemen verwendet, die sehr zeitkritische Ereignisse behandeln. Dazu werden alle Unterbrechungen unterbunden, da sonst andere, weniger wichtige Geräte durch Unterbrechungen eine Verzögerung hervorrufen könnten.

Die Standard-Analogie für Interrupts im Alltag ist eine Tür mit Klingel: Während man seine Aufgaben erledigt, kann man jederzeit durch die Klingel unterbrochen werden, wenn ein Gast eine „Abarbeitung“ wünscht, und sich ihm dann zuwenden. Beim Polling – also ohne Klingel – müsste ständig an die Tür gelaufen werden, um nachzuschauen, ob Besuch da ist oder nicht. Beim Kochen von Milch hingegen ist es wohl besser, nicht erst auf den „Interrupt“ des Überkochens zu warten, sondern den Prozess vielmehr regelmäßig zu überwachen.

Funktionsweise

Die an die CPU angeschlossene Hardware muss interruptfähig sein, d. h. bei Eintreffen eines bestimmten Ereignisses über die sogenannte Interrupt-Leitung ein Ausgangssignal (elektrische Spannung an einem Ausgangs-Pin) erzeugen. Die CPU besitzt im einfachsten Falle einen entsprechenden Eingangs-Pin. Erscheint an diesem Pin eine elektrische Spannung, so startet innerhalb der CPU eine Sequenz von Befehlen, die die Unterbrechungsroutine (Interrupt Service Routine, kurz ISR) einleiten. In einfachen Implementierungen wird nur der gegenwärtige Zustand einiger interner CPU-Register auf dem Stack gesichert, die zur Fortführung des unterbrochenen Programmflusses nötig sind. Dann wird eine Sprungadresse geladen und ein Sprung in die ISR ausgeführt. Der Maschinencode der ISR wird vom Betriebssystem und den Treibern der Geräte installiert. Die Adressen der Unterbrechungsroutinen für alle IRQs befinden sich in der Interruptvektortabelle.

Interrupts können zeitweise von der CPU ignoriert werden, zum Beispiel wenn gerade ein anderer IRQ behandelt wird. Diese Maskierung gilt für alle Interrupts bis auf die nicht maskierbaren (NMI: Non Maskable Interrupt), die für spezielle Fälle vorgesehen sind (Hardware Fehler, Reset usw.), und für die so genannten Software-Interrupts, die durch einen Befehl in einem Programm ausgelöst werden (z. B. 'int IRQNUMMER' bei x86 – dieser Befehl wird beispielsweise von Linux genutzt, um von normalen Anwendungen über Systemaufrufe (syscalls) in den Kernel-Modus zu wechseln).

Latenzzeit

Die Zeit zwischen dem Anlegen des IRQ-Signals und dem Beginn der entsprechenden Verarbeitung nennt man Latenzzeit. Man spricht im Zusammenhang mit Realtime- oder Echtzeit-Betriebssystem davon, dass diese Latenzzeit immer kleiner als ein definierter Wert bleibt – also auch, wenn das System voll ausgelastet ist.

IBM-kompatible PCs

Die Interrupt Requests der Geräte werden zuerst vom Programmable Interrupt Controller entgegengenommen, der sie dann an einen Prozessor weiterleitet, und ihn damit unterbricht. Laufende Befehle werden daraufhin beendet, und der Interrupt wird beim Controller bestätigt. Als nächstes liest die CPU die Nummer des entsprechenden IRQ (Vektor) vom Controller, und verwendet ihn als Index in der Interruptvektortabelle, welche die jeweilige Behandlungsroutine für jeden IRQ enthält, die dann die entsprechenden gerätespezifische Aktion durchführen soll.

Bei modernen Systemen (zum Beispiel PCI-Systemen) ist das so genannte Interrupt-Sharing in der Regel ohne Probleme möglich. Dabei teilen sich mehrere Geräte einen Interrupt. Die Behandlungsroutine für einen solchen Interrupt muss dann alle Treiber, deren Geräte diesen Interrupt ausgelöst haben könnten, aufrufen (am IRQ kann dies nicht festgestellt werden). Hier kann es zu Problemen kommen, wenn einzelne Treiber z. B. aufgrund schlechter Programmierung zu lange aktiv sind, und in der Zwischenzeit im Gerät, welches den Interrupt ursprünglich ausgelöst hat, beispielsweise der Puffer voll wird und überläuft (d. h. im schlimmsten Fall: Datenverlust).

Bei modernen Peripheriegeräten kümmern sich der Computer und das Betriebssystem selbst um die Vergabe der IRQ-Nummern (PnP = Plug-and-Play-Geräte). Bei alten Steckkarten, z. B. ISA-Karten, müssen die IRQs von Hand eingestellt werden oder sind fest auf den Karten verdrahtet.

Unter Linux kann man die Interrupts mit folgendem Befehl abfragen: cat /proc/interrupts

IRQ-Geräte-Tabelle (Diese Liste unterscheidet sich von System zu System)

IRQ Verwendung
0 System-Taktgeber
1 Tastatur
2 Kaskadiert zu IRQ 9 (für 8-15)
3 COM 2,4,6,8 (EIA-232/RS-232)
4 COM 1,3,5,7
5 Frei ggf. LPT 2 (IEEE 1284)
6 Floppy Disk
7 LPT 1
8 Echtzeituhr (RTC)
9 Zu IRQ 2 umgeleitet (aber auch VGA und NIC, IRQ 16–23)
10 Frei ggf. PCI-Bus
11 Frei ggf. Adaptec-SCSI
12 PS/2
13 Mathematischer Coprozessor (FPU)
14 Primary IDE
15 Secondary IDE

Weblinks


Wikimedia Foundation.

Игры ⚽ Нужно сделать НИР?

Schlagen Sie auch in anderen Wörterbüchern nach:

  • Interrupt Request — Interrupt Request,   IRQ …   Universal-Lexikon

  • Interrupt request — IRQ redirects here. For the country with the ISO 3166 1 country code, see Iraq. The computing phrase interrupt request (or IRQ) is used to refer to either the act of interrupting the bus lines used to signal an interrupt, or the interrupt input… …   Wikipedia

  • Interrupt Request — Interruption matérielle On nomme IRQ (de l anglais Interrupt Request, en français: demande d interruption) une interruption qui est déclenchée par une ligne d entrée sortie matérielle d un microprocesseur ou d un microcontrôleur. Les… …   Wikipédia en Français

  • Interrupt Request Line —   [dt. »Unterbrechungsanforderungs Leitung«], Interrupt Leitung …   Universal-Lexikon

  • interrupt request —    Abbreviated IRQ. Hardware lines that carry a signal from a device to the processor.    A hardware interrupt signals that an event has taken place that requires the processor s attention. The interrupt may come from the keyboard, the network… …   Dictionary of networking

  • interrupt request (IRQ) signal —    A method by which I/O peripherals request attention from a PC s CPU …   IT glossary of terms, acronyms and abbreviations

  • interrupt request — noun The act of interrupting any of several hardware processes in a computer …   Wiktionary

  • Interrupt —   [dt. »Unterbrechung«] der, eine Unterbrechung des aktuellen Prozesses, die ein Prozessor in regelmäßigen Abständen oder bei Vorliegen einer entsprechenden Anfrage vornimmt, um Systemroutinen bzw. die Anforderung abzuarbeiten. Der Prozessor… …   Universal-Lexikon

  • Interrupt — This article is about computer interrupts. For the study of the effect of disruptions on job performance, see Interruption science. In computing, an interrupt is an asynchronous signal indicating the need for attention or a synchronous event in… …   Wikipedia

  • Interrupt priority level — The interrupt priority level (IPL) is a part of the current system interrupt state, which indicates the interrupt requests that will currently be accepted. The IPL may be indicated in hardware by the registers in a Programmable Interrupt… …   Wikipedia

Share the article and excerpts

Direct link
Do a right-click on the link above
and select “Copy Link”