Hallo Kollegen, entschuldigt bitte die komplette Newbie-Frage. ich möchte mein Timer-ISR() um 2 seconden verlängern, bei einer aclk-quelle von 32kHz. leider bringt mir mein vorgehensweise in diesem Codeabschnitt keinen Erfolg, der Timer reagiert irgenwie nicht darauf... wenn ich ihm mit 32768 --> 1 sec füttere funktioniert. _EINT(); . . . TACCR0 = TAR+65534; //65534-->2 sec, bei einem aclk = 32kHz //TAR = aktuelle wert TACCTL0 |= CCIE; //TA0 IE aktiv MFG W
Das ist doch ein 16 Bit Timer. D.h da geht maximal 65535 rein. Die Zeile TACCR0 = TAR+65534; für also zum Überlauf. Du solltest mit Vorteiler arbeiten und den Timer mit geringerem Takt füttern.
Hallo, > TACCR0 = TAR+65534; > für also zum Überlauf. die Zeile => CCR0 = TAR+65534; ergibt bei ausfüehren eigentlich das gleiche verhalten wie (CCR0 = TAR-1) - der Timer soll eigentlich nur 16 bit zählen (65534) = 2 sec, > Du solltest mit Vorteiler arbeiten und den Timer mit geringerem Takt > füttern. mein Timer darf nich geädert werden! ich verstehe wirklich nicht genau was du meinst, hast du vielleicht einen Vorschlag wie der Quellcode aussehen sollte. MFG W
>ich verstehe wirklich nicht genau was du meinst
Das trifft auf mich und deine Ausführungen ebenfalls zu... Schreib mal
genau was du vorhast, dann können wir dir helfen.
ok,
es geht um eine USCI kommunication....
die RX-ISR() soll 2 sec lang empfangsbereit, nachdem senden (TX_ISR())
des letzten Bytes bleiben, sollte innerhalb diese Zeit weitere Bytes
kommen, so wird die 2sec auktalisiert und sich verlangert, das erklärt
>(CCR0 = TAR+65534;).
wenn nicht wird die RX-ISR() nach 2 sec ausgeschalten. und weiter
Aufgaben erledigen.
//USCI_A0 interrupt service routine
#pragma vector=USCIAB0TX_VECTOR
__interrupt void USCIA0TX_ISR (void)
{
if(trasmit_Complete){
Disable_TxInt(); // TX-interrupt AUSSCHALTEN
TACCR0 = TAR+65534; // 2 sec
Enable_RxInt(); // Enable RX_int (USCI)
TACCTL0 |=CCIE; // Timer interrupt enable
trasmit_Complete = false;
}
else{
if(char.getNextExist())
UCA0TXBUF = char;
else
trasmit_Complete = true;
}
}
Danke für sie schnellen Antworten.
MFG
W
Zanzana schrieb: > die RX-ISR() soll 2 sec lang empfangsbereit, nachdem senden (TX_ISR()) > des letzten Bytes bleiben, sollte innerhalb diese Zeit weitere Bytes > kommen, so wird die 2sec auktalisiert und sich verlangert, das erklärt >>(CCR0 = TAR+65534;). > wenn nicht wird die RX-ISR() nach 2 sec ausgeschalten. und weiter > Aufgaben erledigen. Und was soll das? Warum nicht einfach die RX-ISR aktiviert lassen? Hältst Du Dir den ganzen Tag die Ohren zu, und nimmst nur während eines Gespräches die Hände von den Ohren?
> Und was soll das? Warum nicht einfach die RX-ISR aktiviert lassen?
es geht um Energie sparendes Modul, muss immer ins lpm gehen
RX-ISR darf erst aktiviert wenn bestimmte kriterien vorliegen, u.a
baudrate...
Geht es denn darum, auf der seriellen Schnittstelle empfangene Daten aktiv zu ignorieren?
Rufus t. Firefly schrieb: > Geht es denn darum, auf der seriellen Schnittstelle empfangene Daten > aktiv zu ignorieren? ja u.a unerlaubte zugriffe und manipulation. und ins lpm mode zu gehen (energie sparend)
Wenn ich das jetzt richtig verstehe, ist deine Verlängerung doch im prinzip durch das rücksetzen des Timers zu erreichen. TAR = 0; sollte doch deinen Wunsch erfüllen.
@ Jörg S. > Wenn ich das jetzt richtig verstehe, ist deine Verlängerung doch im > prinzip durch das rücksetzen des Timers zu erreichen. > TAR = 0; sollte doch deinen Wunsch erfüllen. natürlich hast du Recht und habe auch daran gedacht, leider wird der Timer für andere zwecke auch verwendet und ist somit die ganze Zeit in count mode, es darf nicht resetet werden usw. die ressourcen werden gemeinsam genutzt (sharing)
Hallo, ich habe mein Problem gelöst, vielleicht hilft das jemanden in die Zukunft. Interrupt Flag löschen > //USCI_A0 interrupt service routine > #pragma vector=USCIAB0TX_VECTOR > __interrupt void USCIA0TX_ISR (void) > { > if(trasmit_Complete){ > Disable_TxInt(); // TX-interrupt AUSSCHALTEN TACCTL0 &=~CCIFG; // clear interrupt flag TACCR0 = TAR; // 2 sec die nächste Zeile ist auch richtig, habe mich aber für die obere Zeile entschieden. > TACCR0 = TAR+65534; // 2 sec > Enable_RxInt(); // Enable RX_int (USCI) > TACCTL0 |=CCIE; // Timer interrupt enable > trasmit_Complete = false; > } > else{ > if(char.getNextExist()) > UCA0TXBUF = char; > else > trasmit_Complete = true; > } > } > > > Danke für sie schnellen Antworten. > MFG > W
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.