# HG changeset patch # User Jacob Alexander # Date 1359739072 18000 # Node ID 91c9eb3967b1209a2da4a4fc7ed4a047f5fa03b9 # Parent 872273398943badf95edeffbefebd8d407b2b141 Adding the MSBF register enable flag. diff -r 872273398943 -r 91c9eb3967b1 Lib/mk20dx128.h --- a/Lib/mk20dx128.h Wed Jan 30 23:43:41 2013 -0500 +++ b/Lib/mk20dx128.h Fri Feb 01 12:17:52 2013 -0500 @@ -1085,6 +1085,7 @@ #define UART_S1_PF (uint8_t)0x01 // Parity Error Flag #define UART0_S2 *(volatile uint8_t *)0x4006A005 // UART Status Register 2 #define UART_S2_RXINV (uint8_t)0x10 // RX Line Inversion Enable +#define UART_S2_MSBF (uint8_t)0x20 // MSBF Format Enabled #define UART0_C3 *(volatile uint8_t *)0x4006A006 // UART Control Register 3 #define UART_S2_TXINV (uint8_t)0x10 // TX Line Inversion Enable #define UART0_D *(volatile uint8_t *)0x4006A007 // UART Data Register diff -r 872273398943 -r 91c9eb3967b1 Scan/MBC-55X/scan_loop.c --- a/Scan/MBC-55X/scan_loop.c Wed Jan 30 23:43:41 2013 -0500 +++ b/Scan/MBC-55X/scan_loop.c Fri Feb 01 12:17:52 2013 -0500 @@ -148,7 +148,7 @@ UART0_BDL = (uint8_t)baud; // 8 bit, Even Parity, Idle Character bit after stop - UART0_C1 = ~UART_C1_M | UART_C1_PE | ~UART_C1_PT | UART_C1_ILT; + UART0_C1 = ~UART_C1_M | ~UART_C1_PE | UART_C1_PT | UART_C1_ILT; // Number of bytes in FIFO before TX Interrupt UART0_TWFIFO = 1; @@ -163,15 +163,15 @@ // 0x2 - 8 dataword UART0_PFIFO = ~UART_PFIFO_TXFE | /*TXFIFOSIZE*/ (0x0 << 4) | ~UART_PFIFO_RXFE | /*RXFIFOSIZE*/ (0x0); - // TX Disabled, RX Enabled, RX Interrupt Enabled - UART0_C2 = UART_C2_TE | UART_C2_RE | UART_C2_RIE; - - // Reciever Inversion Disabled - UART0_S2 = ~UART_S2_RXINV; + // Reciever Inversion Disabled, LSBF + UART0_S2 = ~UART_S2_RXINV | UART_S2_MSBF; // Transmit Inversion Disabled UART0_C3 = ~UART_S2_TXINV; + // TX Disabled, RX Enabled, RX Interrupt Enabled + UART0_C2 = UART_C2_TE | UART_C2_RE | UART_C2_RIE; + // Add interrupt to the vector table NVIC_ENABLE_IRQ( IRQ_UART0_STATUS ); @@ -185,6 +185,7 @@ inline uint8_t scan_loop() { UART0_D = 0x56; + UART0_D = 0x1C; _delay_ms( 100 ); return 0; }