Ich möchte den Interrupt INT0 beim FX2 benutzen. Dazu gehe ich folgendermaßen vor: ... // PORTACFG: FLAGD SLCS(*) 0 0 0 0 INT1 INT0 // INT0 am PortA PORTACFG = 0x01; SYNCDELAY; IP = 0x01; SYNCDELAY; //xxxxxxx1 // | // INT0 auf high priority IE = 0x81; SYNCDELAY; //1xxxxxx1 //| | //| Enable interrupts for INT0 //Global interrupt enable TCON |= 0x01; //xxxxxxx1 // || // |1=edge sensitive // Is set when a negaitve cklock edge is detected on the INT0 pin and is automaticaly cleared when the FX2 vectors to the corresponding ISR. ... Syntax zur Definition meiner ISR: void MyIsr(void) __interrupt (0) { // My Interrupt handler for INT0 } Also, sobald ich die ISR definiere und die Firmware laufen lasse, funktionert nichts mehr. Sieht jemand von euch dort einen Fehler? Selbst wenn ich wie hier die ISR leer lasse funktioniert es nicht. Oder muss ich dort noch irgendein Register zurück setzen, von dem ich nichts weis?
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.