portserial.c 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265
  1. #include "at32f403a_407.h"
  2. //#include "at32f403a_407_board.h"
  3. //#include "at32f403a_407_clock.h"
  4. #include "FreeRTOS.h"
  5. #include "task.h"
  6. #include "mb.h"
  7. #include "port.h"
  8. #include "mbport.h"
  9. #include <stdlib.h>
  10. #define USART_INVALID_PORT ( 0xFF )
  11. void vMBPortSerialEnable( BOOL xRxEnable, BOOL xTxEnable )
  12. {
  13. if (xRxEnable) {
  14. gpio_bits_reset(GPIOD, GPIO_PINS_10);
  15. usart_interrupt_enable(USART3, USART_RDBF_INT, TRUE);
  16. }
  17. else {
  18. gpio_bits_set(GPIOD, GPIO_PINS_10);
  19. usart_interrupt_enable(USART3, USART_RDBF_INT, FALSE);
  20. }
  21. if (xTxEnable) {
  22. gpio_bits_set(GPIOD, GPIO_PINS_10);
  23. usart_interrupt_enable(USART3, USART_TDC_INT, TRUE);
  24. }
  25. else {
  26. gpio_bits_reset(GPIOD, GPIO_PINS_10);
  27. usart_interrupt_enable(USART3, USART_TDC_INT, FALSE);
  28. }
  29. }
  30. BOOL xMBPortSerialInit( UCHAR ucPORT, ULONG ulBaudRate, UCHAR ucDataBits,
  31. eMBParity eParity, unsigned int stop_bit )
  32. {
  33. gpio_init_type gpio_init_struct;
  34. usart_parity_selection_type parity;
  35. usart_data_bit_num_type data_bits;
  36. usart_stop_bit_num_type stop_bits;
  37. crm_periph_clock_enable(CRM_USART3_PERIPH_CLOCK, TRUE);
  38. crm_periph_clock_enable(CRM_GPIOD_PERIPH_CLOCK, TRUE);
  39. crm_periph_clock_enable(CRM_IOMUX_PERIPH_CLOCK, TRUE);
  40. gpio_pin_remap_config(USART3_GMUX_0011, TRUE);
  41. gpio_default_para_init(&gpio_init_struct);
  42. // configure the uart tx pin
  43. gpio_init_struct.gpio_drive_strength = GPIO_DRIVE_STRENGTH_STRONGER;
  44. gpio_init_struct.gpio_out_type = GPIO_OUTPUT_PUSH_PULL;
  45. gpio_init_struct.gpio_mode = GPIO_MODE_MUX;
  46. gpio_init_struct.gpio_pins = GPIO_PINS_8;
  47. gpio_init_struct.gpio_pull = GPIO_PULL_NONE;
  48. gpio_init(GPIOD, &gpio_init_struct);
  49. // configure the uart rx pin
  50. gpio_init_struct.gpio_mode = GPIO_MODE_INPUT;
  51. gpio_init_struct.gpio_pins = GPIO_PINS_9;
  52. gpio_init_struct.gpio_pull = GPIO_PULL_UP;
  53. gpio_init(GPIOD, &gpio_init_struct);
  54. // configure the uart rx pin
  55. gpio_init_struct.gpio_drive_strength = GPIO_DRIVE_STRENGTH_STRONGER;
  56. gpio_init_struct.gpio_out_type = GPIO_OUTPUT_PUSH_PULL;
  57. gpio_init_struct.gpio_mode = GPIO_MODE_OUTPUT;
  58. gpio_init_struct.gpio_pins = GPIO_PINS_10;
  59. gpio_init_struct.gpio_pull = GPIO_PULL_UP;
  60. gpio_init(GPIOD, &gpio_init_struct);
  61. gpio_bits_reset(GPIOD, GPIO_PINS_10);
  62. //gpio_bits_set(GPIOD, GPIO_PINS_10);
  63. switch (eParity)
  64. {
  65. case MB_PAR_NONE :
  66. parity = USART_PARITY_NONE;
  67. data_bits = USART_DATA_8BITS;
  68. break;
  69. case MB_PAR_ODD :
  70. parity = USART_PARITY_ODD;
  71. data_bits = USART_DATA_9BITS;
  72. break;
  73. case MB_PAR_EVEN :
  74. parity = USART_PARITY_EVEN;
  75. data_bits = USART_DATA_9BITS;
  76. break;
  77. default :
  78. return FALSE;
  79. }
  80. switch (stop_bit)
  81. {
  82. case 1 :
  83. stop_bits = USART_STOP_1_BIT;
  84. break;
  85. case 3 :
  86. stop_bits = USART_STOP_2_BIT;
  87. break;
  88. default :
  89. return FALSE;
  90. }
  91. // configure uart param
  92. usart_init(USART3, ulBaudRate, data_bits, stop_bits);
  93. usart_parity_selection_config(USART3, parity);
  94. usart_flag_clear(USART3, USART_RDBF_FLAG);
  95. usart_interrupt_enable(USART3, USART_RDBF_INT, TRUE);
  96. usart_receiver_enable(USART3, TRUE);
  97. usart_transmitter_enable(USART3, TRUE);
  98. usart_enable(USART3, TRUE);
  99. nvic_priority_group_config(NVIC_PRIORITY_GROUP_4);
  100. nvic_irq_enable(USART3_IRQn, 5, 0);
  101. //usart_interrupt_enable(USART3, USART_TDC_INT, TRUE);
  102. //usart_interrupt_enable(USART3, USART_RDBF_INT, TRUE);
  103. return TRUE;
  104. #if 0
  105. GPIO_InitTypeDef GPIO_InitStruct = {0};
  106. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  107. GPIO_InitStruct.Pull = GPIO_NOPULL;
  108. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_VERY_HIGH;
  109. __HAL_RCC_USART4_FORCE_RESET();
  110. __HAL_RCC_USART4_RELEASE_RESET();
  111. huart.Init.BaudRate = ulBaudRate;
  112. huart.Init.Mode = UART_MODE_TX_RX;
  113. huart.Init.HwFlowCtl = UART_HWCONTROL_NONE;
  114. huart.Init.OverSampling = UART_OVERSAMPLING_16;
  115. huart.Init.OneBitSampling = UART_ONE_BIT_SAMPLE_DISABLE;
  116. huart.Init.ClockPrescaler = UART_PRESCALER_DIV1;
  117. huart.AdvancedInit.AdvFeatureInit = UART_ADVFEATURE_NO_INIT;
  118. switch (ucPORT)
  119. {
  120. case 4 :
  121. __HAL_RCC_USART4_CLK_ENABLE();
  122. __HAL_RCC_GPIOA_CLK_ENABLE();
  123. GPIO_InitStruct.Pin = GPIO_PIN_0 | GPIO_PIN_1;
  124. GPIO_InitStruct.Alternate = GPIO_AF4_USART4;
  125. HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
  126. huart.Instance = USART4;
  127. HAL_NVIC_SetPriority(USART3_4_IRQn, 5, 0);
  128. break;
  129. default :
  130. return FALSE;
  131. }
  132. switch (eParity)
  133. {
  134. case MB_PAR_NONE :
  135. huart.Init.Parity = UART_PARITY_NONE;
  136. huart.Init.WordLength = UART_WORDLENGTH_8B;
  137. break;
  138. case MB_PAR_ODD :
  139. huart.Init.Parity = UART_PARITY_ODD;
  140. huart.Init.WordLength = UART_WORDLENGTH_9B;
  141. break;
  142. case MB_PAR_EVEN :
  143. huart.Init.Parity = UART_PARITY_EVEN;
  144. huart.Init.WordLength = UART_WORDLENGTH_9B;
  145. break;
  146. default :
  147. return FALSE;
  148. }
  149. switch (stop_bit)
  150. {
  151. case 1 :
  152. huart.Init.StopBits = UART_STOPBITS_1;
  153. break;
  154. case 3 :
  155. huart.Init.StopBits = UART_STOPBITS_2;
  156. break;
  157. default :
  158. return FALSE;
  159. }
  160. HAL_UART_Init(&huart);
  161. HAL_NVIC_EnableIRQ(USART3_4_IRQn);
  162. return TRUE;
  163. #endif
  164. }
  165. //
  166. void vMBPortSerialClose( void )
  167. {
  168. crm_periph_clock_enable(CRM_USART3_PERIPH_CLOCK, FALSE);
  169. }
  170. //
  171. BOOL xMBPortSerialPutByte( CHAR ucByte )
  172. {
  173. //while(usart_flag_get(USART3, USART_TDBE_FLAG) == RESET);
  174. USART3->dt = ((uint16_t)ucByte & 0x01FF);
  175. //while(usart_flag_get(USART3, USART_TDC_FLAG) == RESET);
  176. return TRUE;
  177. #if 0
  178. USART3->dt = ((uint16_t)ucByte & 0x01FF);
  179. return TRUE;
  180. #endif
  181. }
  182. //
  183. BOOL xMBPortSerialGetByte( CHAR * pucByte )
  184. {
  185. *pucByte = USART3->dt;
  186. return TRUE;
  187. }
  188. //
  189. void USART3_IRQHandler(void)
  190. {
  191. if (usart_flag_get(USART3, USART_RDBF_FLAG) != RESET) {
  192. pxMBFrameCBByteReceived();
  193. }
  194. if (usart_flag_get(USART3, USART_TDC_FLAG) != RESET) {
  195. vMBPortSetWithinException(TRUE);
  196. pxMBFrameCBTransmitterEmpty();
  197. vMBPortSetWithinException(FALSE);
  198. }
  199. }
  200. //
  201. void vMB_USART_IRQHandler(void)
  202. {
  203. #if 0
  204. if ((__HAL_UART_GET_IT(&huart, UART_IT_RXNE) != RESET) && (__HAL_UART_GET_IT_SOURCE(&huart, UART_IT_RXNE) != RESET)) {
  205. pxMBFrameCBByteReceived();
  206. __HAL_UART_SEND_REQ(&huart, UART_RXDATA_FLUSH_REQUEST);
  207. }
  208. if ((__HAL_UART_GET_IT(&huart, UART_IT_TXE) != RESET) &&(__HAL_UART_GET_IT_SOURCE(&huart, UART_IT_TXE) != RESET)) {
  209. pxMBFrameCBTransmitterEmpty();
  210. HAL_GPIO_TogglePin(GPIOA, GPIO_PIN_5);
  211. }
  212. if (__HAL_UART_GET_IT(&huart, UART_IT_ERR) != RESET)
  213. __HAL_UART_CLEAR_IT(&huart, UART_CLEAR_OREF);
  214. #endif
  215. }