2011-12-16 09:05:50 +08:00
|
|
|
/***************************************************************************//**
|
2021-03-27 15:16:57 +08:00
|
|
|
* @file drv_leuart.h
|
|
|
|
* @brief LEUART driver of RT-Thread RTOS for EFM32
|
2012-05-18 12:40:40 +08:00
|
|
|
* COPYRIGHT (C) 2012, RT-Thread Development Team
|
2021-03-27 15:16:57 +08:00
|
|
|
* @author onelife
|
2012-05-18 12:40:40 +08:00
|
|
|
* @version 1.0
|
2011-12-16 09:05:50 +08:00
|
|
|
*******************************************************************************
|
|
|
|
* @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
|
2021-03-27 15:16:57 +08:00
|
|
|
* Date Author Notes
|
|
|
|
* 2011-12-09 onelife Initial creation for EFM32
|
2011-12-16 09:05:50 +08:00
|
|
|
******************************************************************************/
|
|
|
|
#ifndef __DRV_LEUSART_H__
|
|
|
|
#define __DRV_LEUSART_H__
|
|
|
|
|
|
|
|
/* Includes ------------------------------------------------------------------*/
|
|
|
|
/* Exported types ------------------------------------------------------------*/
|
|
|
|
struct efm32_leuart_int_mode_t
|
|
|
|
{
|
2021-03-27 15:16:57 +08:00
|
|
|
rt_uint8_t *data_ptr;
|
|
|
|
rt_uint8_t data_size;
|
|
|
|
rt_uint32_t read_index, save_index;
|
2011-12-16 09:05:50 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
struct efm32_leuart_dma_mode_t
|
|
|
|
{
|
2021-03-27 15:16:57 +08:00
|
|
|
/* DMA Channel */
|
|
|
|
rt_uint32_t dma_channel;
|
2011-12-16 09:05:50 +08:00
|
|
|
|
2021-03-27 15:16:57 +08:00
|
|
|
/* buffer info */
|
|
|
|
rt_uint32_t *data_ptr;
|
|
|
|
rt_uint8_t data_size;
|
2011-12-16 09:05:50 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
struct efm32_leuart_device_t
|
|
|
|
{
|
2021-03-27 15:16:57 +08:00
|
|
|
/* 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;
|
2011-12-16 09:05:50 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
/* 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__ */
|
|
|
|
|