Forum: Compiler & IDEs Timer0 bei ATmega16


von Mathias O. (m-obi)


Lesenswert?

Hallo,

ich probiere im Moment ein bisschen mit den Timer0 herum. Und schaffe es 
einfach nicht was ich will. Ich habe einen 16MHz Quarz an meinen 
ATmega16 hängen.
Ich möchte wenn der Timer bei 255 einen Overflow hat, einen Ausgang 
toggeln. Aber es funktioniert noch nicht, was fehlt bzw mach ich falsch?

Mein bisheriger Code:
1
ISR(TIMER0_OVF_vect)
2
{
3
  PORTA ^= 0xff;
4
}
5
6
7
int main(void)
8
{
9
    
10
  DDRA = 0b11111111;
11
  DDRB = 0b11111111;
12
  DDRC = 0b11111111;
13
  DDRD = 0b11100011;
14
  
15
  TCCR0 |= (1<<CS00)|(1<<CS02);
16
17
18
  while(1)
19
  {     
20
    
21
    }
22
}

von Justus S. (jussa)


Lesenswert?

ich würde erstmal Interrupts generell und den Timer1-Overflow-Interrupt 
im speziellen aktivieren...

von Oliver (Gast)


Lesenswert?

Da fehlt das
1
sei()
.

Oliver

von Mathias O. (m-obi)


Lesenswert?

@Justus Skorps
Kannst du mal den Code posten, wie es dann aussehen müsste. Und ich 
verwende Timer0.

von Karl H. (kbuchegg)


Lesenswert?

Mathias Obetzhauser wrote:
> @Justus Skorps
> Kannst du mal den Code posten, wie es dann aussehen müsste. Und ich
> verwende Timer0.


Sieh bitte ins Datenblatt.
Dort gibt es für jeden Timer eine Beschreibung der Register. In einem 
davon gibt es ein Bit, welches du setzen musst, damit der Overflow 
Interrupt ausgelöst wird.

Das ist das eine. Das andere ist, dass es noch ein globales Interrupt 
Flag gibt, welches mittels sei() gesetzt werden muss, damit Interrupts 
generell zugelassen werden.

Das Datenblatt ist dein Freund. Je früher du lernst, damit umzugehen, 
umso besser.
1
#include <avr/io.h>
2
#include <avr/interrupt.h>
3
4
ISR(TIMER0_OVF_vect)
5
{
6
  PORTA ^= 0xff;
7
}
8
9
10
int main(void)
11
{
12
    
13
  DDRA = 0b11111111;
14
  DDRB = 0b11111111;
15
  DDRC = 0b11111111;
16
  DDRD = 0b11100011;
17
  
18
  TCCR0 |= (1<<CS00)|(1<<CS02);
19
  TIMSK =  (1<<TOIE0);
20
21
  sei();
22
23
  while(1)
24
  {     
25
    
26
    }
27
}

von Mathias O. (m-obi)


Lesenswert?

OK es klappt.
1
#include <avr/io.h>
2
#include <avr/interrupt.h>
3
#include <util/delay.h>
4
5
6
ISR(TIMER0_OVF_vect)
7
{
8
  PORTA ^= 0xff;
9
}
10
11
12
int main(void)
13
{
14
    
15
  DDRA = 0b11111111;
16
  DDRB = 0b11111111;
17
  DDRC = 0b11111111;
18
  DDRD = 0b11100011;
19
  
20
  TCCR0 |= (1<<CS00)|(1<<CS02);
21
  TIMSK |= (1<<TOIE0);
22
  
23
  sei();
24
25
  while(1)
26
  {     
27
      
28
    }
29
}

von Oliver (Gast)


Lesenswert?

Zu jedem möglichen Interrupt gibt es im AVR irgendwo ein Flag, mit dem 
sich dieser ein- oder ausschalten lässt.

Für die Timer steckt das Flag im TIMSK. ALso Datenblatt hervorkramen, 
und nachschauen.

Oliver

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.