/***************************************************************************//**
 * @file 	drv_leuart.h
 * @brief 	LEUART driver of RT-Thread RTOS for EFM32
 *  COPYRIGHT (C) 2012, RT-Thread Development Team
 * @author 	onelife
 * @version 1.0
 *******************************************************************************
 * @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
 * 2011-12-09	onelife		Initial creation for EFM32
 ******************************************************************************/
#ifndef __DRV_LEUSART_H__
#define __DRV_LEUSART_H__

/* Includes ------------------------------------------------------------------*/
/* Exported types ------------------------------------------------------------*/
struct efm32_leuart_int_mode_t
{
	rt_uint8_t  		*data_ptr;
	rt_uint8_t  		data_size;
	rt_uint32_t 		read_index, save_index;
};

struct efm32_leuart_dma_mode_t
{
	/* DMA Channel */
	rt_uint32_t 		dma_channel;

	/* buffer info */
	rt_uint32_t 		*data_ptr;
	rt_uint8_t  		data_size;
};

struct efm32_leuart_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 LEUART device structure */
	LEUART_TypeDef 		*leuart_device;
	/* Pointer to RX structure */
	void 				*rx_mode;
	/* Pointer to TX structure */
	void 				*tx_mode;
};

/* Exported constants --------------------------------------------------------*/
/* Exported macro ------------------------------------------------------------*/
#define LEUART_WAIT_TIME_TX     (RT_TICK_PER_SECOND / 100 * 3)

#define LEUART_STATE_CONSOLE    (1 << 0)
#define LEUART_STATE_SYNC       (1 << 1)
#define LEUART_STATE_MASTER     (1 << 2)
#define LEUART_STATE_AUTOCS     (1 << 3)
#define LEUART_STATE_TX_BUSY    (1 << 4)
#define LEUART_STATE_RX_BUSY    (1 << 5)


/* Exported functions ------------------------------------------------------- */
void rt_hw_leuart_init(void);

#endif /* __DRV_LEUSART_H__ */