Subversion Repositories svnkaklik

Rev

Rev 510 | Details | Compare with Previous | Last modification | View Log

Rev Author Line No. Line
510 kaklik 1
/*! \file uart2.h \brief Dual UART driver with buffer support. */
2
//*****************************************************************************
3
//
4
// File Name	: 'uart2.h'
5
// Title		: Dual UART driver with buffer support
6
// Author		: Pascal Stang - Copyright (C) 2000-2002
7
// Created		: 11/20/2000
8
// Revised		: 07/04/2004
9
// Version		: 1.0
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 uart2 UART Driver/Function Library for dual-UART processors (uart2.c)
18
/// \code #include "uart2.h" \endcode
19
/// \par Overview
20
///		This is a UART driver for AVR-series processors with two hardware
21
///		UARTs such as the mega161 and mega128. This library provides both
22
///		buffered and unbuffered transmit and receive functions for the AVR
23
///		processor UART. Buffered access means that the UART can transmit
24
///		and receive data in the "background", while your code continues
25
///		executing.  Also included are functions to initialize the UARTs,
26
///		set the baud rate, flush the buffers, and check buffer status.
27
///
28
/// \note	For full text output functionality, you may wish to use the rprintf
29
///		functions along with this driver.
30
///
31
/// \par About UART operations
32
///		Most Atmel AVR-series processors contain one or more hardware UARTs
33
///		(aka, serial ports).  UART serial ports can communicate with other 
34
///		serial ports of the same type, like those used on PCs.  In general,
35
///		UARTs are used to communicate with devices that are RS-232 compatible
36
///		(RS-232 is a certain kind of serial port).
37
///	\par
38
///		By far, the most common use for serial communications on AVR processors
39
///		is for sending information and data to a PC running a terminal program.
40
///		Here is an exmaple:
41
///	\code
42
/// uartInit();					// initialize UARTs (serial ports)
43
/// uartSetBaudRate(0, 9600);	// set UART0 speed to 9600 baud
44
/// uartSetBaudRate(1, 115200);	// set UART1 speed to 115200 baud
45
///
46
/// rprintfInit(uart0SendByte);	// configure rprintf to use UART0 for output
47
/// rprintf("Hello UART0\r\n");	// send "hello world" message via UART0
48
///
49
/// rprintfInit(uart1SendByte);	// configure rprintf to use UART1 for output
50
/// rprintf("Hello UART1\r\n");	// send "hello world" message via UART1
51
/// \endcode
52
///
53
/// \warning The CPU frequency (F_CPU) must be set correctly in \c global.h
54
///		for the UART library to calculate correct baud rates.  Furthermore,
55
///		certain CPU frequencies will not produce exact baud rates due to
56
///		integer frequency division round-off.  See your AVR processor's
57
///		 datasheet for full details.
58
//
59
//*****************************************************************************
60
//@{
61
 
62
#ifndef UART2_H
63
#define UART2_H
64
 
65
#include "global.h"
66
#include "buffer.h"
67
 
68
//! Default uart baud rate.
69
/// This is the default speed after a uartInit() command,
70
/// and can be changed by using uartSetBaudRate().
71
#define UART0_DEFAULT_BAUD_RATE		9600	///< default baud rate for UART0
72
#define UART1_DEFAULT_BAUD_RATE		9600	///< default baud rate for UART1
73
 
74
// buffer memory allocation defines
75
// buffer sizes
76
#ifndef UART0_TX_BUFFER_SIZE
77
#define UART0_TX_BUFFER_SIZE		0x0010	///< number of bytes for uart0 transmit buffer
78
#endif
79
#ifndef UART0_RX_BUFFER_SIZE
80
#define UART0_RX_BUFFER_SIZE		0x0080	///< number of bytes for uart0 receive buffer
81
#endif
82
#ifndef UART1_TX_BUFFER_SIZE
83
#define UART1_TX_BUFFER_SIZE		0x0010	///< number of bytes for uart1 transmit buffer
84
#endif
85
#ifndef UART1_RX_BUFFER_SIZE
86
#define UART1_RX_BUFFER_SIZE		0x0080	///< number of bytes for uart1 receive buffer
87
#endif
88
 
89
// define this key if you wish to use
90
// external RAM for the	UART buffers
91
//#define UART_BUFFER_EXTERNAL_RAM
92
#ifdef UART_BUFFER_EXTERNAL_RAM
93
	// absolute address of uart0 buffers
94
	#define UART0_TX_BUFFER_ADDR	0x1000
95
	#define UART0_RX_BUFFER_ADDR	0x1100
96
	// absolute address of uart1 buffers
97
	#define UART1_TX_BUFFER_ADDR	0x1200
98
	#define UART1_RX_BUFFER_ADDR	0x1300
99
#endif
100
 
101
//! Type of interrupt handler to use for uart interrupts.
102
/// Value may be SIGNAL or INTERRUPT.
103
/// \warning Do not change unless you know what you're doing.
104
#ifndef UART_INTERRUPT_HANDLER
105
#define UART_INTERRUPT_HANDLER	SIGNAL
106
#endif
107
 
108
// compatibility for the mega161
109
#ifndef RXCIE
110
	#define RXCIE	RXCIE0
111
	#define TXCIE	TXCIE0
112
	#define UDRIE	UDRIE0
113
	#define RXEN	RXEN0
114
	#define TXEN	TXEN0
115
	#define CHR9	CHR90
116
	#define RXB8	RXB80
117
	#define TXB8	TXB80
118
#endif
119
#ifndef UBRR0L
120
	#define UBRR0L	UBRR0
121
	#define UBRR1L	UBRR1
122
#endif
123
 
124
// functions
125
 
126
//! Initializes UARTs.
127
/// \note	After running this init function, the processor
128
/// I/O pins that used for uart communications (RXD, TXD)
129
/// are no long available for general purpose I/O.
130
void uartInit(void);
131
 
132
//! Initializes UART0 only.
133
void uart0Init(void);
134
 
135
//! Initializes UART1 only.
136
void uart1Init(void);
137
 
138
//! Initializes transmit and receive buffers.
139
/// Automatically called from uartInit()
140
void uart0InitBuffers(void);
141
void uart1InitBuffers(void);
142
 
143
//! Redirects received data to a user function.
144
///
145
void uartSetRxHandler(u08 nUart, void (*rx_func)(unsigned char c));
146
 
147
//! Sets the uart baud rate.
148
/// Argument should be in bits-per-second, like \c uartSetBaudRate(9600);
149
void uartSetBaudRate(u08 nUart, u32 baudrate);
150
 
151
//! Returns pointer to the receive buffer structure.
152
///
153
cBuffer* uartGetRxBuffer(u08 nUart);
154
 
155
//! Returns pointer to the transmit buffer structure.
156
///
157
cBuffer* uartGetTxBuffer(u08 nUart);
158
 
159
//! Sends a single byte over the uart.
160
///
161
void uartSendByte(u08 nUart, u08 data);
162
 
163
//! SendByte commands with the UART number hardcoded
164
/// Use these with printfInit() - example: \c printfInit(uart0SendByte);
165
void uart0SendByte(u08 data);
166
void uart1SendByte(u08 data);
167
 
168
//! Gets a single byte from the uart receive buffer.
169
/// Returns the byte, or -1 if no byte is available (getchar-style).
170
int uart0GetByte(void);
171
int uart1GetByte(void);
172
 
173
//! Gets a single byte from the uart receive buffer.
174
/// Function returns TRUE if data was available, FALSE if not.
175
/// Actual data is returned in variable pointed to by "data".
176
/// Example usage:
177
/// \code
178
/// char myReceivedByte;
179
/// uartReceiveByte(0, &myReceivedByte );
180
/// \endcode
181
u08 uartReceiveByte(u08 nUart, u08* data);
182
 
183
//! Returns TRUE/FALSE if receive buffer is empty/not-empty.
184
///
185
u08 uartReceiveBufferIsEmpty(u08 nUart);
186
 
187
//! Flushes (deletes) all data from receive buffer.
188
///
189
void uartFlushReceiveBuffer(u08 nUart);
190
 
191
//! Add byte to end of uart Tx buffer.
192
///
193
void uartAddToTxBuffer(u08 nUart, u08 data);
194
 
195
//! AddToTxBuffer commands with the UART number hardcoded
196
/// Use this with printfInit() - example: \c printfInit(uart0AddToTxBuffer);
197
void uart0AddToTxBuffer(u08 data);
198
void uart1AddToTxBuffer(u08 data);
199
 
200
//! Begins transmission of the transmit buffer under interrupt control.
201
///
202
void uartSendTxBuffer(u08 nUart);
203
 
204
//! sends a buffer of length nBytes via the uart using interrupt control.
205
///
206
u08 uartSendBuffer(u08 nUart, char *buffer, u16 nBytes);
207
 
208
//! interrupt service handlers
209
void uartTransmitService(u08 nUart);
210
void uartReceiveService(u08 nUart);
211
 
212
#endif
213