rt-thread/bsp/efm32/drv_leuart.h
2022-04-05 19:34:30 +08:00

68 lines
1.8 KiB
C

/*
* Copyright (c) 2006-2022, RT-Thread Development Team
*
* SPDX-License-Identifier: Apache-2.0
*
* 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__ */