123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384 |
- /***************************************************************************//**
- * @file drv_usart.h
- * @brief USART 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
- * 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__ */
|