Line No. | Rev | Author | Line |
---|---|---|---|
1 | 6 | kaklik | /*! \file uart.h \brief UART driver with buffer support. */ |
2 | //***************************************************************************** |
||
3 | // |
||
4 | // File Name : 'uart.h' |
||
5 | // Title : UART driver with buffer support |
||
6 | // Author : Pascal Stang - Copyright (C) 2000-2002 |
||
7 | // Created : 11/22/2000 |
||
8 | // Revised : 02/01/2004 |
||
9 | // Version : 1.3 |
||
10 | // Target MCU : ATMEL AVR Series |
||
11 | // Editor Tabs : 4 |
||
12 | // |
||
13 | // This code is distributed under the GNU Public License |
||
14 | // which can be found at http://www.gnu.org/licenses/gpl.txt |
||
15 | // |
||
16 | /// \ingroup driver_avr |
||
17 | /// \defgroup uart UART Driver/Function Library (uart.c) |
||
18 | /// \code #include "uart.h" \endcode |
||
19 | /// \par Overview |
||
20 | /// This library provides both buffered and unbuffered transmit and receive |
||
21 | /// functions for the AVR processor UART. Buffered access means that the |
||
22 | /// UART can transmit and receive data in the "background", while your code |
||
23 | /// continues executing. Also included are functions to initialize the |
||
24 | /// UART, set the baud rate, flush the buffers, and check buffer status. |
||
25 | /// |
||
26 | /// \note For full text output functionality, you may wish to use the rprintf |
||
27 | /// functions along with this driver. |
||
28 | /// |
||
29 | /// \par About UART operations |
||
30 | /// Most Atmel AVR-series processors contain one or more hardware UARTs |
||
31 | /// (aka, serial ports). UART serial ports can communicate with other |
||
32 | /// serial ports of the same type, like those used on PCs. In general, |
||
33 | /// UARTs are used to communicate with devices that are RS-232 compatible |
||
34 | /// (RS-232 is a certain kind of serial port). |
||
35 | /// \par |
||
36 | /// By far, the most common use for serial communications on AVR processors |
||
37 | /// is for sending information and data to a PC running a terminal program. |
||
38 | /// Here is an exmaple: |
||
39 | /// \code |
||
40 | /// uartInit(); // initialize UART (serial port) |
||
41 | /// uartSetBaudRate(9600); // set UART speed to 9600 baud |
||
42 | /// rprintfInit(uartSendByte); // configure rprintf to use UART for output |
||
43 | /// rprintf("Hello World\r\n"); // send "hello world" message via serial port |
||
44 | /// \endcode |
||
45 | /// |
||
46 | /// \warning The CPU frequency (F_CPU) must be set correctly in \c global.h |
||
47 | /// for the UART library to calculate correct baud rates. Furthermore, |
||
48 | /// certain CPU frequencies will not produce exact baud rates due to |
||
49 | /// integer frequency division round-off. See your AVR processor's |
||
50 | /// datasheet for full details. |
||
51 | // |
||
52 | //***************************************************************************** |
||
53 | //@{ |
||
54 | |||
55 | #ifndef UART_H |
||
56 | #define UART_H |
||
57 | |||
58 | #include "global.h" |
||
59 | #include "buffer.h" |
||
60 | |||
61 | //! Default uart baud rate. |
||
62 | /// This is the default speed after a uartInit() command, |
||
63 | /// and can be changed by using uartSetBaudRate(). |
||
64 | #define UART_DEFAULT_BAUD_RATE 9600 |
||
65 | |||
66 | // buffer memory allocation defines |
||
67 | // buffer sizes |
||
68 | #ifndef UART_TX_BUFFER_SIZE |
||
69 | //! Number of bytes for uart transmit buffer. |
||
70 | /// Do not change this value in uart.h, but rather override |
||
71 | /// it with the desired value defined in your project's global.h |
||
72 | #define UART_TX_BUFFER_SIZE 0x0040 |
||
73 | #endif |
||
74 | #ifndef UART_RX_BUFFER_SIZE |
||
75 | //! Number of bytes for uart receive buffer. |
||
76 | /// Do not change this value in uart.h, but rather override |
||
77 | /// it with the desired value defined in your project's global.h |
||
78 | #define UART_RX_BUFFER_SIZE 0x0040 |
||
79 | #endif |
||
80 | |||
81 | // define this key if you wish to use |
||
82 | // external RAM for the UART buffers |
||
83 | //#define UART_BUFFER_EXTERNAL_RAM |
||
84 | #ifdef UART_BUFFER_EXTERNAL_RAM |
||
85 | // absolute address of uart buffers |
||
86 | #define UART_TX_BUFFER_ADDR 0x1000 |
||
87 | #define UART_RX_BUFFER_ADDR 0x1100 |
||
88 | #endif |
||
89 | |||
90 | //! Type of interrupt handler to use for uart interrupts. |
||
91 | /// Value may be SIGNAL or INTERRUPT. |
||
92 | /// \warning Do not change unless you know what you're doing. |
||
93 | #ifndef UART_INTERRUPT_HANDLER |
||
94 | #define UART_INTERRUPT_HANDLER SIGNAL |
||
95 | #endif |
||
96 | |||
97 | // compatibility with most newer processors |
||
98 | #ifdef UCSRB |
||
99 | #define UCR UCSRB |
||
100 | #endif |
||
101 | // compatibility with old Mega processors |
||
102 | #if defined(UBRR) && !defined(UBRRL) |
||
103 | #define UBRRL UBRR |
||
104 | #endif |
||
105 | // compatibility with megaXX8 processors |
||
106 | #if defined(__AVR_ATmega88__) || \ |
||
107 | defined(__AVR_ATmega168__) || \ |
||
108 | defined(__AVR_ATmega644__) |
||
109 | #define UDR UDR0 |
||
110 | #define UCR UCSR0B |
||
111 | #define RXCIE RXCIE0 |
||
112 | #define TXCIE TXCIE0 |
||
113 | #define RXC RXC0 |
||
114 | #define TXC TXC0 |
||
115 | #define RXEN RXEN0 |
||
116 | #define TXEN TXEN0 |
||
117 | #define UBRRL UBRR0L |
||
118 | #define UBRRH UBRR0H |
||
119 | #define SIG_UART_TRANS SIG_USART_TRANS |
||
120 | #define SIG_UART_RECV SIG_USART_RECV |
||
121 | #define SIG_UART_DATA SIG_USART_DATA |
||
122 | #endif |
||
123 | // compatibility with mega169 processors |
||
124 | #if defined(__AVR_ATmega169__) |
||
125 | #define SIG_UART_TRANS SIG_USART_TRANS |
||
126 | #define SIG_UART_RECV SIG_USART_RECV |
||
127 | #define SIG_UART_DATA SIG_USART_DATA |
||
128 | #endif |
||
129 | // compatibility with dual-uart processors |
||
130 | // (if you need to use both uarts, please use the uart2 library) |
||
131 | #if defined(__AVR_ATmega161__) |
||
132 | #define UDR UDR0 |
||
133 | #define UCR UCSR0B |
||
134 | #define UBRRL UBRR0 |
||
135 | #define SIG_UART_TRANS SIG_UART0_TRANS |
||
136 | #define SIG_UART_RECV SIG_UART0_RECV |
||
137 | #define SIG_UART_DATA SIG_UART0_DATA |
||
138 | #endif |
||
139 | #if defined(__AVR_ATmega128__) |
||
140 | #ifdef UART_USE_UART1 |
||
141 | #define UDR UDR1 |
||
142 | #define UCR UCSR1B |
||
143 | #define UBRRL UBRR1L |
||
144 | #define UBRRH UBRR1H |
||
145 | #define SIG_UART_TRANS SIG_UART1_TRANS |
||
146 | #define SIG_UART_RECV SIG_UART1_RECV |
||
147 | #define SIG_UART_DATA SIG_UART1_DATA |
||
148 | #else |
||
149 | #define UDR UDR0 |
||
150 | #define UCR UCSR0B |
||
151 | #define UBRRL UBRR0L |
||
152 | #define UBRRH UBRR0H |
||
153 | #define SIG_UART_TRANS SIG_UART0_TRANS |
||
154 | #define SIG_UART_RECV SIG_UART0_RECV |
||
155 | #define SIG_UART_DATA SIG_UART0_DATA |
||
156 | #endif |
||
157 | #endif |
||
158 | |||
159 | // functions |
||
160 | |||
161 | //! Initializes uart. |
||
162 | /// \note After running this init function, the processor |
||
163 | /// I/O pins that used for uart communications (RXD, TXD) |
||
164 | /// are no long available for general purpose I/O. |
||
165 | void uartInit(void); |
||
166 | |||
167 | //! Initializes transmit and receive buffers. |
||
168 | /// Automatically called from uartInit() |
||
169 | void uartInitBuffers(void); |
||
170 | |||
171 | //! Redirects received data to a user function. |
||
172 | /// |
||
173 | void uartSetRxHandler(void (*rx_func)(unsigned char c)); |
||
174 | |||
175 | //! Sets the uart baud rate. |
||
176 | /// Argument should be in bits-per-second, like \c uartSetBaudRate(9600); |
||
177 | void uartSetBaudRate(u32 baudrate); |
||
178 | |||
179 | //! Returns pointer to the receive buffer structure. |
||
180 | /// |
||
181 | cBuffer* uartGetRxBuffer(void); |
||
182 | |||
183 | //! Returns pointer to the transmit buffer structure. |
||
184 | /// |
||
185 | cBuffer* uartGetTxBuffer(void); |
||
186 | |||
187 | //! Sends a single byte over the uart. |
||
188 | /// \note This function waits for the uart to be ready, |
||
189 | /// therefore, consecutive calls to uartSendByte() will |
||
190 | /// go only as fast as the data can be sent over the |
||
191 | /// serial port. |
||
192 | void uartSendByte(u08 data); |
||
193 | |||
194 | //! Gets a single byte from the uart receive buffer. |
||
195 | /// Returns the byte, or -1 if no byte is available (getchar-style). |
||
196 | int uartGetByte(void); |
||
197 | |||
198 | //! Gets a single byte from the uart receive buffer. |
||
199 | /// Function returns TRUE if data was available, FALSE if not. |
||
200 | /// Actual data is returned in variable pointed to by "data". |
||
201 | /// Example usage: |
||
202 | /// \code |
||
203 | /// char myReceivedByte; |
||
204 | /// uartReceiveByte( &myReceivedByte ); |
||
205 | /// \endcode |
||
206 | u08 uartReceiveByte(u08* data); |
||
207 | |||
208 | //! Returns TRUE/FALSE if receive buffer is empty/not-empty. |
||
209 | /// |
||
210 | u08 uartReceiveBufferIsEmpty(void); |
||
211 | |||
212 | //! Flushes (deletes) all data from receive buffer. |
||
213 | /// |
||
214 | void uartFlushReceiveBuffer(void); |
||
215 | |||
216 | //! Add byte to end of uart Tx buffer. |
||
217 | /// Returns TRUE if successful, FALSE if failed (no room left in buffer). |
||
218 | u08 uartAddToTxBuffer(u08 data); |
||
219 | |||
220 | //! Begins transmission of the transmit buffer under interrupt control. |
||
221 | /// |
||
222 | void uartSendTxBuffer(void); |
||
223 | |||
224 | //! Sends a block of data via the uart using interrupt control. |
||
225 | /// \param buffer pointer to data to be sent |
||
226 | /// \param nBytes length of data (number of bytes to sent) |
||
227 | u08 uartSendBuffer(char *buffer, u16 nBytes); |
||
228 | |||
229 | #endif |
||
230 | //@} |
||
231 | |||
232 |
Powered by WebSVN v2.8.3