From ca007f91f2aa959a738649d35becb54cb1efc8b8 Mon Sep 17 00:00:00 2001 From: Dean Camera Date: Thu, 29 Jul 2010 15:14:56 +0000 Subject: Fixed Benito and USBtoSerial projects not turning off the USART before reconfiguring it, which could cause incorrect operation to occur (thanks to Bob Paddock). --- Projects/USBtoSerial/USBtoSerial.c | 13 ++++++++++--- 1 file changed, 10 insertions(+), 3 deletions(-) (limited to 'Projects/USBtoSerial') diff --git a/Projects/USBtoSerial/USBtoSerial.c b/Projects/USBtoSerial/USBtoSerial.c index 1cd6f5563..b59a3648f 100644 --- a/Projects/USBtoSerial/USBtoSerial.c +++ b/Projects/USBtoSerial/USBtoSerial.c @@ -120,7 +120,6 @@ void SetupHardware(void) clock_prescale_set(clock_div_1); /* Hardware Initialization */ - Serial_Init(9600, false); LEDs_Init(); USB_Init(); @@ -199,9 +198,17 @@ void EVENT_CDC_Device_LineEncodingChanged(USB_ClassInfo_CDC_Device_t* const CDCI ConfigMask |= ((1 << UCSZ11) | (1 << UCSZ10)); break; } + + /* Must turn off USART before reconfiguring it, otherwise incorrect operation may occur */ + UCSR1A = 0; + UCSR1B = 0; + UCSR1C = 0; + + /* Set the new baud rate before configuring the USART */ + UBRR1 = SERIAL_2X_UBBRVAL(CDCInterfaceInfo->State.LineEncoding.BaudRateBPS); + /* Reconfigure the USART in double speed mode for a wider baud rate range at the expense of accuracy */ UCSR1A = (1 << U2X1); UCSR1B = ((1 << RXCIE1) | (1 << TXEN1) | (1 << RXEN1)); - UCSR1C = ConfigMask; - UBRR1 = SERIAL_2X_UBBRVAL(CDCInterfaceInfo->State.LineEncoding.BaudRateBPS); + UCSR1C = ConfigMask; } -- cgit v1.2.3