mirror of https://github.com/ArduPilot/ardupilot
Per Jose, fix the interrupt vectors to work for non-1280-based Arduino.
Make Serial0 also stdin and stderr. git-svn-id: https://arducopter.googlecode.com/svn/trunk@534 f9c3cf11-9bcb-44bc-f272-b75c42450872
This commit is contained in:
parent
9d8ea2563f
commit
6d31545b8d
|
@ -105,8 +105,11 @@ FastSerial::FastSerial(const uint8_t portNumber,
|
|||
// init stdio
|
||||
fdev_setup_stream(&_fd, &FastSerial::_putchar, NULL, _FDEV_SETUP_WRITE);
|
||||
fdev_set_udata(&_fd, this);
|
||||
if (0 == portNumber)
|
||||
if (0 == portNumber) {
|
||||
stdout = &_fd; // serial port 0 is always the default console
|
||||
stdin = &_fd;
|
||||
stderr = &_fd;
|
||||
}
|
||||
}
|
||||
|
||||
// Public Methods //////////////////////////////////////////////////////////////
|
||||
|
|
|
@ -180,7 +180,7 @@ ISR(_TXVECTOR, ISR_BLOCK) \
|
|||
struct hack
|
||||
|
||||
// Macros defining serial ports
|
||||
// XXX note no ATMega8 support here...
|
||||
#if defined(__AVR_ATmega1280__)
|
||||
#define FastSerialPort0(_portName) \
|
||||
FastSerial _portName(0, \
|
||||
&UBRR0H, \
|
||||
|
@ -192,7 +192,6 @@ struct hack
|
|||
(_BV(RXEN0) | _BV(TXEN0) | _BV(RXCIE0)), \
|
||||
(_BV(UDRIE0))); \
|
||||
FastSerialHandler(0, SIG_USART0_RECV, SIG_USART0_DATA, UDR0, UCSR0B, _BV(UDRIE0))
|
||||
#if defined(__AVR_ATmega1280__)
|
||||
#define FastSerialPort1(_portName) \
|
||||
FastSerial _portName(1, \
|
||||
&UBRR1H, \
|
||||
|
@ -226,6 +225,33 @@ struct hack
|
|||
(_BV(RXEN3) | _BV(TXEN3) | _BV(RXCIE3)), \
|
||||
(_BV(UDRIE3))); \
|
||||
FastSerialHandler(3, SIG_USART3_RECV, SIG_USART3_DATA, UDR3, UCSR3B, _BV(UDRIE3))
|
||||
#else
|
||||
#if defined(__AVR_ATmega8__)
|
||||
#define FastSerialPort0(_portName) \
|
||||
FastSerial _portName(0, \
|
||||
&UBRR0H, \
|
||||
&UBRR0L, \
|
||||
&UCSR0A, \
|
||||
&UCSR0B, \
|
||||
&UDR0, \
|
||||
U2X0, \
|
||||
(_BV(RXEN0) | _BV(TXEN0) | _BV(RXCIE0)), \
|
||||
(_BV(UDRIE0))); \
|
||||
FastSerialHandler(0, SIG_UART_RECV, SIG_UART_DATA, UDR0, UCSR0B, _BV(UDRIE0))
|
||||
#else
|
||||
// note no SIG_USART_* defines for the 168, 328, etc.
|
||||
#define FastSerialPort0(_portName) \
|
||||
FastSerial _portName(0, \
|
||||
&UBRR0H, \
|
||||
&UBRR0L, \
|
||||
&UCSR0A, \
|
||||
&UCSR0B, \
|
||||
&UDR0, \
|
||||
U2X0, \
|
||||
(_BV(RXEN0) | _BV(TXEN0) | _BV(RXCIE0)), \
|
||||
(_BV(UDRIE0))); \
|
||||
FastSerialHandler(0, USART_RX_vect, USART_UDRE_vect, UDR0, UCSR0B, _BV(UDRIE0))
|
||||
#endif
|
||||
#endif
|
||||
|
||||
#endif // FastSerial_h
|
||||
|
|
Loading…
Reference in New Issue