Uart.c 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324
  1. #include "includes.h"
  2. #include "Uart.h"
  3. /////////////////////////////////////////////////////////////////////////////
  4. uint8_t usart0TX_Buffer[USART0_TX_SIZE] = {0x01,0x02,0x03,0x04,0x05,0x06,0x07,0x08};
  5. uint8_t usart0RX_Buffer[USART0_RX_SIZE] = {0};
  6. void dma_init_uart0(void)
  7. {
  8. dma_parameter_struct dma_init_Usart0_TX;
  9. dma_parameter_struct dma_init_Usart0_RX;
  10. rcu_periph_clock_enable(RCU_DMA0);
  11. dma_deinit(DMA0, DMA_CH3);
  12. dma_deinit(DMA0, DMA_CH4);
  13. /* initialize DMA0 channel3(Usart0_TX) */
  14. dma_init_Usart0_TX.direction = DMA_MEMORY_TO_PERIPHERAL;
  15. dma_init_Usart0_TX.memory_addr = (uint32_t)usart0TX_Buffer;
  16. dma_init_Usart0_TX.memory_inc = DMA_MEMORY_INCREASE_ENABLE;
  17. dma_init_Usart0_TX.memory_width = DMA_MEMORY_WIDTH_8BIT;
  18. dma_init_Usart0_TX.number = (uint32_t)USART0_TX_SIZE;
  19. dma_init_Usart0_TX.periph_addr = (uint32_t)(&USART_DATA(USART0));
  20. dma_init_Usart0_TX.periph_inc = DMA_PERIPH_INCREASE_DISABLE;
  21. dma_init_Usart0_TX.periph_width = DMA_PERIPHERAL_WIDTH_8BIT;
  22. dma_init_Usart0_TX.priority = DMA_PRIORITY_LOW;
  23. dma_init(DMA0, DMA_CH3, &dma_init_Usart0_TX);
  24. dma_circulation_disable(DMA0, DMA_CH3);
  25. /* initialize DMA0 channel4(Usart0_RX) */
  26. dma_init_Usart0_RX.direction = DMA_PERIPHERAL_TO_MEMORY;
  27. dma_init_Usart0_RX.memory_addr = (uint32_t)usart0RX_Buffer;
  28. dma_init_Usart0_RX.memory_inc = DMA_MEMORY_INCREASE_ENABLE;
  29. dma_init_Usart0_RX.memory_width = DMA_MEMORY_WIDTH_8BIT;
  30. dma_init_Usart0_RX.number = (uint32_t)USART0_RX_SIZE;
  31. dma_init_Usart0_RX.periph_addr = (uint32_t)(&USART_DATA(USART0));
  32. dma_init_Usart0_RX.periph_inc = DMA_PERIPH_INCREASE_DISABLE;
  33. dma_init_Usart0_RX.periph_width = DMA_PERIPHERAL_WIDTH_8BIT;
  34. dma_init_Usart0_RX.priority = DMA_PRIORITY_HIGH;//DMA_PRIORITY_LOW;
  35. dma_init(DMA0, DMA_CH4, &dma_init_Usart0_RX);
  36. dma_circulation_disable(DMA0, DMA_CH4);//circulate or not makes no difference
  37. dma_memory_to_memory_disable(DMA0,DMA_CH3);
  38. dma_memory_to_memory_disable(DMA0,DMA_CH4);
  39. /* enable all DMA channels you need */
  40. dma_channel_enable(DMA0,DMA_CH4);
  41. dma_channel_disable(DMA0,DMA_CH3);
  42. }
  43. void usart0_config(void)
  44. {
  45. /* enable GPIO clock */
  46. rcu_periph_clock_enable(RCU_GPIOA);
  47. /* enable USART clock */
  48. rcu_periph_clock_enable(RCU_USART0);
  49. /* connect port to USARTx_Tx */
  50. gpio_init(GPIOA, GPIO_MODE_AF_PP, GPIO_OSPEED_50MHZ, GPIO_PIN_9);
  51. /* connect port to USARTx_Rx */
  52. gpio_init(GPIOA, GPIO_MODE_IN_FLOATING, GPIO_OSPEED_50MHZ, GPIO_PIN_10);
  53. /* USART configure */
  54. usart_deinit(USART0);
  55. usart_word_length_set(USART0, USART_WL_8BIT);
  56. usart_stop_bit_set(USART0, USART_STB_1BIT);
  57. usart_parity_config(USART0, USART_PM_NONE);
  58. usart_baudrate_set(USART0, 115200U);
  59. usart_hardware_flow_rts_config(USART0, USART_RTS_DISABLE);
  60. usart_hardware_flow_cts_config(USART0, USART_CTS_DISABLE);
  61. usart_receive_config(USART0, USART_RECEIVE_ENABLE);
  62. usart_transmit_config(USART0, USART_TRANSMIT_ENABLE);
  63. /* config USARTx_TX transmit by DMA */
  64. usart_dma_transmit_config(USART0,USART_DENT_ENABLE);
  65. usart_dma_receive_config(USART0,USART_DENR_ENABLE);
  66. /* USART1 IRQ set */
  67. nvic_irq_enable(USART0_IRQn, 1, 0);
  68. // nvic_irq_enable(DMA0_Channel6_IRQn, 1, 1);
  69. usart_interrupt_enable(USART0, USART_INT_IDLE);
  70. // usart_interrupt_enable(USART0, USART_INT_TC); // 使能发送完成中断
  71. usart_enable(USART0);
  72. }
  73. void USART0_IRQHandler(void)
  74. {
  75. volatile uint8_t len = 0;
  76. if((RESET != usart_interrupt_flag_get(USART0, USART_INT_FLAG_IDLE)) \
  77. && (RESET != usart_flag_get(USART0, USART_FLAG_IDLEF)))
  78. {
  79. usart_interrupt_flag_clear(USART0, USART_INT_FLAG_IDLE);//
  80. usart_flag_clear(USART0, USART_FLAG_IDLEF);
  81. dma_channel_disable(DMA0, DMA_CH4);
  82. usart_data_receive(USART0);
  83. len = USART0_RX_SIZE - dma_transfer_number_get(DMA0,DMA_CH4);
  84. if(len>5)
  85. En_Queue(uart0_rx_sq,usart0RX_Buffer,len,len);//数据入队,可多次调用
  86. dma_memory_address_config(DMA0,DMA_CH4,(uint32_t)usart0RX_Buffer);
  87. dma_transfer_number_config(DMA0,DMA_CH4, USART0_RX_SIZE);/* reset DMA_Channel CNT */
  88. dma_channel_enable(DMA0,DMA_CH4);/* enable USART1_RX DMA_Channel */
  89. }
  90. }
  91. /*------------------------------------------485----------------------------------------*/
  92. void RS485_USART_IRQHandler(void)
  93. {
  94. volatile uint8_t len = 0;
  95. if((RESET != usart_interrupt_flag_get(RS485_USARTx, USART_INT_FLAG_IDLE)) \
  96. && (RESET != usart_flag_get(RS485_USARTx, USART_FLAG_IDLEF)))
  97. {
  98. usart_interrupt_flag_clear(RS485_USARTx, USART_INT_FLAG_IDLE);//
  99. usart_flag_clear(RS485_USARTx, USART_FLAG_IDLEF);
  100. dma_channel_disable(RS485_DMAx, RS485_DMA_CH_RX);
  101. usart_data_receive(RS485_USARTx);
  102. len = USART3_RX_SIZE - dma_transfer_number_get(RS485_DMAx,RS485_DMA_CH_RX);
  103. if(len>5)
  104. En_Queue(uart3_rx_sq,usart485RX_Buffer,len,len);//数据入队,可多次调用
  105. // fifo_write(&g_rxfifo,usart485RX_Buffer,len);
  106. dma_memory_address_config(RS485_DMAx, RS485_DMA_CH_RX,(uint32_t)usart485RX_Buffer);
  107. dma_transfer_number_config(RS485_DMAx, RS485_DMA_CH_RX, USART3_RX_SIZE);/* reset DMA_Channel CNT */
  108. dma_channel_enable(RS485_DMAx, RS485_DMA_CH_RX);/* enable USART1_RX DMA_Channel */
  109. // g_uart485.bRcv = 1;
  110. }
  111. else if(RESET != usart_interrupt_flag_get(RS485_USARTx,USART_INT_FLAG_TC)) { // 发送完成中断
  112. usart_interrupt_flag_clear(RS485_USARTx, USART_INT_FLAG_TC);//
  113. usart_flag_clear(RS485_USARTx, USART_FLAG_TC);
  114. // g_uart485.bSdFinish = 1;
  115. // gpio_bit_reset(GPIOC, GPIO_PIN_12);
  116. RS485_RX();
  117. }
  118. }
  119. void RS485_DMA0_CH_TX_IRQHandler(void)//usart1 发送dma
  120. {
  121. if(dma_interrupt_flag_get(RS485_DMAx, RS485_DMA_CH_TX, DMA_INT_FLAG_FTF)){
  122. dma_interrupt_flag_clear(RS485_DMAx, RS485_DMA_CH_TX, DMA_INT_FLAG_G);
  123. //g_uart485.bSdFinish = 1;
  124. //gpio_bit_reset(GPIOC, GPIO_PIN_12);
  125. usart_interrupt_enable(RS485_USARTx, USART_INT_TC); // 使能接收完成中断
  126. }
  127. }
  128. void USART1_IRQHandler(void)
  129. {
  130. RS485_USART_IRQHandler();
  131. }
  132. void DMA0_Channel6_IRQHandler(void)
  133. {
  134. RS485_DMA0_CH_TX_IRQHandler();
  135. }
  136. uint8_t usart485TX_Buffer[USART3_TX_SIZE] = {0x01,0x02,0x03,0x04,0x05,0x06,0x07,0x08};
  137. uint8_t usart485RX_Buffer[USART3_RX_SIZE] = {0};
  138. //uart485Info_t g_uart485;
  139. void dam_init_uart_485(void)
  140. {
  141. dma_parameter_struct dma_init_Usart3_TX;
  142. dma_parameter_struct dma_init_Usart3_RX;
  143. rcu_periph_clock_enable(RS485_DMA_RCU);
  144. dma_deinit(RS485_DMAx, RS485_DMA_CH_RX); // RX
  145. dma_deinit(RS485_DMAx, RS485_DMA_CH_TX); // TX
  146. /* initialize DMA1 channel4(Uart3_TX) */
  147. dma_init_Usart3_TX.direction = DMA_MEMORY_TO_PERIPHERAL;
  148. dma_init_Usart3_TX.memory_addr = (uint32_t)usart485TX_Buffer;
  149. dma_init_Usart3_TX.memory_inc = DMA_MEMORY_INCREASE_ENABLE;
  150. dma_init_Usart3_TX.memory_width = DMA_MEMORY_WIDTH_8BIT;
  151. dma_init_Usart3_TX.number = (uint32_t)USART3_TX_SIZE;
  152. dma_init_Usart3_TX.periph_addr = (uint32_t)(&USART_DATA(RS485_USARTx));
  153. dma_init_Usart3_TX.periph_inc = DMA_PERIPH_INCREASE_DISABLE;
  154. dma_init_Usart3_TX.periph_width = DMA_PERIPHERAL_WIDTH_8BIT;
  155. dma_init_Usart3_TX.priority = DMA_PRIORITY_LOW;
  156. dma_init(RS485_DMAx, RS485_DMA_CH_TX, &dma_init_Usart3_TX);
  157. dma_circulation_disable(RS485_DMAx, RS485_DMA_CH_TX);
  158. /* initialize DMA1 channel2(Uart3_RX) */
  159. dma_init_Usart3_RX.direction = DMA_PERIPHERAL_TO_MEMORY;
  160. dma_init_Usart3_RX.memory_addr = (uint32_t)usart485RX_Buffer;
  161. dma_init_Usart3_RX.memory_inc = DMA_MEMORY_INCREASE_ENABLE;
  162. dma_init_Usart3_RX.memory_width = DMA_MEMORY_WIDTH_8BIT;
  163. dma_init_Usart3_RX.number = (uint32_t)USART3_RX_SIZE;
  164. dma_init_Usart3_RX.periph_addr = (uint32_t)(&USART_DATA(RS485_USARTx));
  165. dma_init_Usart3_RX.periph_inc = DMA_PERIPH_INCREASE_DISABLE;
  166. dma_init_Usart3_RX.periph_width = DMA_PERIPHERAL_WIDTH_8BIT;
  167. dma_init_Usart3_RX.priority = DMA_PRIORITY_LOW;
  168. dma_init(RS485_DMAx, RS485_DMA_CH_RX, &dma_init_Usart3_RX);
  169. dma_circulation_disable(RS485_DMAx, RS485_DMA_CH_RX);//circulate or not makes no difference
  170. dma_memory_to_memory_disable(RS485_DMAx,RS485_DMA_CH_RX);
  171. dma_memory_to_memory_disable(RS485_DMAx,RS485_DMA_CH_TX);
  172. /* enable all DMA channels you need */
  173. dma_channel_enable(RS485_DMAx,RS485_DMA_CH_RX);
  174. dma_channel_disable(RS485_DMAx,RS485_DMA_CH_TX);
  175. }
  176. /*------------------------------------------------------------------------------------
  177. * 485初始化 UART3
  178. * -----------------------------------------------------------------------------------*/
  179. void usart_485_dma_init(void)
  180. {
  181. rcu_periph_clock_enable(RS485_GPIO_RCU);/* enable GPIO clock */
  182. rcu_periph_clock_enable(RCU_AF);
  183. rcu_periph_clock_enable(RS483_USART_RCU);/* enable USART clock */
  184. gpio_init(RS485_GPIOx, GPIO_MODE_AF_PP, GPIO_OSPEED_50MHZ, RS485_GPIO_PIN_TX);/* connect port to USARTx_Tx */
  185. gpio_init(RS485_GPIOx, GPIO_MODE_IN_FLOATING, GPIO_OSPEED_50MHZ, RS485_GPIO_PIN_RX);/* connect port to USARTx_Rx */
  186. //设置rs485芯片,收发模式控制引脚 PC12,低电平接收,高电平发送,初始化为接收模式
  187. gpio_init(RS485_GPIOx, GPIO_MODE_OUT_PP, GPIO_OSPEED_50MHZ, RS485_GPIO_PIN_CTL);
  188. // gpio_bit_reset(GPIOC, GPIO_PIN_12);
  189. RS485_RX();
  190. /* USART configure */
  191. usart_deinit(RS485_USARTx);
  192. usart_word_length_set(RS485_USARTx, USART_WL_8BIT);
  193. usart_stop_bit_set(RS485_USARTx, USART_STB_1BIT);
  194. usart_parity_config(RS485_USARTx, USART_PM_NONE);
  195. usart_baudrate_set(RS485_USARTx, 115200U);
  196. usart_hardware_flow_rts_config(RS485_USARTx, USART_RTS_DISABLE);
  197. usart_hardware_flow_cts_config(RS485_USARTx, USART_CTS_DISABLE);
  198. usart_receive_config(RS485_USARTx, USART_RECEIVE_ENABLE);
  199. usart_transmit_config(RS485_USARTx, USART_TRANSMIT_ENABLE);
  200. usart_enable(RS485_USARTx);
  201. /* config USARTx_TX transmit by DMA */
  202. usart_dma_transmit_config(RS485_USARTx,USART_DENT_ENABLE);
  203. usart_dma_receive_config(RS485_USARTx,USART_DENR_ENABLE);
  204. /* UART3 IRQ set */
  205. nvic_irq_enable(RS485_USART_IRQ, 4, 0);
  206. usart_interrupt_enable(RS485_USARTx, USART_INT_FLAG_IDLE);
  207. dma_interrupt_enable(RS485_DMAx,RS485_DMA_CH_TX,DMA_INT_FTF); /* 使能DAM发送完成中断 */
  208. dma_channel_enable(RS485_DMAx, RS485_DMA_CH_TX);
  209. nvic_irq_enable(RS485_DMA_TX_IRQ, 4, 1);
  210. }
  211. void usart_tx_dma_send(uint32_t usart_periph,uint8_t* data_buffer,uint16_t length)
  212. {
  213. volatile uint32_t i = 0;
  214. if(usart_periph==USART0)
  215. {
  216. /* Channel disable */
  217. dma_channel_disable(DMA0, DMA_CH3);
  218. dma_memory_address_config(DMA0, DMA_CH3,(uint32_t)data_buffer);
  219. dma_transfer_number_config(DMA0,DMA_CH3,length);
  220. /* enable DMA channel to start send */
  221. dma_channel_enable(DMA0, DMA_CH3);
  222. }
  223. else if(usart_periph==RS485_USARTx)
  224. {
  225. /* Channel disable */
  226. // gpio_bit_set(GPIOC, GPIO_PIN_12);
  227. RS485_TX();
  228. dma_interrupt_flag_clear(RS485_DMAx, RS485_DMA_CH_TX, DMA_INT_FLAG_FTF);
  229. usart_interrupt_flag_clear(RS485_USARTx,USART_INT_FLAG_TC);
  230. usart_flag_clear(RS485_USARTx,USART_FLAG_TC);
  231. for(i=0;i<0xFF;i++);
  232. // if(dma_flag_get(DMA1,DMA_FLAG_FTF)!=RESET){
  233. // }
  234. dma_channel_disable(RS485_DMAx, RS485_DMA_CH_TX);
  235. dma_memory_address_config(RS485_DMAx, RS485_DMA_CH_TX,(uint32_t)data_buffer);
  236. dma_transfer_number_config(RS485_DMAx,RS485_DMA_CH_TX,length);
  237. /* enable DMA channel to start send */
  238. dma_channel_enable(RS485_DMAx, RS485_DMA_CH_TX);
  239. usart_dma_transmit_config(RS485_USARTx,USART_DENT_ENABLE);
  240. }
  241. }
  242. int fputc(int ch, FILE *f)
  243. {
  244. if(g_ptTest.bTestStart==PT_OFF)
  245. {
  246. usart_data_transmit(USART0, (uint8_t)ch);
  247. while(RESET == usart_flag_get(USART0, USART_FLAG_TC));
  248. }
  249. return ch;
  250. }
  251. void data_dump(const char *name, uint8_t *data, uint16_t length)
  252. {
  253. int index = 0;
  254. printf("%s Data Info: \r\n ", name);
  255. for(index = 0;index < length;index++) {
  256. if((index%4 == 0)&&index) {
  257. if((index%16 == 0)&&index) {
  258. printf("\r\n ");
  259. } else {
  260. printf(" ");
  261. }
  262. }
  263. printf("%02x ", *(data + index));
  264. }
  265. printf("\r\n");
  266. }
  267. ////////////////////////////////////////////////////////////////////////////