Hallo kurze Frage Was gibt es für einen Grund, dass man das nicht so programmiert:
1 | cli(); |
2 | ...
|
3 | sei(); |
sondern so:
1 | byte oldSREG = SREG; |
2 | cli(); |
3 | ...
|
4 | SREG = oldSREG; |
|
Forum: Mikrocontroller und Digitale Elektronik Arduino: Syntax von cli() sei()
Announcement: there is an English version of this forum on EmbDev.net. Posts you create there will be displayed on Mikrocontroller.net and EmbDev.net.
Hallo kurze Frage Was gibt es für einen Grund, dass man das nicht so programmiert:
sondern so:
Wenn man portabel programmiert, schreibt man seine Funktion so, dass sie möglichst wenige Bedingungen an die Umgebung stellt. Die cli().... sei() Methode setzt voraus, dass vor dem cli() die Interrupts bereits eingeschaltet waren. Deshalb werden hier final die Interrupts eingeschaltet, obwohl sie vorher vielleicht abgeschaltet waren. Liegt das nicht auf der Hand? Im ersten Fall sind danach die Interrupts erlaubt. Im zweiten Fall hast du danach den gleichen zustand, wie davor. In der Praxis macht das nur selten einen Unterschied, weil man Interrupts nur für wenige zusammenhängende Zeilen deaktiviert. Fertige Libraries und Codefragmente für die Copy-Paste Entwickler sollte man aber schon so weitsichtig wie möglich gestalten - koste es was es wolle (siehe Arduino, Cube HAL, ASF, ect). Wenn es um maximale Kompatibilität geht würde ich atomic verwenden und dann
Veit D. schrieb: > Wenn es um maximale Kompatibilität geht Leider gibt es dieses Makro nur in der C Library für AVR, da endet die Kompatibilität schon. Bitte melde dich an um einen Beitrag zu schreiben. Anmeldung ist kostenlos und dauert nur eine Minute.
Bestehender Account
Schon ein Account bei Google/GoogleMail? Keine Anmeldung erforderlich!
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.
|
|