hallo, ich bin gerade dabei mich etwas mit dem msp430f149 vertraut zu machen, und habe dabei ein problem, bei dem ich einfach anstehe. ich möchte über einen button der auf einem der pins von port 2 hängt leds durchschalten die auf der unteren hälfte von port 1 hängen. der button liefert wenn er gedrückt wird 3.3 V. weiß jemand waron ich scheitere? //#include "hardware.h" //#include "../../common/config/common_config.h" //#include "uartapi_msp430.c" #include "msp430x14x.h" #include <signal.h> //#include "clock.c" volatile uint8_t i=1, help = 0; int main(void){ P2DIR = 0x00; //P2SEL = 0x01; P1DIR = 0x0f; P2IES = 1; _BIS_SR(GIE); while(1){ P1OUT = (P1IN>>4); } } interrupt (PORT2_VECTOR) IO_port1_isr(void){ if(i>8) { i=1; } P1OUT = 0x0f; i = i << 1; P2IFG = 0x00; } danke im voraus mfg JR edit: wenn ich die zeile "P1OUT = (P1IN>>4);" rausnehme gehts auch nicht.
Hallo, mir kommt die Zuweisung P2IES = 1; merkwürdig vor, probier mal P2IES = 0x01; Gruß Gerd
Hmmm, warum machst Du mit den Interrupts rum, wenn der nicht mal freigegeben ist? Also, wenn Du einen Portpin auf Port 2 (z.B. P2.0) abfragst und die LED's an Port 1 dann anzünden möchtest, dann z.B. wie folgt: int main(void){ WDTCTL = WDTPW + WDTHOLD; // Stop watchdog timer P1OUT = 0x00; // switch LED's off by default P1DIR |= 0x0F; // Set P1.0...P1.3 to output direction while(1){ if (P2IN & 0x01) { // if P2.0 is set P1OUT |= 0x0F; // switch LED's on } else { P1OUT &= ~0x0F; // otherwise, switch LED's off } }
Er möchte aber mehrere LEDs an Port1 "durchschalten" und zwar mit EINEM Taster. Also quasi: einmal drücken -> LED_1 nochmal drücken -> LED_2 usw. So hab ich es verstanden... Und dann ist es sinnvoll, mit Interrupts zu arbeiten. In der ISR wird dann nen Zähler hochgezählt, mit dem sich dann weiterarbeiten läßt. DAS hat er ja auch gemacht. Wo jetzt der Fehler ist, weiß ch jetzt leider nicht...
Ahsu, jo, dann hab ich das wohl falsch interpretiert. Gut. Kann man mit Interrupts machen, muss aber nicht. Könnte man wie folgt lösen (der delay könnte etwas kurz bemessen sein): volatile uint8_t mask= 0,delay=0; int main(void){ WDTCTL = WDTPW + WDTHOLD; // Stop watchdog timer P1OUT = 0; // Switch off LED's by default P1DIR = 0x0f; // Configure outputs P2IES = 0; // Low-High transition will set IFG P2IFG = 0; // Reset IFG while(1){ while (!(P2IFG & 0x01)); // waiting for the edge 0->1 mask = mask << 1; // next LED, please if ((mask & 0x0F) == 0) // handle overflow mask = 0x01; P1OUT = mask; // switch on next LED for (delay = 0;delay <= 200;delay++); // some delay for debounce P2IFG &= ~0x01; // clear for the next step } }
Gerd K. schrieb: > mir kommt die Zuweisung P2IES = 1; merkwürdig vor, probier mal P2IES = > 0x01; Das sollte hoffentlich ein Witz sein?
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.