drv_usart.h 2.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. /*
  2. * Copyright (c) 2006-2022, RT-Thread Development Team
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Change Logs:
  7. * Date Author Notes
  8. * 2010-12-22 onelife Initial creation for EFM32
  9. * 2011-06-27 onelife Fix a bug when using compiler optimization
  10. * 2011-07-26 onelife Add lock (semaphore) to prevent simultaneously
  11. * access
  12. * 2011-12-09 onelife Add giant gecko support
  13. * 2011-12-09 onelife Add UART module support
  14. * 2011-12-20 onelife Change USART status format
  15. */
  16. #ifndef __DRV_USART_H__
  17. #define __DRV_USART_H__
  18. /* Includes ------------------------------------------------------------------*/
  19. /* Exported types ------------------------------------------------------------*/
  20. struct efm32_usart_int_mode_t
  21. {
  22. rt_uint8_t *data_ptr;
  23. rt_uint8_t data_size;
  24. rt_uint32_t read_index, save_index;
  25. };
  26. struct efm32_usart_dma_mode_t
  27. {
  28. /* DMA Channel */
  29. rt_uint32_t dma_channel;
  30. /* buffer info */
  31. rt_uint32_t *data_ptr;
  32. rt_uint8_t data_size;
  33. };
  34. struct efm32_usart_device_t
  35. {
  36. /* Counter */
  37. rt_uint32_t counter;
  38. /* Lock */
  39. struct rt_semaphore *lock;
  40. /* Unit number */
  41. rt_uint8_t unit;
  42. /* State */
  43. volatile rt_uint8_t state;
  44. /* Pointer to USART device structure */
  45. USART_TypeDef *usart_device;
  46. /* Pointer to RX structure */
  47. void *rx_mode;
  48. /* Pointer to TX structure */
  49. void *tx_mode;
  50. };
  51. /* Exported constants --------------------------------------------------------*/
  52. /* Exported macro ------------------------------------------------------------*/
  53. #define USART_WAIT_TIME_TX (RT_TICK_PER_SECOND / 100 * 3)
  54. #define USART_STATE_CONSOLE (1 << 0)
  55. #define USART_STATE_TX_BUSY (1 << 1)
  56. #define USART_STATE_RX_BUSY (1 << 2)
  57. #if defined(UART_PRESENT)
  58. #define USART_STATE_ASYNC_ONLY (1 << 3)
  59. #endif
  60. #define USART_STATE_SYNC (1 << 4)
  61. #define USART_STATE_MASTER (1 << 5)
  62. #define USART_STATE_AUTOCS (1 << 6)
  63. #define USART_STATE_9BIT (1 << 7)
  64. #define USART_CLK_MODE_GET(state) ((state >> 8) & 0x03)
  65. #define SYNC_SETTING_MASK (0x1F)
  66. #define SYNC_SETTING_SHIFT (5)
  67. /* Exported functions ------------------------------------------------------- */
  68. void rt_hw_usart_init(void);
  69. #endif /* __DRV_USART_H__ */