![]() |
BLDC control on ATAVRMC303 with ATxMega128A1
|
XMEGA USART driver header file. More...
#include "avr_compiler.h"

Go to the source code of this file.
Data Structures | |
| struct | Usart_and_buffer |
| Struct used when interrupt driven driver is used. More... | |
| struct | USART_Buffer |
Macros | |
| #define | USART_Baudrate_Set(_usart, _bselValue, _bScaleFactor) |
| Set USART baud rate. More... | |
| #define | USART_DreInterruptLevel_Set(_usart, _dreIntLevel) (_usart)->CTRLA = ((_usart)->CTRLA & ~USART_DREINTLVL_gm) | _dreIntLevel |
| Set USART DRE interrupt level. More... | |
| #define | USART_Format_Set(_usart, _charSize, _parityMode, _twoStopBits) |
| Macro that sets the USART frame format. More... | |
| #define | USART_GetChar(_usart) ((_usart)->DATA) |
| Get received data (5-8 bit character). More... | |
| #define | USART_IsRXComplete(_usart) (((_usart)->STATUS & USART_RXCIF_bm) != 0) |
| Checks if the RX complete interrupt flag is set. More... | |
| #define | USART_IsTXDataRegisterEmpty(_usart) (((_usart)->STATUS & USART_DREIF_bm) != 0) |
| Check if data register empty flag is set. More... | |
| #define | USART_PutChar(_usart, _data) ((_usart)->DATA = _data) |
| Put data (5-8 bit character). More... | |
| #define | USART_RX_BUFFER_MASK ( USART_RX_BUFFER_SIZE - 1 ) |
| #define | USART_RX_BUFFER_SIZE 4 |
| #define | USART_Rx_Disable(_usart) ((_usart)->CTRLB &= ~USART_RXEN_bm) |
| Disable USART receiver. More... | |
| #define | USART_Rx_Enable(_usart) ((_usart)->CTRLB |= USART_RXEN_bm) |
| Enable USART receiver. More... | |
| #define | USART_RxdInterruptLevel_Set(_usart, _rxdIntLevel) ((_usart)->CTRLA = ((_usart)->CTRLA & ~USART_RXCINTLVL_gm) | _rxdIntLevel) |
| Set USART RXD interrupt level. More... | |
| #define | USART_SetMode(_usart, _usartMode) ((_usart)->CTRLC = ((_usart)->CTRLC & (~USART_CMODE_gm)) | _usartMode) |
| Set the mode the USART run in. More... | |
| #define | USART_TX_BUFFER_MASK ( USART_TX_BUFFER_SIZE - 1 ) |
| #define | USART_TX_BUFFER_SIZE 4 |
| #define | USART_Tx_Disable(_usart) ((_usart)->CTRLB &= ~USART_TXEN_bm) |
| Disable USART transmitter. More... | |
| #define | USART_Tx_Enable(_usart) ((_usart)->CTRLB |= USART_TXEN_bm) |
| Enable USART transmitter. More... | |
| #define | USART_TxdInterruptLevel_Set(_usart, _txdIntLevel) (_usart)->CTRLA = ((_usart)->CTRLA & ~USART_TXCINTLVL_gm) | _txdIntLevel |
| Set USART TXD interrupt level. More... | |
Typedefs | |
| typedef struct USART_Buffer | USART_Buffer_t |
| typedef struct Usart_and_buffer | USART_data_t |
| Struct used when interrupt driven driver is used. More... | |
Functions | |
| void | USART_DataRegEmpty (USART_data_t *usart_data) |
| Data Register Empty Interrupt Service Routine. More... | |
| void | USART_InterruptDriver_DreInterruptLevel_Set (USART_data_t *usart_data, USART_DREINTLVL_t dreIntLevel) |
| Set USART DRE interrupt level. More... | |
| void | USART_InterruptDriver_Initialize (USART_data_t *usart_data, USART_t *usart, USART_DREINTLVL_t dreIntLevel) |
| Initializes buffer and selects what USART module to use. More... | |
| uint16_t | USART_NineBits_GetChar (USART_t *usart) |
| Get received data (9 bit character). More... | |
| void | USART_NineBits_PutChar (USART_t *usart, uint16_t data) |
| Put data (9 bit character). More... | |
| uint8_t | USART_RXBuffer_GetByte (USART_data_t *usart_data) |
| Get received data (5-8 bit character). More... | |
| bool | USART_RXBufferData_Available (USART_data_t *usart_data) |
| Test if there is data in the receive software buffer. More... | |
| bool | USART_RXComplete (USART_data_t *usart_data) |
| RX Complete Interrupt Service Routine. More... | |
| bool | USART_TXBuffer_FreeSpace (USART_data_t *usart_data) |
| Test if there is data in the transmitter software buffer. More... | |
| bool | USART_TXBuffer_PutByte (USART_data_t *usart_data, uint8_t data) |
| Put data (5-8 bit character). More... | |
XMEGA USART driver header file.
This file contains the function prototypes and enumerator definitions for various configuration parameters for the XMEGA USART driver.
The driver is not intended for size and/or speed critical code, since most functions are just a few lines of code, and the function call overhead would decrease code performance. The driver is intended for rapid prototyping and documentation purposes for getting started with the XMEGA ADC module.
For size and/or speed critical code, it is recommended to copy the function contents directly into your application instead of making a function call.
Copyright (c) 2008, Atmel Corporation All rights reserved.
Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:
THIS SOFTWARE IS PROVIDED BY ATMEL "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE EXPRESSLY AND SPECIFICALLY DISCLAIMED. IN NO EVENT SHALL ATMEL BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
Definition in file usart_driver.h.
| #define USART_Baudrate_Set | ( | _usart, | |
| _bselValue, | |||
| _bScaleFactor | |||
| ) |
Set USART baud rate.
Sets the USART's baud rate register.
UBRR_Value : Value written to UBRR ScaleFactor : Time Base Generator Scale Factor
Equation for calculation of BSEL value in asynchronous normal speed mode: If ScaleFactor >= 0 BSEL = ((I/O clock frequency)/(2^(ScaleFactor)*16*Baudrate))-1 If ScaleFactor < 0 BSEL = (1/(2^(ScaleFactor)*16))*(((I/O clock frequency)/Baudrate)-1)
| _usart | Pointer to the USART module. |
| _bselValue | Value to write to BSEL part of Baud control register. Use uint16_t type. |
| _bScaleFactor | USART baud rate scale factor. Use uint8_t type |
Definition at line 156 of file usart_driver.h.
| #define USART_DreInterruptLevel_Set | ( | _usart, | |
| _dreIntLevel | |||
| ) | (_usart)->CTRLA = ((_usart)->CTRLA & ~USART_DREINTLVL_gm) | _dreIntLevel |
Set USART DRE interrupt level.
Sets the interrupt level on Data Register interrupt.
| _usart | Pointer to the USART module. |
| _dreIntLevel | Interrupt level of the DRE interrupt. Use USART_DREINTLVL_t type. |
Definition at line 222 of file usart_driver.h.
| #define USART_Format_Set | ( | _usart, | |
| _charSize, | |||
| _parityMode, | |||
| _twoStopBits | |||
| ) |
Macro that sets the USART frame format.
Sets the frame format, Frame Size, parity mode and number of stop bits.
| _usart | Pointer to the USART module |
| _charSize | The character size. Use USART_CHSIZE_t type. |
| _parityMode | The parity Mode. Use USART_PMODE_t type. |
| _twoStopBits | Enable two stop bit mode. Use bool type. |
Definition at line 129 of file usart_driver.h.
| #define USART_GetChar | ( | _usart | ) | ((_usart)->DATA) |
Get received data (5-8 bit character).
This macro reads out the RX register. Use the macro USART_RX_Complete to check if anything is received.
| _usart | The USART module. |
| Received | data. |
Definition at line 284 of file usart_driver.h.
| #define USART_IsRXComplete | ( | _usart | ) | (((_usart)->STATUS & USART_RXCIF_bm) != 0) |
Checks if the RX complete interrupt flag is set.
Checks if the RX complete interrupt flag is set.
| _usart | The USART module. |
Definition at line 270 of file usart_driver.h.
| #define USART_IsTXDataRegisterEmpty | ( | _usart | ) | (((_usart)->STATUS & USART_DREIF_bm) != 0) |
Check if data register empty flag is set.
| _usart | The USART module. |
Definition at line 248 of file usart_driver.h.
| #define USART_PutChar | ( | _usart, | |
| _data | |||
| ) | ((_usart)->DATA = _data) |
Put data (5-8 bit character).
Use the macro USART_IsTXDataRegisterEmpty before using this function to put data to the TX register.
| _usart | The USART module. |
| _data | The data to send. |
Definition at line 260 of file usart_driver.h.
| #define USART_RX_BUFFER_MASK ( USART_RX_BUFFER_SIZE - 1 ) |
Definition at line 71 of file usart_driver.h.
Referenced by USART_RXBuffer_GetByte(), and USART_RXComplete().
| #define USART_RX_BUFFER_SIZE 4 |
Definition at line 67 of file usart_driver.h.
| #define USART_Rx_Disable | ( | _usart | ) | ((_usart)->CTRLB &= ~USART_RXEN_bm) |
Disable USART receiver.
| _usart | Pointer to the USART module. |
Definition at line 172 of file usart_driver.h.
| #define USART_Rx_Enable | ( | _usart | ) | ((_usart)->CTRLB |= USART_RXEN_bm) |
Enable USART receiver.
| _usart | Pointer to the USART module |
Definition at line 165 of file usart_driver.h.
| #define USART_RxdInterruptLevel_Set | ( | _usart, | |
| _rxdIntLevel | |||
| ) | ((_usart)->CTRLA = ((_usart)->CTRLA & ~USART_RXCINTLVL_gm) | _rxdIntLevel) |
Set USART RXD interrupt level.
Sets the interrupt level on RX Complete interrupt.
| _usart | Pointer to the USART module. |
| _rxdIntLevel | Interrupt level of the RXD interrupt. Use USART_RXCINTLVL_t type. |
Definition at line 197 of file usart_driver.h.
| #define USART_SetMode | ( | _usart, | |
| _usartMode | |||
| ) | ((_usart)->CTRLC = ((_usart)->CTRLC & (~USART_CMODE_gm)) | _usartMode) |
Set the mode the USART run in.
Set the mode the USART run in. The default mode is asynchronous mode.
| _usart | Pointer to the USART module register section. |
| _usartMode | Selects the USART mode. Use USART_CMODE_t type. |
USART modes:
Definition at line 239 of file usart_driver.h.
| #define USART_TX_BUFFER_MASK ( USART_TX_BUFFER_SIZE - 1 ) |
Definition at line 73 of file usart_driver.h.
Referenced by USART_DataRegEmpty(), USART_TXBuffer_FreeSpace(), and USART_TXBuffer_PutByte().
| #define USART_TX_BUFFER_SIZE 4 |
Definition at line 69 of file usart_driver.h.
| #define USART_Tx_Disable | ( | _usart | ) | ((_usart)->CTRLB &= ~USART_TXEN_bm) |
Disable USART transmitter.
| _usart | Pointer to the USART module. |
Definition at line 186 of file usart_driver.h.
| #define USART_Tx_Enable | ( | _usart | ) | ((_usart)->CTRLB |= USART_TXEN_bm) |
Enable USART transmitter.
| _usart | Pointer to the USART module. |
Definition at line 179 of file usart_driver.h.
| #define USART_TxdInterruptLevel_Set | ( | _usart, | |
| _txdIntLevel | |||
| ) | (_usart)->CTRLA = ((_usart)->CTRLA & ~USART_TXCINTLVL_gm) | _txdIntLevel |
Set USART TXD interrupt level.
Sets the interrupt level on TX Complete interrupt.
| _usart | Pointer to the USART module. |
| _txdIntLevel | Interrupt level of the TXD interrupt. Use USART_TXCINTLVL_t type. |
Definition at line 209 of file usart_driver.h.
| typedef struct USART_Buffer USART_Buffer_t |
| typedef struct Usart_and_buffer USART_data_t |
Struct used when interrupt driven driver is used.
Struct containing pointer to a usart, a buffer and a location to store Data register interrupt level temporary.
| void USART_DataRegEmpty | ( | USART_data_t * | usart_data | ) |
Data Register Empty Interrupt Service Routine.
Data Register Empty Interrupt Service Routine. Transmits one byte from TX software buffer. Disables DRE interrupt if buffer is empty. Argument is pointer to USART (USART_data_t).
| usart_data | The USART_data_t struct instance. |
Definition at line 260 of file usart_driver.c.
References Usart_and_buffer::buffer, USART_Buffer::TX, USART_Buffer::TX_Head, USART_Buffer::TX_Tail, Usart_and_buffer::usart, and USART_TX_BUFFER_MASK.
| void USART_InterruptDriver_DreInterruptLevel_Set | ( | USART_data_t * | usart_data, |
| USART_DREINTLVL_t | dreIntLevel | ||
| ) |
Set USART DRE interrupt level.
Set the interrupt level on Data Register interrupt.
| usart_data | The USART_data_t struct instance |
| dreIntLevel | Interrupt level of the DRE interrupt. |
Definition at line 106 of file usart_driver.c.
References Usart_and_buffer::dreIntLevel.
| void USART_InterruptDriver_Initialize | ( | USART_data_t * | usart_data, |
| USART_t * | usart, | ||
| USART_DREINTLVL_t | dreIntLevel | ||
| ) |
Initializes buffer and selects what USART module to use.
Initializes receive and transmit buffer and selects what USART module to use, and stores the data register empty interrupt level.
| usart_data | The USART_data_t struct instance. |
| usart | The USART module. |
| dreIntLevel | Data register empty interrupt level. |
Definition at line 81 of file usart_driver.c.
References Usart_and_buffer::buffer, Usart_and_buffer::dreIntLevel, USART_Buffer::RX_Head, USART_Buffer::RX_Tail, USART_Buffer::TX_Head, USART_Buffer::TX_Tail, and Usart_and_buffer::usart.
| uint16_t USART_NineBits_GetChar | ( | USART_t * | usart | ) |
Get received data (9 bit character).
This function reads out the received 9 bit character (uint16_t). Use the function USART_IsRXComplete to check if anything is received.
| usart | The USART module. |
| Received | data. |
Definition at line 313 of file usart_driver.c.
| void USART_NineBits_PutChar | ( | USART_t * | usart, |
| uint16_t | data | ||
| ) |
Put data (9 bit character).
Use the function USART_IsTXDataRegisterEmpty before using this function to put 9 bit character to the TX register.
| usart | The USART module. |
| data | The data to send. |
Definition at line 292 of file usart_driver.c.
| uint8_t USART_RXBuffer_GetByte | ( | USART_data_t * | usart_data | ) |
Get received data (5-8 bit character).
The function USART_RXBufferData_Available should be used before this function is used to ensure that data is available.
Returns data from RX software buffer.
| usart_data | The USART_data_t struct instance. |
Definition at line 204 of file usart_driver.c.
References Usart_and_buffer::buffer, USART_Buffer::RX, USART_Buffer::RX_Tail, and USART_RX_BUFFER_MASK.
| bool USART_RXBufferData_Available | ( | USART_data_t * | usart_data | ) |
Test if there is data in the receive software buffer.
This function can be used to test if there is data in the receive software buffer.
| usart_data | The USART_data_t struct instance |
| true | There is data in the receive buffer. |
| false | The receive buffer is empty. |
Definition at line 181 of file usart_driver.c.
References Usart_and_buffer::buffer, USART_Buffer::RX_Head, and USART_Buffer::RX_Tail.
| bool USART_RXComplete | ( | USART_data_t * | usart_data | ) |
RX Complete Interrupt Service Routine.
RX Complete Interrupt Service Routine. Stores received data in RX software buffer.
| usart_data | The USART_data_t struct instance. |
Definition at line 227 of file usart_driver.c.
References Usart_and_buffer::buffer, USART_Buffer::RX, USART_Buffer::RX_Head, USART_Buffer::RX_Tail, Usart_and_buffer::usart, and USART_RX_BUFFER_MASK.
| bool USART_TXBuffer_FreeSpace | ( | USART_data_t * | usart_data | ) |
Test if there is data in the transmitter software buffer.
This function can be used to test if there is free space in the transmitter software buffer.
| usart_data | The USART_data_t struct instance. |
| true | There is data in the receive buffer. |
| false | The receive buffer is empty. |
Definition at line 123 of file usart_driver.c.
References Usart_and_buffer::buffer, USART_Buffer::TX_Head, USART_Buffer::TX_Tail, and USART_TX_BUFFER_MASK.
Referenced by USART_TXBuffer_PutByte().
| bool USART_TXBuffer_PutByte | ( | USART_data_t * | usart_data, |
| uint8_t | data | ||
| ) |
Put data (5-8 bit character).
Stores data byte in TX software buffer and enables DRE interrupt if there is free space in the TX software buffer.
| usart_data | The USART_data_t struct instance. |
| data | The data to send. |
Definition at line 143 of file usart_driver.c.
References Usart_and_buffer::buffer, Usart_and_buffer::dreIntLevel, USART_Buffer::TX, USART_Buffer::TX_Head, Usart_and_buffer::usart, USART_TX_BUFFER_MASK, and USART_TXBuffer_FreeSpace().
