drv_usart.h 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. /***************************************************************************//**
  2. * @file drv_usart.h
  3. * @brief USART driver of RT-Thread RTOS for EFM32
  4. * COPYRIGHT (C) 2012, RT-Thread Development Team
  5. * @author onelife
  6. * @version 1.0
  7. *******************************************************************************
  8. * @section License
  9. * The license and distribution terms for this file may be found in the file
  10. * LICENSE in this distribution or at http://www.rt-thread.org/license/LICENSE
  11. *******************************************************************************
  12. * @section Change Logs
  13. * Date Author Notes
  14. * 2010-12-22 onelife Initial creation for EFM32
  15. * 2011-06-27 onelife Fix a bug when using compiler optimization
  16. * 2011-07-26 onelife Add lock (semaphore) to prevent simultaneously
  17. * access
  18. * 2011-12-09 onelife Add giant gecko support
  19. * 2011-12-09 onelife Add UART module support
  20. * 2011-12-20 onelife Change USART status format
  21. ******************************************************************************/
  22. #ifndef __DRV_USART_H__
  23. #define __DRV_USART_H__
  24. /* Includes ------------------------------------------------------------------*/
  25. /* Exported types ------------------------------------------------------------*/
  26. struct efm32_usart_int_mode_t
  27. {
  28. rt_uint8_t *data_ptr;
  29. rt_uint8_t data_size;
  30. rt_uint32_t read_index, save_index;
  31. };
  32. struct efm32_usart_dma_mode_t
  33. {
  34. /* DMA Channel */
  35. rt_uint32_t dma_channel;
  36. /* buffer info */
  37. rt_uint32_t *data_ptr;
  38. rt_uint8_t data_size;
  39. };
  40. struct efm32_usart_device_t
  41. {
  42. /* Counter */
  43. rt_uint32_t counter;
  44. /* Lock */
  45. struct rt_semaphore *lock;
  46. /* Unit number */
  47. rt_uint8_t unit;
  48. /* State */
  49. volatile rt_uint8_t state;
  50. /* Pointer to USART device structure */
  51. USART_TypeDef *usart_device;
  52. /* Pointer to RX structure */
  53. void *rx_mode;
  54. /* Pointer to TX structure */
  55. void *tx_mode;
  56. };
  57. /* Exported constants --------------------------------------------------------*/
  58. /* Exported macro ------------------------------------------------------------*/
  59. #define USART_WAIT_TIME_TX (RT_TICK_PER_SECOND / 100 * 3)
  60. #define USART_STATE_CONSOLE (1 << 0)
  61. #define USART_STATE_TX_BUSY (1 << 1)
  62. #define USART_STATE_RX_BUSY (1 << 2)
  63. #if defined(UART_PRESENT)
  64. #define USART_STATE_ASYNC_ONLY (1 << 3)
  65. #endif
  66. #define USART_STATE_SYNC (1 << 4)
  67. #define USART_STATE_MASTER (1 << 5)
  68. #define USART_STATE_AUTOCS (1 << 6)
  69. #define USART_STATE_9BIT (1 << 7)
  70. #define USART_CLK_MODE_GET(state) ((state >> 8) & 0x03)
  71. #define SYNC_SETTING_MASK (0x1F)
  72. #define SYNC_SETTING_SHIFT (5)
  73. /* Exported functions ------------------------------------------------------- */
  74. void rt_hw_usart_init(void);
  75. #endif /* __DRV_USART_H__ */