diff options
author | Cristian Maglie <c.maglie@bug.st> | 2014-01-27 22:48:17 +0100 |
---|---|---|
committer | Cristian Maglie <c.maglie@bug.st> | 2014-01-27 22:48:17 +0100 |
commit | e088421ef902180f6561f906181408133796531f (patch) | |
tree | 88a5b32b3cf2588bb6a2a442b417489b72e5bae0 /cores/arduino/HardwareSerial0.cpp | |
parent | f01025a70d6c11c09e32033195f4a9396462fb05 (diff) | |
parent | c3cd35f1979290d072ab77a6805dc4419f2ef6fb (diff) |
Merge branch 'serial-patch-2' into ide-1.5.x
Diffstat (limited to 'cores/arduino/HardwareSerial0.cpp')
-rw-r--r-- | cores/arduino/HardwareSerial0.cpp | 55 |
1 files changed, 55 insertions, 0 deletions
diff --git a/cores/arduino/HardwareSerial0.cpp b/cores/arduino/HardwareSerial0.cpp new file mode 100644 index 0000000..efbd527 --- /dev/null +++ b/cores/arduino/HardwareSerial0.cpp @@ -0,0 +1,55 @@ +#include "Arduino.h" +#include "HardwareSerial.h" +#include "HardwareSerial_private.h" + +// Each HardwareSerial is defined in its own file, sine the linker pulls +// in the entire file when any element inside is used. --gc-sections can +// additionally cause unused symbols to be dropped, but ISRs have the +// "used" attribute so are never dropped and they keep the +// HardwareSerial instance in as well. Putting each instance in its own +// file prevents the linker from pulling in any unused instances in the +// first place. + +#if defined(HAVE_HWSERIAL0) + +#if defined(USART_RX_vect) + ISR(USART_RX_vect) +#elif defined(USART0_RX_vect) + ISR(USART0_RX_vect) +#elif defined(USART_RXC_vect) + ISR(USART_RXC_vect) // ATmega8 +#else + #error "Don't know what the Data Received vector is called for the first UART" +#endif + { + Serial._rx_complete_irq(); + } + +#if defined(UART0_UDRE_vect) +ISR(UART0_UDRE_vect) +#elif defined(UART_UDRE_vect) +ISR(UART_UDRE_vect) +#elif defined(USART0_UDRE_vect) +ISR(USART0_UDRE_vect) +#elif defined(USART_UDRE_vect) +ISR(USART_UDRE_vect) +#else + #error "Don't know what the Data Register Empty vector is called for the first UART" +#endif +{ + Serial._tx_udr_empty_irq(); +} + +#if defined(UBRRH) && defined(UBRRL) + HardwareSerial Serial(&UBRRH, &UBRRL, &UCSRA, &UCSRB, &UCSRC, &UDR); +#else + HardwareSerial Serial(&UBRR0H, &UBRR0L, &UCSR0A, &UCSR0B, &UCSR0C, &UDR0); +#endif + +// Function that can be weakly referenced by serialEventRun to prevent +// pulling in this file if it's not otherwise used. +bool Serial0_available() { + return Serial.available(); +} + +#endif // HAVE_HWSERIAL0 |