usart.c 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862
  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) 2024 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. #include "dtuaes.h"
  24. uint8_t U1_485reFlag = 0;
  25. uint8_t U1_485recvBuff[BUFFER_SIZE];
  26. uint8_t U1_485recvLength = 0; //接收一帧数据的长度
  27. uint8_t U4_4GreFlag = 0;
  28. uint8_t U4_4GrecvBuff[BUFFER_SIZE];
  29. uint8_t U4_4GrecvLength = 0; //接收一帧数据的长度
  30. uint8_t U5_BTreFlag = 0;
  31. uint8_t U5_BTrecvBuff[BUFFER_SIZE];
  32. uint8_t U5_BTrecvBuff1[BUFFER_SIZE];
  33. uint8_t U5_BTrecvLength = 0; //接收一帧数据的长度
  34. uint8_t DtuBtKey[16] = {0x4A, 0x49, 0x41, 0x4C, 0x4F, 0x4E, 0x47, 0x5F, 0x32, 0x40, 0x38, 0x21, 0x35, 0x23, 0x39, 0x32};//JIALONG_2@8!5#92
  35. uint8_t iv[16] = {0x31, 0x31, 0x31, 0x31, 0x31, 0x31, 0x31, 0x31, 0x31, 0x31, 0x31, 0x31, 0x31, 0x31, 0x31, 0x31};//偏移
  36. /* USER CODE END 0 */
  37. UART_HandleTypeDef huart4;
  38. UART_HandleTypeDef huart5;
  39. UART_HandleTypeDef huart1;
  40. UART_HandleTypeDef huart2;
  41. UART_HandleTypeDef huart3;
  42. DMA_HandleTypeDef hdma_uart4_rx;
  43. DMA_HandleTypeDef hdma_uart4_tx;
  44. DMA_HandleTypeDef hdma_usart1_rx;
  45. DMA_HandleTypeDef hdma_usart1_tx;
  46. DMA_HandleTypeDef hdma_usart2_rx;
  47. DMA_HandleTypeDef hdma_usart2_tx;
  48. DMA_HandleTypeDef hdma_usart3_rx;
  49. DMA_HandleTypeDef hdma_usart3_tx;
  50. /* UART4 init function */
  51. void MX_UART4_Init(void)
  52. {
  53. /* USER CODE BEGIN UART4_Init 0 */
  54. /* USER CODE END UART4_Init 0 */
  55. /* USER CODE BEGIN UART4_Init 1 */
  56. /* USER CODE END UART4_Init 1 */
  57. huart4.Instance = UART4;
  58. huart4.Init.BaudRate = 115200;
  59. huart4.Init.WordLength = UART_WORDLENGTH_8B;
  60. huart4.Init.StopBits = UART_STOPBITS_1;
  61. huart4.Init.Parity = UART_PARITY_NONE;
  62. huart4.Init.Mode = UART_MODE_TX_RX;
  63. huart4.Init.HwFlowCtl = UART_HWCONTROL_NONE;
  64. huart4.Init.OverSampling = UART_OVERSAMPLING_16;
  65. if (HAL_UART_Init(&huart4) != HAL_OK)
  66. {
  67. Error_Handler();
  68. }
  69. /* USER CODE BEGIN UART4_Init 2 */
  70. /* USER CODE END UART4_Init 2 */
  71. }
  72. /* UART5 init function */
  73. void MX_UART5_Init(void)
  74. {
  75. /* USER CODE BEGIN UART5_Init 0 */
  76. /* USER CODE END UART5_Init 0 */
  77. /* USER CODE BEGIN UART5_Init 1 */
  78. /* USER CODE END UART5_Init 1 */
  79. huart5.Instance = UART5;
  80. huart5.Init.BaudRate = 115200;
  81. huart5.Init.WordLength = UART_WORDLENGTH_8B;
  82. huart5.Init.StopBits = UART_STOPBITS_1;
  83. huart5.Init.Parity = UART_PARITY_NONE;
  84. huart5.Init.Mode = UART_MODE_TX_RX;
  85. huart5.Init.HwFlowCtl = UART_HWCONTROL_NONE;
  86. huart5.Init.OverSampling = UART_OVERSAMPLING_16;
  87. if (HAL_UART_Init(&huart5) != HAL_OK)
  88. {
  89. Error_Handler();
  90. }
  91. /* USER CODE BEGIN UART5_Init 2 */
  92. /* USER CODE END UART5_Init 2 */
  93. }
  94. /* USART1 init function */
  95. void MX_USART1_UART_Init(void)
  96. {
  97. /* USER CODE BEGIN USART1_Init 0 */
  98. /* USER CODE END USART1_Init 0 */
  99. /* USER CODE BEGIN USART1_Init 1 */
  100. /* USER CODE END USART1_Init 1 */
  101. huart1.Instance = USART1;
  102. huart1.Init.BaudRate = 115200;
  103. huart1.Init.WordLength = UART_WORDLENGTH_8B;
  104. huart1.Init.StopBits = UART_STOPBITS_1;
  105. huart1.Init.Parity = UART_PARITY_NONE;
  106. huart1.Init.Mode = UART_MODE_TX_RX;
  107. huart1.Init.HwFlowCtl = UART_HWCONTROL_NONE;
  108. huart1.Init.OverSampling = UART_OVERSAMPLING_16;
  109. if (HAL_UART_Init(&huart1) != HAL_OK)
  110. {
  111. Error_Handler();
  112. }
  113. /* USER CODE BEGIN USART1_Init 2 */
  114. /* USER CODE END USART1_Init 2 */
  115. }
  116. /* USART2 init function */
  117. void MX_USART2_UART_Init(void)
  118. {
  119. /* USER CODE BEGIN USART2_Init 0 */
  120. /* USER CODE END USART2_Init 0 */
  121. /* USER CODE BEGIN USART2_Init 1 */
  122. /* USER CODE END USART2_Init 1 */
  123. huart2.Instance = USART2;
  124. huart2.Init.BaudRate = 115200;
  125. huart2.Init.WordLength = UART_WORDLENGTH_8B;
  126. huart2.Init.StopBits = UART_STOPBITS_1;
  127. huart2.Init.Parity = UART_PARITY_NONE;
  128. huart2.Init.Mode = UART_MODE_TX_RX;
  129. huart2.Init.HwFlowCtl = UART_HWCONTROL_NONE;
  130. huart2.Init.OverSampling = UART_OVERSAMPLING_16;
  131. if (HAL_UART_Init(&huart2) != HAL_OK)
  132. {
  133. Error_Handler();
  134. }
  135. /* USER CODE BEGIN USART2_Init 2 */
  136. /* USER CODE END USART2_Init 2 */
  137. }
  138. /* USART3 init function */
  139. void MX_USART3_UART_Init(void)
  140. {
  141. /* USER CODE BEGIN USART3_Init 0 */
  142. /* USER CODE END USART3_Init 0 */
  143. /* USER CODE BEGIN USART3_Init 1 */
  144. /* USER CODE END USART3_Init 1 */
  145. huart3.Instance = USART3;
  146. huart3.Init.BaudRate = 115200;
  147. huart3.Init.WordLength = UART_WORDLENGTH_8B;
  148. huart3.Init.StopBits = UART_STOPBITS_1;
  149. huart3.Init.Parity = UART_PARITY_NONE;
  150. huart3.Init.Mode = UART_MODE_TX_RX;
  151. huart3.Init.HwFlowCtl = UART_HWCONTROL_NONE;
  152. huart3.Init.OverSampling = UART_OVERSAMPLING_16;
  153. if (HAL_UART_Init(&huart3) != HAL_OK)
  154. {
  155. Error_Handler();
  156. }
  157. /* USER CODE BEGIN USART3_Init 2 */
  158. /* USER CODE END USART3_Init 2 */
  159. }
  160. void HAL_UART_MspInit(UART_HandleTypeDef* uartHandle)
  161. {
  162. GPIO_InitTypeDef GPIO_InitStruct = {0};
  163. if(uartHandle->Instance==UART4)
  164. {
  165. /* USER CODE BEGIN UART4_MspInit 0 */
  166. /* USER CODE END UART4_MspInit 0 */
  167. /* UART4 clock enable */
  168. __HAL_RCC_UART4_CLK_ENABLE();
  169. __HAL_RCC_GPIOC_CLK_ENABLE();
  170. /**UART4 GPIO Configuration
  171. PC10 ------> UART4_TX
  172. PC11 ------> UART4_RX
  173. */
  174. GPIO_InitStruct.Pin = GPIO_PIN_10;
  175. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  176. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
  177. HAL_GPIO_Init(GPIOC, &GPIO_InitStruct);
  178. GPIO_InitStruct.Pin = GPIO_PIN_11;
  179. GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
  180. GPIO_InitStruct.Pull = GPIO_NOPULL;
  181. HAL_GPIO_Init(GPIOC, &GPIO_InitStruct);
  182. /* UART4 DMA Init */
  183. /* UART4_RX Init */
  184. hdma_uart4_rx.Instance = DMA2_Channel3;
  185. hdma_uart4_rx.Init.Direction = DMA_PERIPH_TO_MEMORY;
  186. hdma_uart4_rx.Init.PeriphInc = DMA_PINC_DISABLE;
  187. hdma_uart4_rx.Init.MemInc = DMA_MINC_ENABLE;
  188. hdma_uart4_rx.Init.PeriphDataAlignment = DMA_PDATAALIGN_BYTE;
  189. hdma_uart4_rx.Init.MemDataAlignment = DMA_MDATAALIGN_BYTE;
  190. hdma_uart4_rx.Init.Mode = DMA_NORMAL;
  191. hdma_uart4_rx.Init.Priority = DMA_PRIORITY_LOW;
  192. if (HAL_DMA_Init(&hdma_uart4_rx) != HAL_OK)
  193. {
  194. Error_Handler();
  195. }
  196. __HAL_LINKDMA(uartHandle,hdmarx,hdma_uart4_rx);
  197. /* UART4_TX Init */
  198. hdma_uart4_tx.Instance = DMA2_Channel5;
  199. hdma_uart4_tx.Init.Direction = DMA_MEMORY_TO_PERIPH;
  200. hdma_uart4_tx.Init.PeriphInc = DMA_PINC_DISABLE;
  201. hdma_uart4_tx.Init.MemInc = DMA_MINC_ENABLE;
  202. hdma_uart4_tx.Init.PeriphDataAlignment = DMA_PDATAALIGN_BYTE;
  203. hdma_uart4_tx.Init.MemDataAlignment = DMA_MDATAALIGN_BYTE;
  204. hdma_uart4_tx.Init.Mode = DMA_NORMAL;
  205. hdma_uart4_tx.Init.Priority = DMA_PRIORITY_LOW;
  206. if (HAL_DMA_Init(&hdma_uart4_tx) != HAL_OK)
  207. {
  208. Error_Handler();
  209. }
  210. __HAL_LINKDMA(uartHandle,hdmatx,hdma_uart4_tx);
  211. /* UART4 interrupt Init */
  212. HAL_NVIC_SetPriority(UART4_IRQn, 5, 0);
  213. HAL_NVIC_EnableIRQ(UART4_IRQn);
  214. /* USER CODE BEGIN UART4_MspInit 1 */
  215. /* USER CODE END UART4_MspInit 1 */
  216. }
  217. else if(uartHandle->Instance==UART5)
  218. {
  219. /* USER CODE BEGIN UART5_MspInit 0 */
  220. /* USER CODE END UART5_MspInit 0 */
  221. /* UART5 clock enable */
  222. __HAL_RCC_UART5_CLK_ENABLE();
  223. __HAL_RCC_GPIOC_CLK_ENABLE();
  224. __HAL_RCC_GPIOD_CLK_ENABLE();
  225. /**UART5 GPIO Configuration
  226. PC12 ------> UART5_TX
  227. PD2 ------> UART5_RX
  228. */
  229. GPIO_InitStruct.Pin = GPIO_PIN_12;
  230. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  231. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
  232. HAL_GPIO_Init(GPIOC, &GPIO_InitStruct);
  233. GPIO_InitStruct.Pin = GPIO_PIN_2;
  234. GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
  235. GPIO_InitStruct.Pull = GPIO_NOPULL;
  236. HAL_GPIO_Init(GPIOD, &GPIO_InitStruct);
  237. /* UART5 interrupt Init */
  238. HAL_NVIC_SetPriority(UART5_IRQn, 5, 0);
  239. HAL_NVIC_EnableIRQ(UART5_IRQn);
  240. /* USER CODE BEGIN UART5_MspInit 1 */
  241. /* USER CODE END UART5_MspInit 1 */
  242. }
  243. else if(uartHandle->Instance==USART1)
  244. {
  245. /* USER CODE BEGIN USART1_MspInit 0 */
  246. /* USER CODE END USART1_MspInit 0 */
  247. /* USART1 clock enable */
  248. __HAL_RCC_USART1_CLK_ENABLE();
  249. __HAL_RCC_GPIOA_CLK_ENABLE();
  250. /**USART1 GPIO Configuration
  251. PA9 ------> USART1_TX
  252. PA10 ------> USART1_RX
  253. */
  254. GPIO_InitStruct.Pin = GPIO_PIN_9;
  255. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  256. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
  257. HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
  258. GPIO_InitStruct.Pin = GPIO_PIN_10;
  259. GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
  260. GPIO_InitStruct.Pull = GPIO_NOPULL;
  261. HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
  262. /* USART1 DMA Init */
  263. /* USART1_RX Init */
  264. hdma_usart1_rx.Instance = DMA1_Channel5;
  265. hdma_usart1_rx.Init.Direction = DMA_PERIPH_TO_MEMORY;
  266. hdma_usart1_rx.Init.PeriphInc = DMA_PINC_DISABLE;
  267. hdma_usart1_rx.Init.MemInc = DMA_MINC_ENABLE;
  268. hdma_usart1_rx.Init.PeriphDataAlignment = DMA_PDATAALIGN_BYTE;
  269. hdma_usart1_rx.Init.MemDataAlignment = DMA_MDATAALIGN_BYTE;
  270. hdma_usart1_rx.Init.Mode = DMA_NORMAL;
  271. hdma_usart1_rx.Init.Priority = DMA_PRIORITY_LOW;
  272. if (HAL_DMA_Init(&hdma_usart1_rx) != HAL_OK)
  273. {
  274. Error_Handler();
  275. }
  276. __HAL_LINKDMA(uartHandle,hdmarx,hdma_usart1_rx);
  277. /* USART1_TX Init */
  278. hdma_usart1_tx.Instance = DMA1_Channel4;
  279. hdma_usart1_tx.Init.Direction = DMA_MEMORY_TO_PERIPH;
  280. hdma_usart1_tx.Init.PeriphInc = DMA_PINC_DISABLE;
  281. hdma_usart1_tx.Init.MemInc = DMA_MINC_ENABLE;
  282. hdma_usart1_tx.Init.PeriphDataAlignment = DMA_PDATAALIGN_BYTE;
  283. hdma_usart1_tx.Init.MemDataAlignment = DMA_MDATAALIGN_BYTE;
  284. hdma_usart1_tx.Init.Mode = DMA_NORMAL;
  285. hdma_usart1_tx.Init.Priority = DMA_PRIORITY_LOW;
  286. if (HAL_DMA_Init(&hdma_usart1_tx) != HAL_OK)
  287. {
  288. Error_Handler();
  289. }
  290. __HAL_LINKDMA(uartHandle,hdmatx,hdma_usart1_tx);
  291. /* USART1 interrupt Init */
  292. HAL_NVIC_SetPriority(USART1_IRQn, 5, 0);
  293. HAL_NVIC_EnableIRQ(USART1_IRQn);
  294. /* USER CODE BEGIN USART1_MspInit 1 */
  295. /* USER CODE END USART1_MspInit 1 */
  296. }
  297. else if(uartHandle->Instance==USART2)
  298. {
  299. /* USER CODE BEGIN USART2_MspInit 0 */
  300. /* USER CODE END USART2_MspInit 0 */
  301. /* USART2 clock enable */
  302. __HAL_RCC_USART2_CLK_ENABLE();
  303. __HAL_RCC_GPIOA_CLK_ENABLE();
  304. /**USART2 GPIO Configuration
  305. PA2 ------> USART2_TX
  306. PA3 ------> USART2_RX
  307. */
  308. GPIO_InitStruct.Pin = GPIO_PIN_2;
  309. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  310. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
  311. HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
  312. GPIO_InitStruct.Pin = GPIO_PIN_3;
  313. GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
  314. GPIO_InitStruct.Pull = GPIO_NOPULL;
  315. HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
  316. /* USART2 DMA Init */
  317. /* USART2_RX Init */
  318. hdma_usart2_rx.Instance = DMA1_Channel6;
  319. hdma_usart2_rx.Init.Direction = DMA_PERIPH_TO_MEMORY;
  320. hdma_usart2_rx.Init.PeriphInc = DMA_PINC_DISABLE;
  321. hdma_usart2_rx.Init.MemInc = DMA_MINC_ENABLE;
  322. hdma_usart2_rx.Init.PeriphDataAlignment = DMA_PDATAALIGN_BYTE;
  323. hdma_usart2_rx.Init.MemDataAlignment = DMA_MDATAALIGN_BYTE;
  324. hdma_usart2_rx.Init.Mode = DMA_NORMAL;
  325. hdma_usart2_rx.Init.Priority = DMA_PRIORITY_LOW;
  326. if (HAL_DMA_Init(&hdma_usart2_rx) != HAL_OK)
  327. {
  328. Error_Handler();
  329. }
  330. __HAL_LINKDMA(uartHandle,hdmarx,hdma_usart2_rx);
  331. /* USART2_TX Init */
  332. hdma_usart2_tx.Instance = DMA1_Channel7;
  333. hdma_usart2_tx.Init.Direction = DMA_MEMORY_TO_PERIPH;
  334. hdma_usart2_tx.Init.PeriphInc = DMA_PINC_DISABLE;
  335. hdma_usart2_tx.Init.MemInc = DMA_MINC_ENABLE;
  336. hdma_usart2_tx.Init.PeriphDataAlignment = DMA_PDATAALIGN_BYTE;
  337. hdma_usart2_tx.Init.MemDataAlignment = DMA_MDATAALIGN_BYTE;
  338. hdma_usart2_tx.Init.Mode = DMA_NORMAL;
  339. hdma_usart2_tx.Init.Priority = DMA_PRIORITY_LOW;
  340. if (HAL_DMA_Init(&hdma_usart2_tx) != HAL_OK)
  341. {
  342. Error_Handler();
  343. }
  344. __HAL_LINKDMA(uartHandle,hdmatx,hdma_usart2_tx);
  345. /* USART2 interrupt Init */
  346. HAL_NVIC_SetPriority(USART2_IRQn, 5, 0);
  347. HAL_NVIC_EnableIRQ(USART2_IRQn);
  348. /* USER CODE BEGIN USART2_MspInit 1 */
  349. /* USER CODE END USART2_MspInit 1 */
  350. }
  351. else if(uartHandle->Instance==USART3)
  352. {
  353. /* USER CODE BEGIN USART3_MspInit 0 */
  354. /* USER CODE END USART3_MspInit 0 */
  355. /* USART3 clock enable */
  356. __HAL_RCC_USART3_CLK_ENABLE();
  357. __HAL_RCC_GPIOB_CLK_ENABLE();
  358. /**USART3 GPIO Configuration
  359. PB10 ------> USART3_TX
  360. PB11 ------> USART3_RX
  361. */
  362. GPIO_InitStruct.Pin = GPIO_PIN_10;
  363. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  364. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
  365. HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
  366. GPIO_InitStruct.Pin = GPIO_PIN_11;
  367. GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
  368. GPIO_InitStruct.Pull = GPIO_NOPULL;
  369. HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
  370. /* USART3 DMA Init */
  371. /* USART3_RX Init */
  372. hdma_usart3_rx.Instance = DMA1_Channel3;
  373. hdma_usart3_rx.Init.Direction = DMA_PERIPH_TO_MEMORY;
  374. hdma_usart3_rx.Init.PeriphInc = DMA_PINC_DISABLE;
  375. hdma_usart3_rx.Init.MemInc = DMA_MINC_ENABLE;
  376. hdma_usart3_rx.Init.PeriphDataAlignment = DMA_PDATAALIGN_BYTE;
  377. hdma_usart3_rx.Init.MemDataAlignment = DMA_MDATAALIGN_BYTE;
  378. hdma_usart3_rx.Init.Mode = DMA_NORMAL;
  379. hdma_usart3_rx.Init.Priority = DMA_PRIORITY_LOW;
  380. if (HAL_DMA_Init(&hdma_usart3_rx) != HAL_OK)
  381. {
  382. Error_Handler();
  383. }
  384. __HAL_LINKDMA(uartHandle,hdmarx,hdma_usart3_rx);
  385. /* USART3_TX Init */
  386. hdma_usart3_tx.Instance = DMA1_Channel2;
  387. hdma_usart3_tx.Init.Direction = DMA_MEMORY_TO_PERIPH;
  388. hdma_usart3_tx.Init.PeriphInc = DMA_PINC_DISABLE;
  389. hdma_usart3_tx.Init.MemInc = DMA_MINC_ENABLE;
  390. hdma_usart3_tx.Init.PeriphDataAlignment = DMA_PDATAALIGN_BYTE;
  391. hdma_usart3_tx.Init.MemDataAlignment = DMA_MDATAALIGN_BYTE;
  392. hdma_usart3_tx.Init.Mode = DMA_NORMAL;
  393. hdma_usart3_tx.Init.Priority = DMA_PRIORITY_LOW;
  394. if (HAL_DMA_Init(&hdma_usart3_tx) != HAL_OK)
  395. {
  396. Error_Handler();
  397. }
  398. __HAL_LINKDMA(uartHandle,hdmatx,hdma_usart3_tx);
  399. /* USART3 interrupt Init */
  400. HAL_NVIC_SetPriority(USART3_IRQn, 5, 0);
  401. HAL_NVIC_EnableIRQ(USART3_IRQn);
  402. /* USER CODE BEGIN USART3_MspInit 1 */
  403. /* USER CODE END USART3_MspInit 1 */
  404. }
  405. }
  406. void HAL_UART_MspDeInit(UART_HandleTypeDef* uartHandle)
  407. {
  408. if(uartHandle->Instance==UART4)
  409. {
  410. /* USER CODE BEGIN UART4_MspDeInit 0 */
  411. /* USER CODE END UART4_MspDeInit 0 */
  412. /* Peripheral clock disable */
  413. __HAL_RCC_UART4_CLK_DISABLE();
  414. /**UART4 GPIO Configuration
  415. PC10 ------> UART4_TX
  416. PC11 ------> UART4_RX
  417. */
  418. HAL_GPIO_DeInit(GPIOC, GPIO_PIN_10|GPIO_PIN_11);
  419. /* UART4 DMA DeInit */
  420. HAL_DMA_DeInit(uartHandle->hdmarx);
  421. HAL_DMA_DeInit(uartHandle->hdmatx);
  422. /* UART4 interrupt Deinit */
  423. HAL_NVIC_DisableIRQ(UART4_IRQn);
  424. /* USER CODE BEGIN UART4_MspDeInit 1 */
  425. /* USER CODE END UART4_MspDeInit 1 */
  426. }
  427. else if(uartHandle->Instance==UART5)
  428. {
  429. /* USER CODE BEGIN UART5_MspDeInit 0 */
  430. /* USER CODE END UART5_MspDeInit 0 */
  431. /* Peripheral clock disable */
  432. __HAL_RCC_UART5_CLK_DISABLE();
  433. /**UART5 GPIO Configuration
  434. PC12 ------> UART5_TX
  435. PD2 ------> UART5_RX
  436. */
  437. HAL_GPIO_DeInit(GPIOC, GPIO_PIN_12);
  438. HAL_GPIO_DeInit(GPIOD, GPIO_PIN_2);
  439. /* UART5 interrupt Deinit */
  440. HAL_NVIC_DisableIRQ(UART5_IRQn);
  441. /* USER CODE BEGIN UART5_MspDeInit 1 */
  442. /* USER CODE END UART5_MspDeInit 1 */
  443. }
  444. else if(uartHandle->Instance==USART1)
  445. {
  446. /* USER CODE BEGIN USART1_MspDeInit 0 */
  447. /* USER CODE END USART1_MspDeInit 0 */
  448. /* Peripheral clock disable */
  449. __HAL_RCC_USART1_CLK_DISABLE();
  450. /**USART1 GPIO Configuration
  451. PA9 ------> USART1_TX
  452. PA10 ------> USART1_RX
  453. */
  454. HAL_GPIO_DeInit(GPIOA, GPIO_PIN_9|GPIO_PIN_10);
  455. /* USART1 DMA DeInit */
  456. HAL_DMA_DeInit(uartHandle->hdmarx);
  457. HAL_DMA_DeInit(uartHandle->hdmatx);
  458. /* USART1 interrupt Deinit */
  459. HAL_NVIC_DisableIRQ(USART1_IRQn);
  460. /* USER CODE BEGIN USART1_MspDeInit 1 */
  461. /* USER CODE END USART1_MspDeInit 1 */
  462. }
  463. else if(uartHandle->Instance==USART2)
  464. {
  465. /* USER CODE BEGIN USART2_MspDeInit 0 */
  466. /* USER CODE END USART2_MspDeInit 0 */
  467. /* Peripheral clock disable */
  468. __HAL_RCC_USART2_CLK_DISABLE();
  469. /**USART2 GPIO Configuration
  470. PA2 ------> USART2_TX
  471. PA3 ------> USART2_RX
  472. */
  473. HAL_GPIO_DeInit(GPIOA, GPIO_PIN_2|GPIO_PIN_3);
  474. /* USART2 DMA DeInit */
  475. HAL_DMA_DeInit(uartHandle->hdmarx);
  476. HAL_DMA_DeInit(uartHandle->hdmatx);
  477. /* USART2 interrupt Deinit */
  478. HAL_NVIC_DisableIRQ(USART2_IRQn);
  479. /* USER CODE BEGIN USART2_MspDeInit 1 */
  480. /* USER CODE END USART2_MspDeInit 1 */
  481. }
  482. else if(uartHandle->Instance==USART3)
  483. {
  484. /* USER CODE BEGIN USART3_MspDeInit 0 */
  485. /* USER CODE END USART3_MspDeInit 0 */
  486. /* Peripheral clock disable */
  487. __HAL_RCC_USART3_CLK_DISABLE();
  488. /**USART3 GPIO Configuration
  489. PB10 ------> USART3_TX
  490. PB11 ------> USART3_RX
  491. */
  492. HAL_GPIO_DeInit(GPIOB, GPIO_PIN_10|GPIO_PIN_11);
  493. /* USART3 DMA DeInit */
  494. HAL_DMA_DeInit(uartHandle->hdmarx);
  495. HAL_DMA_DeInit(uartHandle->hdmatx);
  496. /* USART3 interrupt Deinit */
  497. HAL_NVIC_DisableIRQ(USART3_IRQn);
  498. /* USER CODE BEGIN USART3_MspDeInit 1 */
  499. /* USER CODE END USART3_MspDeInit 1 */
  500. }
  501. }
  502. /* USER CODE BEGIN 1 */
  503. #ifdef __GNUC__
  504. /* With GCC/RAISONANCE, small printf (option LD Linker->Libraries->Small printf
  505. set to 'Yes') calls __io_putchar() */
  506. #define PUTCHAR_PROTOTYPE int __io_putchar(int ch)
  507. #else
  508. #define PUTCHAR_PROTOTYPE int fputc(int ch, FILE *f)
  509. #endif /* __GNUC__ */
  510. PUTCHAR_PROTOTYPE
  511. {
  512. HAL_UART_Transmit(&huart1, (uint8_t *)&ch, 1, 0xFFFF);//485串口打印
  513. return ch;
  514. }
  515. //uint8_t Read_flash_6(uint32_t addr, uint8_t* data_ptr){
  516. // for (int i = 5; i > -1; i--) {
  517. //
  518. // data_ptr[5-i] = *(volatile uint8_t*)(addr + i);
  519. // }
  520. // uint8_t Lstatus = *(volatile uint8_t*)(addr + 7);
  521. // return Lstatus;
  522. //}
  523. //void erase_flash(uint32_t ADDR_FLASH){ //进行擦除
  524. // FLASH_EraseInitTypeDef erase_init;
  525. // erase_init.TypeErase = FLASH_TYPEERASE_PAGES; // 擦除类型为页擦除
  526. // erase_init.PageAddress = ADDR_FLASH;
  527. // erase_init.NbPages = 1; // 擦除的页数
  528. // uint32_t page_error = 0;
  529. // HAL_FLASH_Unlock(); // 解锁Flash
  530. // HAL_StatusTypeDef status = HAL_FLASHEx_Erase(&erase_init, &page_error); // 执行擦除操作
  531. // HAL_FLASH_Lock(); // 上锁Flash
  532. // HAL_Delay(10);
  533. //}
  534. //void Write_Info64(uint32_t addr, uint64_t newValue) {//烧写mac号
  535. // erase_flash(addr);
  536. // HAL_FLASH_Unlock(); // 解锁Flash
  537. //
  538. // HAL_StatusTypeDef status = HAL_FLASH_Program(FLASH_TYPEPROGRAM_DOUBLEWORD, addr, newValue);
  539. //
  540. // HAL_FLASH_Lock(); // 上锁Flash
  541. //}
  542. //void Write_Info08(uint32_t addr, uint8_t newValue) {
  543. // erase_flash(addr);
  544. // HAL_FLASH_Unlock(); // 解锁Flash
  545. // HAL_StatusTypeDef status = HAL_FLASH_Program(FLASH_TYPEPROGRAM_HALFWORD, addr, newValue);
  546. // HAL_FLASH_Lock(); // 上锁Flash
  547. //}
  548. //uint16_t read_flash_16(uint32_t addr){
  549. // uint16_t data = *(volatile uint16_t*)addr; // 从Flash中读取2个字节
  550. // return data;
  551. //}
  552. //void Write_Information(uint32_t addr, uint16_t newValue) {
  553. // erase_flash(addr);
  554. // HAL_FLASH_Unlock(); // 解锁Flash
  555. // if(addr== serialNum1Addr || addr== serialNum2Addr || addr== serialNum3Addr || addr== serialNum4Addr)
  556. // {
  557. // HAL_StatusTypeDef status = HAL_FLASH_Program(FLASH_TYPEPROGRAM_WORD, addr, newValue);
  558. // }
  559. // else
  560. // {
  561. // HAL_StatusTypeDef status = HAL_FLASH_Program(FLASH_TYPEPROGRAM_HALFWORD, addr, newValue);
  562. // }
  563. // HAL_FLASH_Lock(); // 上锁Flash
  564. //}
  565. void Flash_ReadBytes(uint16_t* sorBuf,uint32_t FlashAddr,uint16_t len)
  566. {
  567. uint16_t* p = sorBuf;
  568. uint8_t i = 0,j = 0;
  569. uint32_t addr = FlashAddr;
  570. while(len--)
  571. {
  572. i = *(uint32_t*)addr++;
  573. j = *(uint32_t*)addr++;
  574. *p++ = j<<8|i;
  575. }
  576. }
  577. HAL_StatusTypeDef WriteSta;
  578. // 定义Flash缓冲区
  579. uint16_t Flashbuf[2048] __attribute__((at(0X20001000)));
  580. // Flash写入函数
  581. HAL_StatusTypeDef Flash_WriteBytes(uint16_t* sorBuf, uint32_t FlashAddr, uint16_t len)
  582. {
  583. uint32_t Offset_ADDR = 0, Page_StartAddr = 0, i = 0;
  584. // 计算偏移地址和起始地址
  585. Offset_ADDR = FlashAddr % FLASH_PAGE_SIZE;
  586. Page_StartAddr = FlashAddr - Offset_ADDR;
  587. // 设置PageError
  588. uint32_t PageError = 0;
  589. // 初始化擦除参数
  590. FLASH_EraseInitTypeDef f;
  591. f.TypeErase = FLASH_TYPEERASE_PAGES;
  592. f.PageAddress = Page_StartAddr;
  593. f.NbPages = 1;
  594. // 读取Flash缓冲区数据
  595. Flash_ReadBytes(Flashbuf, Page_StartAddr, 0x400);
  596. // 将源缓冲区数据写入Flash缓冲区
  597. for (i = 0; i < len; i++)
  598. Flashbuf[Offset_ADDR / 2 + i] = sorBuf[i];
  599. // 解锁FLASH
  600. HAL_FLASH_Unlock();
  601. // 擦除FLASH
  602. HAL_FLASHEx_Erase(&f, &PageError);
  603. // 写入Flash缓冲区数据到FLASH
  604. for (uint16_t i = 0; i < 0x400; i++)
  605. {
  606. WriteSta = HAL_FLASH_Program(FLASH_TYPEPROGRAM_HALFWORD, Page_StartAddr + (i * 2), Flashbuf[i]);
  607. }
  608. HAL_Delay(100);
  609. // 锁住FLASH
  610. HAL_FLASH_Lock();
  611. return WriteSta;
  612. }
  613. void Printf_u4u5logbyU1(void)
  614. {
  615. if(U4_4GreFlag)
  616. {
  617. U4_4GreFlag=false;
  618. HAL_UART_Transmit(&huart1,U4_4GrecvBuff,U4_4GrecvLength,0xFFFF);//有信息就吐
  619. }
  620. if(U5_BTreFlag)
  621. {
  622. U5_BTreFlag=false;
  623. memcpy(autoRe,U5_BTrecvBuff,U5_BTrecvLength);
  624. HAL_UART_Transmit(&huart1,U5_BTrecvBuff,U5_BTrecvLength,0xFFFF);
  625. //memset(U5_BTrecvBuff,0,BUFFER_SIZE);
  626. }
  627. }
  628. uint8_t xorBytes(uint8_t arr[], int size) {
  629. uint8_t result = arr[0]; // 初始化结果为第一个元素
  630. for (int i = 1; i < size; i++) {
  631. result ^= arr[i]; // 将结果与当前元素进行异或操作
  632. }
  633. //printf("异或结果: %02X\n", result); // 打印异或结果
  634. return result;
  635. }
  636. uint16_t crc16(uint8_t *data, size_t len) {
  637. uint8_t flag;
  638. uint16_t wcrc = 0xffff;
  639. for (size_t i = 0; i < len; i++) {
  640. wcrc = wcrc ^ (data[i] & 0xff);
  641. for (size_t j = 0; j < 8; j++) {
  642. flag = wcrc & 0x0001;
  643. wcrc = wcrc >> 1;
  644. if (flag == 1) {
  645. wcrc ^= 0xa001;
  646. }
  647. wcrc = wcrc & 0xffff;
  648. }
  649. }
  650. return wcrc;
  651. }
  652. void USART_SendHexArray(UART_HandleTypeDef *huart, uint8_t *data, int length)
  653. {
  654. HAL_UART_Transmit(huart,data, length, 0xFFFF);
  655. HAL_UART_Transmit(&huart1, data, length, 0xFFFF);//485
  656. }
  657. struct AES_ctx ctx;
  658. void sendCombinedArray(uint8_t *header, size_t headerLength, uint8_t *command, size_t commandLength, bool encryption) {
  659. // 创建一个长度为20的数组
  660. uint8_t combinedArray[20] = {0};
  661. // 将header复制到combinedArray的前两个字节
  662. combinedArray[0] = header[0];//0x66
  663. combinedArray[1] = header[1];//0x01(加密)
  664. // 计算command的异或校验和
  665. uint8_t result_xor = xorBytes(command, commandLength);
  666. // 创建一个长度为16的数组来存储command和result_xor
  667. uint8_t cmd_array[16] = {0};
  668. // 将command复制到cmd_array中
  669. for (int i = 0; i < commandLength; i++) {
  670. cmd_array[i] = command[i];
  671. }
  672. cmd_array[commandLength] = result_xor;
  673. /* 加密 */
  674. if(encryption)
  675. {
  676. AES_init_ctx_iv(&ctx, DtuBtKey, iv);
  677. AES_CBC_encrypt_buffer(&ctx, cmd_array, 16);
  678. }
  679. // 将cmd_array添加到combinedArray
  680. for (int i = 0; i < 16; i++) {
  681. combinedArray[i + headerLength] = cmd_array[i];
  682. }
  683. // 计算combinedArray的CRC校验和
  684. uint16_t result_frame = crc16(combinedArray, sizeof(combinedArray) - 2);
  685. // 将result_frame添加到combinedArray
  686. combinedArray[18] = result_frame & 0xFF; //低字节在前
  687. combinedArray[19] = (result_frame >> 8) & 0xFF;
  688. // 发送combinedArray
  689. USART_SendHexArray(&huart5, combinedArray, sizeof(combinedArray));
  690. }
  691. uint32_t convertGPS(double temp) {
  692. //*WGS-84坐标
  693. if(temp > 40)
  694. {
  695. temp = temp/100;
  696. double latDeg = floor(temp);//向下取整 纬度
  697. double latMin = fmod(temp, 1);
  698. temp = latDeg + (latMin / 60.0)*100;
  699. double dlat = temp;
  700. uint32_t latMicrodegree = (uint32_t)(dlat * 1000000);
  701. return latMicrodegree;
  702. }
  703. else
  704. {
  705. temp = temp/100;
  706. double lonDeg = floor(temp);//向下取整
  707. double lonMin = fmod(temp, 1);
  708. temp = lonDeg + (lonMin / 60.0)*100;
  709. double dlng = temp;
  710. uint32_t lngMicrodegree = (uint32_t)(dlng * 1000000);
  711. return lngMicrodegree;
  712. }
  713. }
  714. /* USER CODE END 1 */