usart.c 10.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377
  1. /* USER CODE BEGIN Header */
  2. /**
  3. ******************************************************************************
  4. * @file usart.c
  5. * @brief This file provides code for the configuration
  6. * of the USART instances.
  7. ******************************************************************************
  8. * @attention
  9. *
  10. * Copyright (c) 2023 STMicroelectronics.
  11. * All rights reserved.
  12. *
  13. * This software is licensed under terms that can be found in the LICENSE file
  14. * in the root directory of this software component.
  15. * If no LICENSE file comes with this software, it is provided AS-IS.
  16. *
  17. ******************************************************************************
  18. */
  19. /* USER CODE END Header */
  20. /* Includes ------------------------------------------------------------------*/
  21. #include "usart.h"
  22. /* USER CODE BEGIN 0 */
  23. uint8_t USART_IAP_RX[RX_BUF_SIZE];
  24. uint8_t USART_PUB_RX[RX_BUF_SIZE];
  25. uint8_t USART_MODBUS_RX[RX_BUF_SIZE];
  26. uint8_t USART_IAP_FLAG = 0;
  27. uint8_t USART_MODBUS_FLAG = 0;
  28. uint16_t USART_PUB_LENGTH = 0;
  29. uint16_t package_num = 0;
  30. uint16_t app_Cache_buf[ARRAY_SIZE] = {0};
  31. uint8_t destArray[128];
  32. int nameIndex = -1;
  33. int sizeIndex = -1;
  34. int count = 0; // 用于统计0x00出现的次数
  35. uint8_t nameArray[16] = {0};
  36. uint16_t sizeArray[1] = {0};
  37. uint8_t md5Array[16] = {0};
  38. uint8_t VERArray[10] = {0};
  39. uint16_t curpackage=0;
  40. uint32_t curaddress=0;
  41. /* USER CODE END 0 */
  42. UART_HandleTypeDef huart1;
  43. UART_HandleTypeDef huart3;
  44. DMA_HandleTypeDef hdma_usart1_rx;
  45. DMA_HandleTypeDef hdma_usart1_tx;
  46. DMA_HandleTypeDef hdma_usart3_rx;
  47. /* USART1 init function */
  48. void MX_USART1_UART_Init(void)
  49. {
  50. /* USER CODE BEGIN USART1_Init 0 */
  51. /* USER CODE END USART1_Init 0 */
  52. /* USER CODE BEGIN USART1_Init 1 */
  53. /* USER CODE END USART1_Init 1 */
  54. huart1.Instance = USART1;
  55. huart1.Init.BaudRate = 9600;
  56. huart1.Init.WordLength = UART_WORDLENGTH_8B;
  57. huart1.Init.StopBits = UART_STOPBITS_1;
  58. huart1.Init.Parity = UART_PARITY_NONE;
  59. huart1.Init.Mode = UART_MODE_TX_RX;
  60. huart1.Init.HwFlowCtl = UART_HWCONTROL_NONE;
  61. huart1.Init.OverSampling = UART_OVERSAMPLING_16;
  62. if (HAL_UART_Init(&huart1) != HAL_OK)
  63. {
  64. Error_Handler();
  65. }
  66. /* USER CODE BEGIN USART1_Init 2 */
  67. /* USER CODE END USART1_Init 2 */
  68. }
  69. /* USART3 init function */
  70. void MX_USART3_UART_Init(void)
  71. {
  72. /* USER CODE BEGIN USART3_Init 0 */
  73. /* USER CODE END USART3_Init 0 */
  74. /* USER CODE BEGIN USART3_Init 1 */
  75. /* USER CODE END USART3_Init 1 */
  76. huart3.Instance = USART3;
  77. huart3.Init.BaudRate = 9600;
  78. huart3.Init.WordLength = UART_WORDLENGTH_8B;
  79. huart3.Init.StopBits = UART_STOPBITS_1;
  80. huart3.Init.Parity = UART_PARITY_NONE;
  81. huart3.Init.Mode = UART_MODE_TX_RX;
  82. huart3.Init.HwFlowCtl = UART_HWCONTROL_NONE;
  83. huart3.Init.OverSampling = UART_OVERSAMPLING_16;
  84. if (HAL_UART_Init(&huart3) != HAL_OK)
  85. {
  86. Error_Handler();
  87. }
  88. /* USER CODE BEGIN USART3_Init 2 */
  89. /* USER CODE END USART3_Init 2 */
  90. }
  91. void HAL_UART_MspInit(UART_HandleTypeDef* uartHandle)
  92. {
  93. GPIO_InitTypeDef GPIO_InitStruct = {0};
  94. if(uartHandle->Instance==USART1)
  95. {
  96. /* USER CODE BEGIN USART1_MspInit 0 */
  97. /* USER CODE END USART1_MspInit 0 */
  98. /* USART1 clock enable */
  99. __HAL_RCC_USART1_CLK_ENABLE();
  100. __HAL_RCC_GPIOA_CLK_ENABLE();
  101. /**USART1 GPIO Configuration
  102. PA9 ------> USART1_TX
  103. PA10 ------> USART1_RX
  104. */
  105. GPIO_InitStruct.Pin = GPIO_PIN_9;
  106. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  107. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
  108. HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
  109. GPIO_InitStruct.Pin = GPIO_PIN_10;
  110. GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
  111. GPIO_InitStruct.Pull = GPIO_NOPULL;
  112. HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
  113. /* USART1 DMA Init */
  114. /* USART1_RX Init */
  115. hdma_usart1_rx.Instance = DMA1_Channel5;
  116. hdma_usart1_rx.Init.Direction = DMA_PERIPH_TO_MEMORY;
  117. hdma_usart1_rx.Init.PeriphInc = DMA_PINC_DISABLE;
  118. hdma_usart1_rx.Init.MemInc = DMA_MINC_ENABLE;
  119. hdma_usart1_rx.Init.PeriphDataAlignment = DMA_PDATAALIGN_BYTE;
  120. hdma_usart1_rx.Init.MemDataAlignment = DMA_MDATAALIGN_BYTE;
  121. hdma_usart1_rx.Init.Mode = DMA_NORMAL;
  122. hdma_usart1_rx.Init.Priority = DMA_PRIORITY_LOW;
  123. if (HAL_DMA_Init(&hdma_usart1_rx) != HAL_OK)
  124. {
  125. Error_Handler();
  126. }
  127. __HAL_LINKDMA(uartHandle,hdmarx,hdma_usart1_rx);
  128. /* USART1_TX Init */
  129. hdma_usart1_tx.Instance = DMA1_Channel4;
  130. hdma_usart1_tx.Init.Direction = DMA_MEMORY_TO_PERIPH;
  131. hdma_usart1_tx.Init.PeriphInc = DMA_PINC_DISABLE;
  132. hdma_usart1_tx.Init.MemInc = DMA_MINC_ENABLE;
  133. hdma_usart1_tx.Init.PeriphDataAlignment = DMA_PDATAALIGN_BYTE;
  134. hdma_usart1_tx.Init.MemDataAlignment = DMA_MDATAALIGN_BYTE;
  135. hdma_usart1_tx.Init.Mode = DMA_NORMAL;
  136. hdma_usart1_tx.Init.Priority = DMA_PRIORITY_LOW;
  137. if (HAL_DMA_Init(&hdma_usart1_tx) != HAL_OK)
  138. {
  139. Error_Handler();
  140. }
  141. __HAL_LINKDMA(uartHandle,hdmatx,hdma_usart1_tx);
  142. /* USART1 interrupt Init */
  143. HAL_NVIC_SetPriority(USART1_IRQn, 5, 0);
  144. HAL_NVIC_EnableIRQ(USART1_IRQn);
  145. /* USER CODE BEGIN USART1_MspInit 1 */
  146. /* USER CODE END USART1_MspInit 1 */
  147. }
  148. else if(uartHandle->Instance==USART3)
  149. {
  150. /* USER CODE BEGIN USART3_MspInit 0 */
  151. /* USER CODE END USART3_MspInit 0 */
  152. /* USART3 clock enable */
  153. __HAL_RCC_USART3_CLK_ENABLE();
  154. __HAL_RCC_GPIOB_CLK_ENABLE();
  155. /**USART3 GPIO Configuration
  156. PB10 ------> USART3_TX
  157. PB11 ------> USART3_RX
  158. */
  159. GPIO_InitStruct.Pin = GPIO_PIN_10;
  160. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  161. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
  162. HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
  163. GPIO_InitStruct.Pin = GPIO_PIN_11;
  164. GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
  165. GPIO_InitStruct.Pull = GPIO_NOPULL;
  166. HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
  167. /* USART3 DMA Init */
  168. /* USART3_RX Init */
  169. hdma_usart3_rx.Instance = DMA1_Channel3;
  170. hdma_usart3_rx.Init.Direction = DMA_PERIPH_TO_MEMORY;
  171. hdma_usart3_rx.Init.PeriphInc = DMA_PINC_DISABLE;
  172. hdma_usart3_rx.Init.MemInc = DMA_MINC_ENABLE;
  173. hdma_usart3_rx.Init.PeriphDataAlignment = DMA_PDATAALIGN_BYTE;
  174. hdma_usart3_rx.Init.MemDataAlignment = DMA_MDATAALIGN_BYTE;
  175. hdma_usart3_rx.Init.Mode = DMA_NORMAL;
  176. hdma_usart3_rx.Init.Priority = DMA_PRIORITY_LOW;
  177. if (HAL_DMA_Init(&hdma_usart3_rx) != HAL_OK)
  178. {
  179. Error_Handler();
  180. }
  181. __HAL_LINKDMA(uartHandle,hdmarx,hdma_usart3_rx);
  182. /* USART3 interrupt Init */
  183. HAL_NVIC_SetPriority(USART3_IRQn, 5, 0);
  184. HAL_NVIC_EnableIRQ(USART3_IRQn);
  185. /* USER CODE BEGIN USART3_MspInit 1 */
  186. /* USER CODE END USART3_MspInit 1 */
  187. }
  188. }
  189. void HAL_UART_MspDeInit(UART_HandleTypeDef* uartHandle)
  190. {
  191. if(uartHandle->Instance==USART1)
  192. {
  193. /* USER CODE BEGIN USART1_MspDeInit 0 */
  194. /* USER CODE END USART1_MspDeInit 0 */
  195. /* Peripheral clock disable */
  196. __HAL_RCC_USART1_CLK_DISABLE();
  197. /**USART1 GPIO Configuration
  198. PA9 ------> USART1_TX
  199. PA10 ------> USART1_RX
  200. */
  201. HAL_GPIO_DeInit(GPIOA, GPIO_PIN_9|GPIO_PIN_10);
  202. /* USART1 DMA DeInit */
  203. HAL_DMA_DeInit(uartHandle->hdmarx);
  204. HAL_DMA_DeInit(uartHandle->hdmatx);
  205. /* USART1 interrupt Deinit */
  206. HAL_NVIC_DisableIRQ(USART1_IRQn);
  207. /* USER CODE BEGIN USART1_MspDeInit 1 */
  208. /* USER CODE END USART1_MspDeInit 1 */
  209. }
  210. else if(uartHandle->Instance==USART3)
  211. {
  212. /* USER CODE BEGIN USART3_MspDeInit 0 */
  213. /* USER CODE END USART3_MspDeInit 0 */
  214. /* Peripheral clock disable */
  215. __HAL_RCC_USART3_CLK_DISABLE();
  216. /**USART3 GPIO Configuration
  217. PB10 ------> USART3_TX
  218. PB11 ------> USART3_RX
  219. */
  220. HAL_GPIO_DeInit(GPIOB, GPIO_PIN_10|GPIO_PIN_11);
  221. /* USART3 DMA DeInit */
  222. HAL_DMA_DeInit(uartHandle->hdmarx);
  223. /* USART3 interrupt Deinit */
  224. HAL_NVIC_DisableIRQ(USART3_IRQn);
  225. /* USER CODE BEGIN USART3_MspDeInit 1 */
  226. /* USER CODE END USART3_MspDeInit 1 */
  227. }
  228. }
  229. /* USER CODE BEGIN 1 */
  230. void change_baudrate(uint32_t baudrate){
  231. __HAL_UART_DISABLE(&huart1); // 关闭UART
  232. huart1.Init.BaudRate = baudrate; // 更改波特率
  233. if(HAL_UART_Init(&huart1) != HAL_OK){
  234. Error_Handler();
  235. }
  236. __HAL_UART_ENABLE(&huart1); // 重新打开UART
  237. }
  238. uint32_t baudrate_list[] = {1200, 2400, 4800, 9600, 19200, 38400, 57600, 115200};
  239. void update_baudrate(uint16_t temp) {
  240. if(temp <= 7) {
  241. change_baudrate(baudrate_list[temp]);
  242. }
  243. if(temp == 0xFFFF || temp == 0x0003) {
  244. change_baudrate(9600);
  245. }
  246. }
  247. void HAL_UART_TxCpltCallback(UART_HandleTypeDef *huart)
  248. {
  249. __HAL_UART_CLEAR_FLAG(huart, UART_FLAG_RXNE); // 清除接收中断标志位
  250. __HAL_UART_CLEAR_FLAG(huart, UART_FLAG_ORE); // 清除接收溢出标志位
  251. }
  252. void HAL_UART_RxCpltCallback(UART_HandleTypeDef *huart)
  253. {
  254. __HAL_UART_CLEAR_FLAG(huart, UART_FLAG_RXNE); // 清除接收中断标志位
  255. __HAL_UART_CLEAR_FLAG(huart, UART_FLAG_ORE); // 清除接收溢出标志位
  256. }
  257. void update_sysVersion(uint32_t addr)
  258. {
  259. Flash_ReadBytes(version, StartMode_Addr + 14, 8);
  260. for (int i = 0; i < 4; i++) {
  261. version[i] = ((version[i] >> 8) & 0xFF) | ((version[i] << 8) & 0xFF00);
  262. }
  263. uint32_t ver;
  264. convertHexToAscii(version, &ver);
  265. if(ver == 0xFFFFFFFF)
  266. {
  267. return;
  268. }else{
  269. System_version = ver;
  270. }
  271. }
  272. void update_iaplength(uint32_t addr)
  273. {
  274. Flash_ReadBytes(sizeArray, addr, 2);
  275. for (int i = 0; i < 1; i++) {
  276. sizeArray[i] = ((sizeArray[i] >> 8) & 0xFF) | ((sizeArray[i] << 8) & 0xFF00);
  277. }
  278. if(sizeArray[0] == 0xFFFF)
  279. {
  280. FileLength_IAP = 0;
  281. }else{
  282. FileLength_IAP = ((sizeArray[0] >> 8) & 0xFF) | ((sizeArray[0] << 8) & 0xFF00);
  283. }
  284. }
  285. void updateiapMd5(uint32_t addr)
  286. {
  287. Flash_ReadBytes(iapbinMd5, MD5_ADDR, 16);
  288. for (int i = 0; i < 8; i++) {
  289. iapbinMd5[i] = ((iapbinMd5[i] >> 8) & 0xFF) | ((iapbinMd5[i] << 8) & 0xFF00);
  290. }
  291. }
  292. void updatecuraddr(uint32_t addr)
  293. {
  294. Flash_ReadBytes(&curaddr[0], addr, 4);
  295. nowcurAddr1 = ((uint32_t)curaddr[0] << 16) | curaddr[1];
  296. }
  297. void updatecurpack(uint32_t addr)
  298. {
  299. Flash_ReadBytes(&curapack[0], addr+4, 2);
  300. nowcurpack = curapack[0];
  301. }
  302. int compareArrays(uint16_t arr1[], uint16_t arr2[], int size) {
  303. for (int i = 0; i < size; i++) {
  304. if (arr1[i] != arr2[i]) {
  305. return 0; // 数组不一致,返回0
  306. }
  307. }
  308. return 1; // 数组一致,返回1
  309. }
  310. /* USER CODE END 1 */