Ja, das ist schon klar.
Aber wie gesagt, ich würde alles in den Interrupt rein packen.
Werbung
Ja, das ist schon klar.
Aber wie gesagt, ich würde alles in den Interrupt rein packen.
Geändert von TobiKa (24.04.2011 um 13:42 Uhr)
Hi ihr beiden!
Danke euch für eure Unterstützung!
@Sternst: Vielen, vielen dank für diese Erklärung! Das wird mich vermutlich in Zukunft vor solchen Problemen bewahren.![]()
ich hab befürchtet, dass ich was prinzipiell einfaches übersehen hab...
ist das selbe wieCode:ATOMIC_BLOCK(ATOMIC_FORCEON){ ... }oder? Nur, dass ich nicht noch "util/atomic.h" include (wenn ich die Datei richtig lese...).Code:cli(); ... sei();
@TobiKa: An der Hochschule hat man mir eingebleut, dass Interruptroutinen so kurz wie nur irgendmöglich sein sollen. Daher hab' ich die (unkritischen) Teile aus der Routine herausgelöst...
Und wenn ich es in den Interrupt lege sehe ich auch keinen echten Vorteil...
Nun, fast.ist das selbe wie
ATOMIC_BLOCK bietet einen besseren Schutz gegen Code-Reordering. Und es stellt sicher, dass die Interrupts wieder eingeschaltet werden, egal auf welchem Exit-Pfad der Code-Block verlassen wird (du kannst sogar ohne Probleme "return" innerhalb des Blockes verwenden).
MfG
Stefan
Ja da hast du schon recht, aber 3 Abfragen und 3 Zuweisungen sollten kein Problem sein.@TobiKa: An der Hochschule hat man mir eingebleut, dass Interruptroutinen so kurz wie nur irgendmöglich sein sollen. Daher hab' ich die (unkritischen) Teile aus der Routine herausgelöst...
Und wenn ich es in den Interrupt lege sehe ich auch keinen echten Vorteil...
Ich sehe bei deiner Variante Probleme falls "UART" mal länger braucht und g_msec irgendwann überläuft.
Lesezeichen