Hallo, ich schreibe gerade ein Programm, welches die UART Schnittstelle eines Atmel AVR nutzt. Vor dem Empfang des ersten Datenbytes möchte ich das USART Receive Complete Flag (Register: UCSR1A, Bit: RXC1) auf 0 setzen, da ich dieses Bit nutze um auf die zu empfangenenen Daten zu warten. Das Bit lässt sich laut Datenblatt aber nur durchs Auslesen des Datenregisters UDR1 rücksetzen. D.h. zum Rücksetzen müsste ich z.B. diese Operation ausführen: uint8_t u8_Temp = UDR1; Da kommt dann aber noch die Compilerwarnung, dass ich diese Variable nicht nutze (mache ich ja auch nicht...). Da der Compiler vom Warn- und Fehlerverhalten her so bleiben soll wie er ist, müsste ich um den Hinweis zu unterdrücken etwas in der Art machen: uint8_t u8_Temp = UDR1; u8_Temp++; Das finde ich aber sehr unschön... Kennt wer einen einfacheren Weg? Ich vermute eine Lösung die auf Assembler baut, aber Assembler ist nicht grad meine Stärke :-) Gruß, André
einfach nur
1 | UDR1; |
müsste die Warnung zum Verschwinden bringen. Das mag für dich jetzt ungewöhnt aussehen, aber eine Expression ist ein gültiges Statement. Niemand sagt, dass man mit dem Eregbnis eines Ausdrucks etwas machen muss. Du schreibst ja auch bedenkenlos
1 | i++; |
ohne dir darüber Gedanken zu machen, was mit dem Ergebnis dieses arithmetischen Ausdrucks zu passieren hat. Du bist nur am Nebeneffekt interessiert und genau das gleiche gilt auch für
1 | UDR1; |
wegoptimieren kann der Compiler diesen Ausdruck nicht, da UDR1, wie alle Prozessorregister, volatile ist.
Oder, mit etwas Dokumentations-Seiteneffekt:
1 | (void)UDR1; |
Stimmt :-) Ich war so fixiert darauf die Daten irgendwo speichern zu müssen dass ich die Möglichkeit ganz ausgeblendet habe... Vielen Dank für die schnelle Antwort!
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
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.