cmem7_uart.c 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177
  1. /**
  2. *****************************************************************************
  3. * @file cmem7_uart.c
  4. *
  5. * @brief CMEM7 uart file
  6. *
  7. *
  8. * @version V1.0
  9. * @date 3. September 2013
  10. *
  11. * @note
  12. *
  13. *****************************************************************************
  14. * @attention
  15. *
  16. * THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
  17. * WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE
  18. * TIME. AS A RESULT, CAPITAL-MICRO SHALL NOT BE HELD LIABLE FOR ANY DIRECT,
  19. * INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING
  20. * FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE
  21. * CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
  22. *
  23. * <h2><center>&copy; COPYRIGHT 2013 Capital-micro </center></h2>
  24. *****************************************************************************
  25. */
  26. #include "cmem7_uart.h"
  27. #define UART_Mode_8b 1
  28. #define UART_Mode_8b_Parity 7
  29. #define UART_BaudMode_0 0
  30. #define UART_BaudMode_1 1
  31. #define UART_BaudMode_Division 19200
  32. #define UART_WR_MAX_FIFO_SIZE 16
  33. static uint32_t UART_GetClock(UART0_Type* UARTx) {
  34. uint32_t dividor;
  35. if ((uint32_t)UARTx == (uint32_t)UART0) {
  36. dividor = GLOBAL_CTRL->CLK_SEL_0_b.UART0_CLK;
  37. } else if ((uint32_t)UARTx == (uint32_t)UART1) {
  38. dividor = GLOBAL_CTRL->CLK_SEL_0_b.UART1_CLK;
  39. } else if ((uint32_t)UARTx == (uint32_t)UART2) {
  40. dividor = GLOBAL_CTRL->CLK_SEL_1_b.UART2_CLK;
  41. }
  42. return SYSTEM_CLOCK_FREQ / (1 << (dividor + 1));
  43. }
  44. static uint16_t UART_CalcBaudrateReload(uint32_t FreqHz, uint32_t Baudrate) {
  45. if (Baudrate <= UART_BaudMode_Division) {
  46. /** reload in mode 0
  47. * reload = FreqHz / 16 * Baudrate
  48. * round up
  49. * reload = FreqHz / 16 * Baudrate + 1/ 2
  50. * reload = (2 * FreqHz + 16 * Baudrate) / 2 * 16 * Baudrate
  51. */
  52. return ((FreqHz << 1) + (Baudrate << 4)) / (Baudrate << 5);
  53. }
  54. /** reload in mode 1
  55. * reload = Baudrate * 16 * 65536 / FreqHz
  56. * round up
  57. * reload = Baudrate * 16 * 65536 / FreqHz + 1/ 2
  58. * reload = (2 * Baudrate * 16 * 65536 + FreqHz) / 2 * FreqHz
  59. */
  60. return ((((uint64_t)(Baudrate)) << 21) + FreqHz) / (FreqHz << 1);
  61. }
  62. void UART_Init(UART0_Type* UARTx, UART_InitTypeDef *init) {
  63. assert_param(IS_UART_ALL_PERIPH(UARTx));
  64. assert_param(init);
  65. assert_param(IS_UART_STOPBITS(init->UART_StopBits));
  66. assert_param(IS_UART_PARITY(init->UART_Parity));
  67. /* TODO : assume clock is 50MHz */
  68. UARTx->BAUDRATE = UART_CalcBaudrateReload(
  69. UART_GetClock(UARTx), init->UART_BaudRate);
  70. UARTx->CTRL_b.MODE =
  71. (init->UART_Parity == UART_Parity_None) ?
  72. UART_Mode_8b : UART_Mode_8b_Parity;
  73. UARTx->CTRL_b.STOP = init->UART_StopBits;
  74. UARTx->CTRL_b.PARITY =
  75. (init->UART_Parity == UART_Parity_None) ?
  76. UART_Parity_Even : init->UART_Parity;
  77. UARTx->CTRL_b.LOOPBACK = init->UART_LoopBack;
  78. UARTx->CTRL_b.RX_EN = init->UART_RxEn;
  79. UARTx->CTRL_b.CTS = init->UART_CtsEn;
  80. UARTx->CTRL_b.BAUD_MODE =
  81. (init->UART_BaudRate > UART_BaudMode_Division) ?
  82. UART_BaudMode_1 : UART_BaudMode_0;
  83. UARTx->CTRL_b.FIFO_EN = TRUE;
  84. UARTx->CTRL_b.RX_THRESHOLD = UART_WR_MAX_FIFO_SIZE;
  85. UARTx->CTRL_b.RX_HALF_FULL = (UART_WR_MAX_FIFO_SIZE >> 1);
  86. UARTx->TIMEOUT = 0xFF;
  87. UARTx->INT_MASK |= UART_Int_All;
  88. UARTx->INT_SEEN &= UART_Int_All;
  89. }
  90. void UART_EnableInt(UART0_Type* UARTx, uint32_t Int, BOOL enable) {
  91. assert_param(IS_UART_ALL_PERIPH(UARTx));
  92. assert_param(IS_UART_INT(Int));
  93. if (enable) {
  94. UARTx->INT_MASK &= ~Int;
  95. } else {
  96. UARTx->INT_MASK |= Int;
  97. }
  98. UARTx->INT_MASK &= UART_Int_All;
  99. }
  100. void UART_Enable(UART0_Type* UARTx, BOOL enable) {
  101. assert_param(IS_UART_ALL_PERIPH(UARTx));
  102. UARTx->RUN_b.EN = enable;
  103. }
  104. BOOL UART_GetIntStatus(UART0_Type* UARTx, uint32_t Int) {
  105. assert_param(IS_UART_ALL_PERIPH(UARTx));
  106. assert_param(IS_UART_INT(Int));
  107. if (0 != (UARTx->INT_SEEN & Int)) {
  108. return TRUE;
  109. }
  110. return FALSE;
  111. }
  112. void UART_ClearInt(UART0_Type* UARTx, uint32_t Int) {
  113. assert_param(IS_UART_ALL_PERIPH(UARTx));
  114. assert_param(IS_UART_INT(Int));
  115. UARTx->INT_SEEN = Int;
  116. }
  117. uint8_t UART_Write(UART0_Type* UARTx, uint8_t Size, uint8_t* Data) {
  118. uint8_t count;
  119. /* Check the parameters */
  120. assert_param(IS_UART_ALL_PERIPH(UARTx));
  121. assert_param(Data);
  122. if (!UARTx->RUN_b.EN) {
  123. return 0;
  124. }
  125. count = 0;
  126. while (!UARTx->STATUS_b.TF && count < Size) {
  127. UARTx->TX_BUF = *(Data + count++);
  128. }
  129. return count;
  130. }
  131. /* return value is actual read data size */
  132. uint8_t UART_Read(UART0_Type* UARTx, uint8_t Size, uint8_t* Data) {
  133. uint8_t count;
  134. assert_param(IS_UART_ALL_PERIPH(UARTx));
  135. assert_param(Data);
  136. if (!UARTx->RUN_b.EN) {
  137. return 0;
  138. }
  139. count = 0;
  140. while (UARTx->STATUS_b.RNE && count < Size) {
  141. *(Data + count++) = (UARTx->RX_BUF & 0x00FF);
  142. }
  143. return count;
  144. }