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.