Unterschiede
Hier werden die Unterschiede zwischen zwei Versionen angezeigt.
Beide Seiten der vorigen Revision Vorhergehende Überarbeitung Nächste Überarbeitung | Vorhergehende Überarbeitung | ||
faecher:nwt:arduino:lernbaustein2:interrupt:start [22.05.2023 18:53] – sbel | faecher:nwt:arduino:lernbaustein2:interrupt:start [22.05.2023 19:27] (aktuell) – [Interrupts aktivieren/deaktivieren] sbel | ||
---|---|---|---|
Zeile 5: | Zeile 5: | ||
Wird ein Interrupt ausgelöst, wird der Ablauf des Programms angehalten, die Interrupt-Funktion ausgeführt ((" | Wird ein Interrupt ausgelöst, wird der Ablauf des Programms angehalten, die Interrupt-Funktion ausgeführt ((" | ||
- | Für ISR gelten einige besondere Regeln: | + | ===== Wie macht mans? ===== |
+ | |||
+ | Der Ardunio Uno hat zwei Interrupts, die Pins 2 und 3 können verwendet werden. Um eine Interrupt-Service-Routine mit einem Interrupt zu verknüpfen, | ||
+ | |||
+ | attachInterrupt(PIN, | ||
| | ||
- | | + | dabei ist: |
+ | * PIN: Der Pin, der die ISR Triggern soll | ||
+ | * ISR: Der Name der Funktion, die aufgerufen werden soll | ||
+ | * mode: Definiert, wann der Interrupt getriggert werden soll. Dafür sind bereuts 4 Konstanten definiert: | ||
+ | * LOW Interrupt wird getriggert, wenn der Pin LOW ist | ||
+ | * CHANGE Interrupt wird getriggert, wenn der Pin den Wert ändert | ||
+ | * RISING Interrupt wird getriggert, wenn der Pin von LOW auf HIGH wechselt | ||
+ | * FALLING Interrupt wird getriggert, wenn der Pin von HIGH auf LOW wechselt | ||
+ | |||
+ | |||
+ | ==== Beispiel 1 ==== | ||
+ | |||
+ | {{ : | ||
+ | |||
+ | ---- | ||
+ | {{: | ||
+ | === (A1) === | ||
+ | |||
+ | Das Programm steuert ein Lauflicht mit 8 LEDs. Erläutere, wie die LEDs anschlossen sein müssen, damit das funktioniert. Welche Verhaltensweise wird durch den Einsatz des Interrupts erreicht? | ||
+ | |||
+ | ---- | ||
+ | |||
+ | ==== ISR-Regeln ==== | ||
+ | |||
+ | |||
+ | Für ISR gelten einige besondere Regeln: | ||
+ | |||
+ | | ||
* ISR können keine Argumente bekommen oder Rückgabewerte zurückgeben. Stattdessen werden - ausnahmsweise! - globale Variablen benutzt, um Daten zwischen Interrupt Service Routinen und dem Hauptprogramm zu tauschen. Damit die Variablen dabei korrekt geändert werden, sollten sie als '' | * ISR können keine Argumente bekommen oder Rückgabewerte zurückgeben. Stattdessen werden - ausnahmsweise! - globale Variablen benutzt, um Daten zwischen Interrupt Service Routinen und dem Hauptprogramm zu tauschen. Damit die Variablen dabei korrekt geändert werden, sollten sie als '' | ||
* Einige Funktionen verhalten sich in ISRs anders als gewohnt oder funktionieren gar nicht: | * Einige Funktionen verhalten sich in ISRs anders als gewohnt oder funktionieren gar nicht: | ||
Zeile 15: | Zeile 46: | ||
* '' | * '' | ||
+ | |||
+ | ==== Beispiel 2 ==== | ||
+ | |||
+ | {{ : | ||
+ | |||
+ | ---- | ||
+ | {{: | ||
+ | === (A2) === | ||
+ | |||
+ | * Was könnte man mit dem Programmgerüst bei geeigneter ausgestaltung der Funktion '' | ||
+ | * Wie könnte man ein solches Konstrukt einsetzen, um z.B. einen Linienfolger zu steuern oder schnell auf ein Hindernis zu reagieren? | ||
+ | |||
+ | ==== Interrupts aktivieren/ | ||
+ | |||
+ | Manchmal möchte man in bestimmten Sequenzen eines Programms eine Unterbrechung des Ablaufs durch Interrupts nicht zulassen, in anderen aber schon. Dazu kann man dem Arduino mitteilen, ob er auf Interrupts reagieren soll oder nicht: | ||
+ | |||
+ | |||
+ | noInterrupts(); | ||
+ | // anderer Code, der nicht unterbrochen werden soll | ||
+ | interrupts(); | ||
+ | |||
+ | |||
+ | Weitere Informationen findest du hier: https:// | ||
+ | |||
+ | ==== Material ==== | ||
+ | |||
+ | {{simplefilelist>: |