From 5b989d13b3165f9a04c4032c9213391760afda63 Mon Sep 17 00:00:00 2001 From: Zach Eveland Date: Thu, 18 Aug 2011 19:40:04 -0400 Subject: [PATCH] HW Serial on pins 0 and 1 works. Accessed by Serial1.* methods --- .../arduino/cores/arduino/HardwareSerial.cpp | 28 +++++-------------- 1 file changed, 7 insertions(+), 21 deletions(-) diff --git a/hardware/arduino/cores/arduino/HardwareSerial.cpp b/hardware/arduino/cores/arduino/HardwareSerial.cpp index ee77b4599..77ccd06aa 100644 --- a/hardware/arduino/cores/arduino/HardwareSerial.cpp +++ b/hardware/arduino/cores/arduino/HardwareSerial.cpp @@ -85,14 +85,8 @@ inline void store_char(unsigned char c, ring_buffer *buffer) } } -#if defined(__AVR_ATmega32U4__) - void serialEvent() __attribute__((weak)); - void serialEvent() {} - SIGNAL(USART1_RX_vect) { - unsigned char c = UDR1; - store_char(c, &rx_buffer); - serialEvent(); - } +#if !defined(USART0_RX_vect) && defined(USART1_RX_vect) +// do nothing - on the 32u4 the first USART is USART1 #else #if !defined(USART_RX_vect) && !defined(SIG_USART0_RECV) && \ !defined(SIG_UART0_RECV) && !defined(USART0_RX_vect) && \ @@ -124,6 +118,7 @@ inline void store_char(unsigned char c, ring_buffer *buffer) serialEvent(); } #endif +#endif #if defined(USART1_RX_vect) void serialEvent1() __attribute__((weak)); @@ -163,18 +158,9 @@ inline void store_char(unsigned char c, ring_buffer *buffer) #elif defined(SIG_USART3_RECV) #error SIG_USART3_RECV #endif -#endif -#if defined(__AVR_ATmega32U4__) -ISR(USART1_UDRE_vect) { - if (tx_buffer.head == tx_buffer.tail) { - cbi(UCSR1B, UDRIE1); - } else { - unsigned char c = tx_buffer.buffer[tx_buffer.tail]; - tx_buffer.tail = (tx_buffer.tail + 1) % SERIAL_BUFFER_SIZE; - UDR1 = c; - } -} +#if !defined(USART0_UDRE_vect) && defined(USART1_UDRE_vect) +// do nothing - on the 32u4 the first USART is USART1 #else #if !defined(UART0_UDRE_vect) && !defined(UART_UDRE_vect) && !defined(USART0_UDRE_vect) && !defined(USART_UDRE_vect) #error Don't know what the Data Register Empty vector is called for the first UART @@ -212,6 +198,7 @@ ISR(USART_UDRE_vect) } } #endif +#endif #ifdef USART1_UDRE_vect ISR(USART1_UDRE_vect) @@ -229,7 +216,6 @@ ISR(USART1_UDRE_vect) } } #endif -#endif #ifdef USART2_UDRE_vect ISR(USART2_UDRE_vect) @@ -399,7 +385,7 @@ void HardwareSerial::write(uint8_t c) #elif defined(UBRR0H) && defined(UBRR0L) HardwareSerial Serial(&rx_buffer, &tx_buffer, &UBRR0H, &UBRR0L, &UCSR0A, &UCSR0B, &UDR0, RXEN0, TXEN0, RXCIE0, UDRIE0, U2X0); #elif defined(USBCON) - #warning no serial port defined (port 0) + // do nothing - Serial object and buffers are initialized in CDC code #else #error no serial port defined (port 0) #endif