rt-thread-official/bsp/efm32/drv_usart.h

85 lines
3.0 KiB
C

/***************************************************************************//**
* @file drv_usart.h
* @brief USART driver of RT-Thread RTOS for EFM32
* COPYRIGHT (C) 2011, RT-Thread Development Team
* @author onelife
* @version 0.4 beta
*******************************************************************************
* @section License
* The license and distribution terms for this file may be found in the file
* LICENSE in this distribution or at http://www.rt-thread.org/license/LICENSE
*******************************************************************************
* @section Change Logs
* Date Author Notes
* 2010-12-22 onelife Initial creation for EFM32
* 2011-06-27 onelife Fix a bug when using compiler optimization
* 2011-07-26 onelife Add lock (semaphore) to prevent simultaneously
* access
* 2011-12-09 onelife Add giant gecko support
* 2011-12-09 onelife Add UART module support
* 2011-12-20 onelife Change USART status format
******************************************************************************/
#ifndef __DRV_USART_H__
#define __DRV_USART_H__
/* Includes ------------------------------------------------------------------*/
/* Exported types ------------------------------------------------------------*/
struct efm32_usart_int_mode_t
{
rt_uint8_t *data_ptr;
rt_uint8_t data_size;
rt_uint32_t read_index, save_index;
};
struct efm32_usart_dma_mode_t
{
/* DMA Channel */
rt_uint32_t dma_channel;
/* buffer info */
rt_uint32_t *data_ptr;
rt_uint8_t data_size;
};
struct efm32_usart_device_t
{
/* Counter */
rt_uint32_t counter;
/* Lock */
struct rt_semaphore *lock;
/* Unit number */
rt_uint8_t unit;
/* State */
volatile rt_uint8_t state;
/* Pointer to USART device structure */
USART_TypeDef *usart_device;
/* Pointer to RX structure */
void *rx_mode;
/* Pointer to TX structure */
void *tx_mode;
};
/* Exported constants --------------------------------------------------------*/
/* Exported macro ------------------------------------------------------------*/
#define USART_WAIT_TIME_TX (RT_TICK_PER_SECOND / 100 * 3)
#define USART_STATE_CONSOLE (1 << 0)
#define USART_STATE_TX_BUSY (1 << 1)
#define USART_STATE_RX_BUSY (1 << 2)
#if defined(UART_PRESENT)
#define USART_STATE_ASYNC_ONLY (1 << 3)
#endif
#define USART_STATE_SYNC (1 << 4)
#define USART_STATE_MASTER (1 << 5)
#define USART_STATE_AUTOCS (1 << 6)
#define USART_STATE_9BIT (1 << 7)
#define USART_CLK_MODE_GET(state) ((state >> 8) & 0x03)
#define SYNC_SETTING_MASK (0x1F)
#define SYNC_SETTING_SHIFT (5)
/* Exported functions ------------------------------------------------------- */
void rt_hw_usart_init(void);
#endif /* __DRV_USART_H__ */