- 12V Akku mit 280 Ah bauen         
Seite 2 von 4 ErsteErste 1234 LetzteLetzte
Ergebnis 11 bis 20 von 33

Thema: Timer beim ATMega32 in C

  1. #11
    Erfahrener Benutzer Robotik Einstein
    Registriert seit
    07.03.2011
    Beiträge
    1.899
    Anzeige

    E-Bike
    Zitat Zitat von wkrug Beitrag anzeigen
    In diesem Interrupt würde ich nur ein Flag setzen ( Bit Variable ) und im Hauptprogramm dieses Flag wieder löschen, sobald es verarbeiet wurde.
    Wozu dann überhaupt eine ISR? Dann kannst du ja gleich das Interrupt Status Bit in der Mainloop pollen.

    MfG Klebwax
    Strom fließt auch durch krumme Drähte !

  2. #12
    Neuer Benutzer Öfters hier
    Registriert seit
    05.06.2012
    Beiträge
    14
    auch nach vielen versuchen und änderungen will der code nicht. jetzt wird zu langsam gezählt

    #include <avr/interrupt.h>
    ...
    unsigned long int timerLauf= 0;
    ...
    int main (void)
    {
    TCCR1B |= (1<<CS02) | (1<<CS00);
    OCR1A = 15625;
    TIMSK |= (1<<OCIE1A);
    sei();
    ...
    }

    ISR (TIMER1_COMPA_vect)
    {
    timerLauf++;
    }
    was mache ich nur falsch?
    Geändert von tom77? (10.06.2012 um 15:37 Uhr)

  3. #13
    Erfahrener Benutzer Roboter-Spezialist Avatar von robo_tom_24
    Registriert seit
    04.02.2012
    Ort
    Burgenland, Österreich
    Beiträge
    485
    Hast du den Quarz richtig eingestellt?

    Setzt du den Timer auch wieder zurück nachdem der ISR aufgerufen wurde?
    Du musst noch ins Register TCCR1B das Bit CTC aktivieren -> Clear Timer on Compare Match -> Rücksetzen nach Abgleich

    Wahrscheinlich zählt der Timer 1 mal richtig und dann zählt er immer die vollen 65535 Schritte durch
    Also ca so:
    Timerwert: 0...........15625 *INTERRUPT* ..............65535 - 0 ........ 15625 *INTERRUPT* ...........65535 - 0 .........15625 *INTERRUPT*.... ->
    Zeiterlauf: 0s.................1s............................. ...................................4,2s........... ............................................8,4s.. ................. ->
    Variable:...0....................1................ .................................................. 2................................................. ...........3.................... ->

  4. #14
    Neuer Benutzer Öfters hier
    Registriert seit
    05.06.2012
    Beiträge
    14
    wenn ich das CTC aktiviere lässt sich der code nicht kompilieren

    TCCR1B |= (1<<CTC) | (1<<CS02) | (1<<CS00);
    error: 'CTC' undeclared (first use in this function)

    achja: quarz ist richtig eingestellt (getestet mit _delay_ms(xx) -> funktioniert exakt, auch gemessen mit dem oszi)

    Wie genau meinst du das?
    Setzt du den Timer auch wieder zurück nachdem der ISR aufgerufen wurde?
    Geändert von tom77? (10.06.2012 um 19:50 Uhr)

  5. #15
    Erfahrener Benutzer Roboter-Spezialist Avatar von robo_tom_24
    Registriert seit
    04.02.2012
    Ort
    Burgenland, Österreich
    Beiträge
    485
    Ok...
    CTC heißt das der Timer nach dem Match - also der Übereinstimmung - zurückgesetzt wird

    Das kannst du aber auch händisch machen inem du in deiner ISR den Timer wieder auf 0 zurück setzt:
    Code:
    TCNT1=0; //Timer-Wert-Register auf 0 setzen

  6. #16
    Erfahrener Benutzer Robotik Einstein Avatar von wkrug
    Registriert seit
    17.08.2006
    Ort
    Dietfurt
    Beiträge
    2.214
    Ohne CTC läuft der Timer nicht richtig.
    Das CTC bedeutet, das das TCNT1 Register bei einem Comparematch auf 0 gesetzt wird.
    Wenn das nicht eingestellt ist wird der Timer über den Overflow springen und dann erst wieder beim Zählerstand von 15625 wieder einen Interrupt auslösen.
    Das bedeutet der Interrupt wird nur alle ca 4 Sekunden angesprungen.
    Da gibt es mehrere Lösungen.
    Entweder du zählst bei einem aufgetretenen Comparematch Interrupt ( in diesem natürlich ) einfach die 15625 zum Comparematchwert dazu.
    OCR1A+=15625;
    Das bewirkt, das beim Zählerstand von 31250 wieder ein Interrupt ausgelöst wird.
    Keine Angst bei den Überläufen ( >65535 ) Werden die Überlaufenden Bits gekillt, weil das ja nur ein 16Bit Register ist.
    Oder du aktivierst das CTC Bit im Register, das anscheinend in der Library anders heisst, oder nicht definiert ist.
    Guck auch mal ins Datenblatt unter Timer 1 WGM10 bis WGM13 bzw. CTC1.

    Das mit dem TCNT1=0 würde ich nicht machen, weil dabei ein kompletter Zählersprung "vergessen" werden könnte und deine Uhr damit auf Dauer falsch geht.
    Das ist halt eine Sache wie lange deine Controller sich in anderen Interupts aufhält, wie lange diese Interrupts sind und welche Prescaler man benutzt.
    Geändert von wkrug (10.06.2012 um 22:13 Uhr)

  7. #17
    Neuer Benutzer Öfters hier
    Registriert seit
    05.06.2012
    Beiträge
    14
    danke für eure antworten. kann im moment leider nichts testen - werde den code aber noch versuchen und mich dann nochmals melden .

  8. #18
    Neuer Benutzer Öfters hier
    Registriert seit
    05.06.2012
    Beiträge
    14
    so. nach einigen tests von beiden beschriebenen beiträgen muss ich leider wider einen misserfolg vermelden. es will und will nicht .

  9. #19
    Moderator Robotik Einstein Avatar von Kampi
    Registriert seit
    21.11.2009
    Ort
    Monheim, Nordrhein-Westfalen, Germany
    Alter
    34
    Beiträge
    3.501
    Blog-Einträge
    9
    Wie macht sich den der Fehler bemerkbar?
    Wird die Timer-ISR nicht ausgeführt oder was?
    Schaut ruhig mal auf meiner Homepage vorbei :
    http://kampis-elektroecke.de

    Oder folge mir auf Google+:
    Daniel Kampert

    Es gibt 10 Arten von Menschen. Die einen können Binär, die anderen nicht.

    Gruß
    Daniel

  10. #20
    Neuer Benutzer Öfters hier
    Registriert seit
    05.06.2012
    Beiträge
    14
    Weder ein syntaktisch noch ein semantisch Fehler wird vom Compiler angezeigt, folgedessen muss es sich um einen Logikfehler handeln.
    Bemerkbar macht sich das dadurch, dass der Couter jetzt gar nicht mehr hochzählt.

    folgenden code verwende ich im moment:
    //Variablen initialisierung
    long int Laufvariable = 0;

    //HAUPTPROGRAMM
    int main (void)
    {
    //Timer1 (16Bit) Initialisieren
    TCCR1A |= (1<<CS02) | (1<<CS00) | (1<<WGM10);
    OCR1A = 15625;
    TIMSK |= (1<<OCIE1A);
    sei();
    ...
    ...
    //Ausgabe der Variablen "Laufvariable" auf dem Display
    //(Displayfehler habe ich 100%ig ausgeschlossen)
    ...
    ...
    return 0;
    }

    //INTERRUPT von Timer1 (16Bit)
    ISR (TIMER1_COMPA_vect)
    {
    if (++Laufvariable > 100)
    Laufvariable = 0;
    }
    laut meinem verständnis sollte der code jede sekunde unterbrechen und den zähler "Laufvariable" durch die isr um eins erhöhen. ist der zähler über 100 gekommen, so wird er reseted.
    Geändert von tom77? (15.06.2012 um 15:06 Uhr)

Seite 2 von 4 ErsteErste 1234 LetzteLetzte

Ähnliche Themen

  1. Timer beim atmega8
    Von MrTaco im Forum C - Programmierung (GCC u.a.)
    Antworten: 1
    Letzter Beitrag: 19.05.2010, 15:28
  2. ausschaltverzögerung beim einschalten (timer)
    Von Warloxx im Forum Elektronik
    Antworten: 7
    Letzter Beitrag: 03.09.2009, 19:55
  3. Timer => Fehlermeldungen beim compilieren
    Von The Man im Forum Assembler-Programmierung
    Antworten: 5
    Letzter Beitrag: 14.02.2007, 11:07
  4. Timer/Counter0 beim Butterfly
    Von Heiko R. im Forum Basic-Programmierung (Bascom-Compiler)
    Antworten: 3
    Letzter Beitrag: 09.11.2005, 18:55
  5. Timer beim Mega16
    Von maw_hn im Forum C - Programmierung (GCC u.a.)
    Antworten: 3
    Letzter Beitrag: 22.08.2005, 10:03

Stichworte

Berechtigungen

  • Neue Themen erstellen: Nein
  • Themen beantworten: Nein
  • Anhänge hochladen: Nein
  • Beiträge bearbeiten: Nein
  •  

12V Akku bauen