Hallo, ich möchte eine Function bauen die mithilfe des Timer1 ein Signal bestimmter Länge an einen Pin sendet. Der Timer(im normal-mode) funktioniert auch soweit (mit Interrupt getestet) aber die Schleife in der Funktion wird nicht ausgeführt. Hier der Code: >void _impulse_en(uint64_t microseconds) >{ > PORTB |= (1<<_en); > > uint16_t current = TCNT1; > while(microseconds > 0) > { > if(TCNT1 < current) > { > current = TCNT1; > microseconds --; > } > } > > PORTB ^= (1<<_en); >} Wenn ich allerdings TCNT1 in der Schleife inkrementiere, wird sie ausgeführt. Offensichtlich denkt der Compiler, dass die Bedingung in der Schleife nie zutrifft. Dabei beachtet er aber den Timer nicht, der TCNT1 jede Millisekunde inkrementiert. Kann ich dieses Phänomen irgendwie umgehen? Danke schonmal!
Ergänzung: Im Timer1 normal Mode wird TCNT1 bei einem Overflow auf 0 zurückgesetzt. An der Stelle würde die Bedingung in der Schleife zutreffen. Wenn ich TCNT1 in der Schleife aktiv verändern würde, (simulation des Timers) dann würde die Schleife wie erwartet ausgeführt werden.
ATmegaTimer schrieb: > funktioniert auch soweit (mit Interrupt getestet) aber die Schleife in > der Funktion wird nicht ausgeführt. Das glaube ich nicht. Die wird eher als Endlosschleife laufen, wenn TCNT1 nach dem Programmstart den Startwert 0 hat. Oliver
Hallo, dafür wird es bestimmt Tausende Lösungen geben. Mit deinem Weg würde ich bei Bedarf den Timer mit Zähler 0 starten und wenn der Compare Interrupt auslöst den Timer gleichzeitig wieder stoppen. Bei Start und Stopp den Pin entsprechend schalten.
:
Bearbeitet durch User
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.