Hallo Leute,
habe kleines C-programm geschrieben, wo ich INT0 durch ein
Taster-Drücken auslöse. Dann wird ein Zähler um 1 erhöht.
Leider funktioniert es nicht immer, da manchmal um mehr als eins erhöht
wird:
Bsp: Counter = 10 >> taster Drücken >> counter = 12 (Sollte aber 11
sein)
hier ein Code-Asuschnitt:
volatile uint8_t counter;
SIGNAL(SIG_INTERRUPT0)
{
counter = counter + 1;
}
int main(void)
{
PORTD = 0x0C;
DDRD = 0x32;
GIFR |= (1 << INTF0);
GIFR |= (1 << INTF1);
MCUCR |= 0x03;
MCUCR |= 0x0C;
GICR |= (1 << INT0);
GICR |= (1 << INT1);
cli(); // clear Interrupt
sei(); // enable interrupts
while (1)
{ }
}
Kann mir bitte jemand dabei helfen? Vielen Dank im Voraus
Gruß
^^ wenn du noch nen Timer übrig hast, kannste den ja so einstellen, dass der nen Output Compare Interrupt auslöst. Dann ermöglicht dein Tastendruck den Timer-OCM-Interrupt und wenn der dann kommt, wird erst geschaut, wo der Taster gerade ist.. also nachdem er sich beruhigt hat. zB für nen 8Bit-Timer (Zeiangaben für fCPUI/O = 8MHz):
1 | // initialize irgendwo vor main{}:
|
2 | // 8Bit - Timer: CTC-Mode(4), TOP = 0xFF, Prescaler 1/1024 (32ms bis TOP), nix externes, OCM-Interrupt
|
3 | TCCRnA = ... |
4 | TCCRnB = ... |
5 | |
6 | // deine Interrupt Routine
|
7 | SIGNAL(SIG_INTERRUPT0) |
8 | {
|
9 | TCNT3 = 0x00; // Timer Zählregister reset |
10 | OCRnA = 0x4F; // ca 10ms bis Timer Compare Match A Interrupt |
11 | TIFRn |= (1<<OCFnA); // Timer Compare Match A Flag löschen |
12 | TIMSKn |= (1<<OCIEnA); // Timer Compare Match A Interrupt aktivieren |
13 | }
|
14 | |
15 | // Timer Compare Match A Interrupt
|
16 | ISR (TIMERn_COMPA_vect) |
17 | {
|
18 | TIMSKn &= ~(1<<OCIEnA); // Timer Compare Match A Interrupt deaktivieren |
19 | TIFRn |= (1<<OCFnA); // Timer Compare Match A Flag löschen |
20 | if (<<Pin_INT0>> == <<LOW>>) // nur wenn <<Pin_INT0>> low ist, zählen ... die genauen Bezeichnungen musst du ergänzen ;-) |
21 | {
|
22 | counter = counter + 1; |
23 | }
|
24 | }
|
25 | |
26 | int main(void) |
27 | {
|
28 | PORTD = 0x0C; |
29 | DDRD = 0x32; |
30 | GIFR |= (1 << INTF0)|(1 << INTF1); |
31 | MCUCR |= 0x03|0x0C; |
32 | GICR |= (1 << INT0)|(1 << INT1); |
33 | sei(); // enable interrupts |
34 | while (1) // loop forever |
35 | { } |
36 | }
|
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.