user_uart.h 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260
  1. #ifndef __USER_UART_H__
  2. #define __USER_UART_H__
  3. #include <define.h>
  4. /* UART Printf Definition */
  5. #define USER_UART1_NoRemap 1 //Tx-PD5 Rx-PD6
  6. #define USER_UART1_Remap1 2 //Tx-PD6 Rx-PD5
  7. #define USER_UART1_Remap2 3 //Tx-PD0 Rx-PD1
  8. #define USER_UART1_Remap3 4 //Tx-PC0 Rx-PC1
  9. #define USER_UART1_Remap4 5 //Tx-PD1 Rx-PB3
  10. #define USER_UART1_Remap5 6 //Tx-PB3 Rx-PD1
  11. #define USER_UART1_Remap6 7 //Tx-PC5 Rx-PC6
  12. #define USER_UART1_Remap7 8 //Tx-PB5 Rx-PB6
  13. #define USER_UART1_Remap8 9 //Tx-PA0 Rx-PA1
  14. /* USART2 print function only for V005,V006,V007,M007 series*/
  15. #if defined(CH32V005) || defined(CH32V006) || defined(CH32V007_M007)
  16. #define USER_UART2_NoRemap 10 //Tx-PA7 Rx-PB3
  17. #define USER_UART2_Remap1 11 //Tx-PA4 Rx-PA5
  18. #define USER_UART2_Remap2 12 //Tx-PA2 Rx-PA3
  19. #define USER_UART2_Remap3 13 //Tx-PD2 Rx-PD3
  20. #define USER_UART2_Remap4 14 //Tx-PB0 Rx-PB1
  21. #define USER_UART2_Remap5 15 //Tx-PC4 Rx-PD1
  22. #define USER_UART2_Remap6 16 //Tx-PA6 Rx-PA5
  23. #endif
  24. typedef struct{
  25. uint32_t baudrate;
  26. uint16_t wordlength;
  27. uint16_t stopbit;
  28. uint16_t parity;
  29. }user_uart_param_s;
  30. //上报回调函数
  31. typedef void (*vUser_usart_data_upload_func)(uint8_t *data, uint16_t size);
  32. #if (USER_USART1_ENABLE == 1)
  33. #define USER_UART_DATA_SIZE 16
  34. #define USER_USART1_REMAP USER_UART1_Remap3
  35. #if (USER_USART1_REMAP == USER_UART1_NoRemap)
  36. #define USER_USART1_RCC_ENABLE RCC_PB2PeriphClockCmd(RCC_PB2Periph_GPIOD | RCC_PB2Periph_USART1, ENABLE)
  37. #define USER_USART1_TX_GPIO GPIOD
  38. #define USER_USART1_TX_PIN GPIO_Pin_5
  39. #define USER_USART1_RX_GPIO GPIOD
  40. #define USER_USART1_RX_PIN GPIO_Pin_6
  41. #elif (USER_USART1_REMAP == USER_UART1_Remap1)
  42. #define USER_USART1_RCC_ENABLE RCC_PB2PeriphClockCmd(RCC_PB2Periph_GPIOD | RCC_PB2Periph_USART1 | RCC_PB2Periph_AFIO, ENABLE)
  43. #define USER_USART1_REMAP_ENABLE GPIO_PinRemapConfig(GPIO_PartialRemap1_USART1, ENABLE);
  44. #define USER_USART1_TX_GPIO GPIOD
  45. #define USER_USART1_TX_PIN GPIO_Pin_6
  46. #define USER_USART1_RX_GPIO GPIOD
  47. #define USER_USART1_RX_PIN GPIO_Pin_5
  48. #elif (USER_USART1_REMAP == USER_UART1_Remap2)
  49. #define USER_USART1_RCC_ENABLE RCC_PB2PeriphClockCmd(RCC_PB2Periph_GPIOD | RCC_PB2Periph_USART1 | RCC_PB2Periph_AFIO, ENABLE)
  50. #define USER_USART1_REMAP_ENABLE GPIO_PinRemapConfig(GPIO_PartialRemap2_USART1, ENABLE);
  51. #define USER_USART1_TX_GPIO GPIOD
  52. #define USER_USART1_TX_PIN GPIO_Pin_0
  53. #define USER_USART1_RX_GPIO GPIOD
  54. #define USER_USART1_RX_PIN GPIO_Pin_1
  55. #elif (USER_USART1_REMAP == USER_UART1_Remap3)
  56. #define USER_USART1_RCC_ENABLE RCC_PB2PeriphClockCmd(RCC_PB2Periph_GPIOC | RCC_PB2Periph_USART1 | RCC_PB2Periph_AFIO, ENABLE)
  57. #define USER_USART1_REMAP_ENABLE GPIO_PinRemapConfig(GPIO_PartialRemap3_USART1, ENABLE);
  58. #define USER_USART1_TX_GPIO GPIOC
  59. #define USER_USART1_TX_PIN GPIO_Pin_0
  60. #define USER_USART1_RX_GPIO GPIOC
  61. #define USER_USART1_RX_PIN GPIO_Pin_1
  62. #elif (USER_USART1_REMAP == USER_UART1_Remap4)
  63. #define USER_USART1_RCC_ENABLE RCC_PB2PeriphClockCmd(RCC_PB2Periph_GPIOB | RCC_PB2Periph_GPIOD | RCC_PB2Periph_USART1 | RCC_PB2Periph_AFIO, ENABLE)
  64. #define USER_USART1_REMAP_ENABLE GPIO_PinRemapConfig(GPIO_PartialRemap4_USART1, ENABLE);
  65. #define USER_USART1_TX_GPIO GPIOD
  66. #define USER_USART1_TX_PIN GPIO_Pin_1
  67. #define USER_USART1_RX_GPIO GPIOB
  68. #define USER_USART1_RX_PIN GPIO_Pin_3
  69. #elif (USER_USART1_REMAP == USER_UART1_Remap5)
  70. #define USER_USART1_RCC_ENABLE RCC_PB2PeriphClockCmd(RCC_PB2Periph_GPIOB | RCC_PB2Periph_GPIOD | RCC_PB2Periph_USART1 | RCC_PB2Periph_AFIO, ENABLE)
  71. #define USER_USART1_REMAP_ENABLE GPIO_PinRemapConfig(GPIO_PartialRemap5_USART1, ENABLE);
  72. #define USER_USART1_TX_GPIO GPIOB
  73. #define USER_USART1_TX_PIN GPIO_Pin_3
  74. #define USER_USART1_RX_GPIO GPIOD
  75. #define USER_USART1_RX_PIN GPIO_Pin_1
  76. #elif (USER_USART1_REMAP == USER_UART1_Remap6)
  77. #define USER_USART1_RCC_ENABLE RCC_PB2PeriphClockCmd(RCC_PB2Periph_GPIOC | RCC_PB2Periph_USART1 | RCC_PB2Periph_AFIO, ENABLE)
  78. #define USER_USART1_REMAP_ENABLE GPIO_PinRemapConfig(GPIO_PartialRemap6_USART1, ENABLE);
  79. #define USER_USART1_TX_GPIO GPIOC
  80. #define USER_USART1_TX_PIN GPIO_Pin_5
  81. #define USER_USART1_RX_GPIO GPIOC
  82. #define USER_USART1_RX_PIN GPIO_Pin_6
  83. #elif (USER_USART1_REMAP == USER_UART1_Remap7)
  84. #define USER_USART1_RCC_ENABLE RCC_PB2PeriphClockCmd(RCC_PB2Periph_GPIOB | RCC_PB2Periph_USART1 | RCC_PB2Periph_AFIO, ENABLE)
  85. #define USER_USART1_REMAP_ENABLE GPIO_PinRemapConfig(GPIO_PartialRemap7_USART1, ENABLE);
  86. #define USER_USART1_TX_GPIO GPIOB
  87. #define USER_USART1_TX_PIN GPIO_Pin_5
  88. #define USER_USART1_RX_GPIO GPIOB
  89. #define USER_USART1_RX_PIN GPIO_Pin_6
  90. #elif (USER_USART1_REMAP == USER_UART1_Remap8)
  91. #define USER_USART1_RCC_ENABLE RCC_PB2PeriphClockCmd(RCC_PB2Periph_GPIOA | RCC_PB2Periph_USART1 | RCC_PB2Periph_AFIO, ENABLE)
  92. #define USER_USART1_REMAP_ENABLE GPIO_PinRemapConfig(GPIO_PartialRemap8_USART1, ENABLE);
  93. #define USER_USART1_TX_GPIO GPIOA
  94. #define USER_USART1_TX_PIN GPIO_Pin_0
  95. #define USER_USART1_RX_GPIO GPIOA
  96. #define USER_USART1_RX_PIN GPIO_Pin_1
  97. #endif
  98. #define USER_USART1_DMA_TX_ENABLE 1 //使能DMA TX功能,默认开启tx发送中断
  99. #define USER_USART1_DMA_RX_ENABLE 0 //使能DMA RX功能
  100. #define USER_USART1_RX_IRQ_ENABLE 1 //使能接收中断
  101. #if USER_USART1_RX_IRQ_ENABLE == 0
  102. #define USER_USART1_RX_DMA_IRQ_ENABLE 1 //使能DMA RX接收中断,此功能和usart接收中断二选一
  103. #endif
  104. void vUser_usart1_init(user_uart_param_s *param);
  105. bool vUser_usart1_send(uint8_t *data, uint16_t size);
  106. void vUser_usart1_set_data_upload_func(vUser_usart_data_upload_func func);
  107. #if (USER_USART1_DMA_RX_ENABLE == 0) && (USER_USART1_RX_IRQ_ENABLE == 0)
  108. bool vUser_usart1_set_recieve_finish_size(uint16_t size);
  109. #endif
  110. #endif
  111. #if (USER_USART2_ENABLE == 1)
  112. #define USER_USART2_REMAP USER_UART2_Remap3
  113. #if (USER_USART2_REMAP == USER_UART2_NoRemap)
  114. #define USER_USART2_RCC_ENABLE RCC_PB2PeriphClockCmd(RCC_PB2Periph_GPIOA | RCC_PB2Periph_GPIOB | RCC_PB2Periph_USART2, ENABLE)
  115. #define USER_USART2_TX_GPIO GPIOA
  116. #define USER_USART2_TX_PIN GPIO_Pin_7
  117. #define USER_USART2_RX_GPIO GPIOB
  118. #define USER_USART2_RX_PIN GPIO_Pin_3
  119. #elif (USER_USART2_REMAP == USER_UART2_Remap1)
  120. #define USER_USART2_RCC_ENABLE RCC_PB2PeriphClockCmd(RCC_PB2Periph_GPIOA | RCC_PB2Periph_USART2 | RCC_PB2Periph_AFIO, ENABLE)
  121. #define USER_USART2_REMAP_ENABLE GPIO_PinRemapConfig(GPIO_PartialRemap1_USART2, ENABLE);
  122. #define USER_USART2_TX_GPIO GPIOA
  123. #define USER_USART2_TX_PIN GPIO_Pin_4
  124. #define USER_USART2_RX_GPIO GPIOA
  125. #define USER_USART2_RX_PIN GPIO_Pin_5
  126. #elif (USER_USART2_REMAP == USER_UART2_Remap2)
  127. #define USER_USART2_RCC_ENABLE RCC_PB2PeriphClockCmd(RCC_PB2Periph_GPIOA | RCC_PB2Periph_USART2 | RCC_PB2Periph_AFIO, ENABLE)
  128. #define USER_USART2_REMAP_ENABLE GPIO_PinRemapConfig(GPIO_PartialRemap2_USART2, ENABLE);
  129. #define USER_USART2_TX_GPIO GPIOA
  130. #define USER_USART2_TX_PIN GPIO_Pin_2
  131. #define USER_USART2_RX_GPIO GPIOA
  132. #define USER_USART2_RX_PIN GPIO_Pin_3
  133. #elif (USER_USART2_REMAP == USER_UART2_Remap3)
  134. #define USER_USART2_RCC_ENABLE RCC_PB2PeriphClockCmd(RCC_PB2Periph_GPIOD | RCC_PB2Periph_USART2 | RCC_PB2Periph_AFIO, ENABLE)
  135. #define USER_USART2_REMAP_ENABLE GPIO_PinRemapConfig(GPIO_PartialRemap3_USART2, ENABLE);
  136. #define USER_USART2_TX_GPIO GPIOD
  137. #define USER_USART2_TX_PIN GPIO_Pin_2
  138. #define USER_USART2_RX_GPIO GPIOD
  139. #define USER_USART2_RX_PIN GPIO_Pin_3
  140. #elif (USER_USART2_REMAP == USER_UART2_Remap4)
  141. #define USER_USART2_RCC_ENABLE RCC_PB2PeriphClockCmd(RCC_PB2Periph_GPIOB | RCC_PB2Periph_USART2 | RCC_PB2Periph_AFIO, ENABLE)
  142. #define USER_USART2_REMAP_ENABLE GPIO_PinRemapConfig(GPIO_PartialRemap4_USART2, ENABLE);
  143. #define USER_USART2_TX_GPIO GPIOB
  144. #define USER_USART2_TX_PIN GPIO_Pin_0
  145. #define USER_USART2_RX_GPIO GPIOB
  146. #define USER_USART2_RX_PIN GPIO_Pin_1
  147. #elif (USER_USART2_REMAP == USER_UART1_Remap5)
  148. #define USER_USART2_RCC_ENABLE RCC_PB2PeriphClockCmd(RCC_PB2Periph_GPIOC | RCC_PB2Periph_GPIOD | RCC_PB2Periph_USART2 | RCC_PB2Periph_AFIO, ENABLE)
  149. #define USER_USART2_REMAP_ENABLE GPIO_PinRemapConfig(GPIO_PartialRemap5_USART2, ENABLE);
  150. #define USER_USART2_TX_GPIO GPIOC
  151. #define USER_USART2_TX_PIN GPIO_Pin_4
  152. #define USER_USART2_RX_GPIO GPIOD
  153. #define USER_USART2_RX_PIN GPIO_Pin_1
  154. #elif (USER_USART2_REMAP == USER_UART1_Remap6)
  155. #define USER_USART2_RCC_ENABLE RCC_PB2PeriphClockCmd(RCC_PB2Periph_GPIOA | RCC_PB2Periph_USART2 | RCC_PB2Periph_AFIO, ENABLE)
  156. #define USER_USART2_REMAP_ENABLE GPIO_PinRemapConfig(GPIO_PartialRemap6_USART2, ENABLE);
  157. #define USER_USART2_TX_GPIO GPIOA
  158. #define USER_USART2_TX_PIN GPIO_Pin_6
  159. #define USER_USART2_RX_GPIO GPIOA
  160. #define USER_USART2_RX_PIN GPIO_Pin_5
  161. #endif
  162. #define USER_USART2_DMA_TX_ENABLE 1 //使能DMA TX功能,默认开启tx发送中断
  163. #define USER_USART2_DMA_RX_ENABLE 0 //使能DMA RX功能
  164. #define USER_USART2_RX_IRQ_ENABLE 1 //使能接收中断
  165. #if USER_USART2_RX_IRQ_ENABLE == 0
  166. #define USER_USART2_RX_DMA_IRQ_ENABLE 1 //使能DMA RX接收中断,此功能和usart接收中断二选一
  167. #endif
  168. void vUser_usart2_init(user_uart_param_s *param);
  169. bool vUser_usart2_send(uint8_t *data, uint16_t size);
  170. void vUser_usart2_set_data_upload_func(vUser_usart_data_upload_func func);
  171. #if (USER_USART2_DMA_RX_ENABLE == 0) && (USER_USART2_RX_IRQ_ENABLE == 0)
  172. bool vUser_usart2_set_recieve_finish_size(uint16_t size);
  173. #endif
  174. #endif
  175. void vUser_usart_pro(void);
  176. #endif /* __USER_UART_H__ */