Hallo zusammen,
ich habe hier einen Atmel 1284P und einen Taster der an Pin
PB2(PCINT10/INT2/AIN0) einen Interrupt auslösen soll (siehe triviale
Schaltung im Anhang - SW_SET ist direkt mit PB2 verbunden). Der
Kondensator C14 (22nF) entprellt den Taster und wird vollständig geladen
bevor die Interrupts aktiviert werden. Nur zum debuggen hängt noch eine
LED an Pin PC1.
Der passende Code dazu (ich verwende Atmel Studio):
1 | #ifndef F_CPU
|
2 | #define F_CPU 8000000UL
|
3 | #endif
|
4 |
|
5 | #include <avr/interrupt.h>
|
6 | #include <util/delay.h>
|
7 |
|
8 | int main(void) {
|
9 | // LED on PC1: Set as output and clear.
|
10 | DDRC |= (1 << PC1);
|
11 | PORTC &= ~(1 << PC1);
|
12 | //Switch connected to PB2: Set as input and pull-up.
|
13 | PORTB |= (1 << PB2);
|
14 | DDRB &= ~(1 << PB2);
|
15 | // Cap needs 4 ms to charge - just wait ...
|
16 | _delay_ms(500);
|
17 | // "01" in bit 5,4 indicates that any changes on PB2 triggers
|
18 | // the interrupt.
|
19 | EICRA = 0b00010000;
|
20 | // Enable external interrupt 2.
|
21 | EIMSK = 0b00000100;
|
22 | // Enable interrupts.
|
23 | sei();
|
24 | while (1) {}
|
25 | return(0);
|
26 | }
|
27 |
|
28 | ISR(INT2_vect) {
|
29 | // Turn on LED on PC1 permanently.
|
30 | PORTC |= (1 << PC1);
|
31 | }
|
Das funktioniert zum großen Teil auch. Das Problem ist, dass direkt bei
Aktivierung der Interrupts durch "sei();" einmal der Interrupthandler
ausgeführt wird. Das passiert auch, wenn man nur auf ansteigende Signale
reagiert (also "EICRA = 0b00110000;"). Meine Erwartung wäre, dass erst
ein Druck auf den Taster die Interruptbehandlung auslöst und damit die
LED einschaltet.
Woran kann das liegen? Was übersehe ich?
Vielen Dank,
Daniel