Hi, ich versuch grad daten via dem usart zu empfangen. Die DMX Werte kommen auch richtig an, aber die Break wird nicht richtig erkannt, so dass nicht 512 Werte gespeichert werden sondern z.B. nur 502 oder 508.... Des Weiteren treten verstärkt Overrun Fehler auf. Als Prozessor verwende ich den AT91SAM9263 von Atmel. muss ich hier eher von einem software oder einem hardware Problem ausgehen? Ist vielleicht in meiner Init irgendwas falsch? Bei der Initialisierung hab ich zwei Stoppbits, ein Startbit sowie 8 Datenbits ausgewählt und als Datenrate 250000bit/s. unsigned int mode = AT91C_US_USMODE_NORMAL | AT91C_US_CLKS_CLOCK | AT91C_US_PAR_NONE | AT91C_US_CHRL_8_BITS | AT91C_US_NBSTOP_2_BIT | AT91C_US_CHMODE_NORMAL; unsigned int baudrate = 250000; AT91F_US0_CfgPIO(); AT91F_US0_CfgPMC(); AT91C_BASE_US0->US_CR = AT91C_US_RSTRX | AT91C_US_RSTTX | AT91C_US_RXDIS | AT91C_US_TXDIS; AT91C_BASE_US0->US_MR = mode; if (((mode & AT91C_US_SYNC) == 0) && ((mode & AT91C_US_OVER) == 0)) { AT91C_BASE_US0->US_BRGR = (masterClock / baudrate) / 16; } AT91C_BASE_US0->US_IER = AT91C_US_RXRDY | AT91C_US_FRAME | AT91C_US_TIMEOUT | AT91C_US_RXBRK; AT91F_AIC_ConfigureIt(AT91C_BASE_AIC, AT91C_ID_US0, 6, AT91C_AIC_SRCTYPE_INT_LEVEL_SENSITIVE, (void (*)(void))ISR_Usart0); AT91F_AIC_EnableIt(AT91C_BASE_AIC, AT91C_ID_US0); //enable AT91C_BASE_US0->US_CR = AT91C_US_RXEN; Gruß Hannes PS: sorry für meinen doppelpost im platinenboard
Overrun Fehler sind wohl Softwarefehler. Ich hab nie mit AT91SAM9 gearbeitet aber beim AT91SAM7 habe ich für den DMX Empfang immer AT91C_AIC_SRCTYPE_INT_POSITIVE_EDGE benutzt.
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.