main.c 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677
  1. /* USER CODE BEGIN Header */
  2. /**
  3. ******************************************************************************
  4. * @file : main.c
  5. * @brief : Main program body
  6. ******************************************************************************
  7. * @attention
  8. *
  9. * Copyright (c) 2023 STMicroelectronics.
  10. * All rights reserved.
  11. *
  12. * This software is licensed under terms that can be found in the LICENSE file
  13. * in the root directory of this software component.
  14. * If no LICENSE file comes with this software, it is provided AS-IS.
  15. *
  16. ******************************************************************************
  17. */
  18. /* USER CODE END Header */
  19. /* Includes ------------------------------------------------------------------*/
  20. #include "main.h"
  21. #include "cmsis_os.h"
  22. #include "adc.h"
  23. #include "dma.h"
  24. #include "tim.h"
  25. #include "usart.h"
  26. #include "gpio.h"
  27. /* Private includes ----------------------------------------------------------*/
  28. /* USER CODE BEGIN Includes */
  29. /* USER CODE END Includes */
  30. /* Private typedef -----------------------------------------------------------*/
  31. /* USER CODE BEGIN PTD */
  32. /* USER CODE END PTD */
  33. /* Private define ------------------------------------------------------------*/
  34. /* USER CODE BEGIN PD */
  35. /* USER CODE END PD */
  36. /* Private macro -------------------------------------------------------------*/
  37. /* USER CODE BEGIN PM */
  38. /* USER CODE END PM */
  39. /* Private variables ---------------------------------------------------------*/
  40. /* USER CODE BEGIN PV */
  41. int rebootTip;
  42. uint8_t data_to_send[50];
  43. uint16_t CRC_value = 0;
  44. uint16_t initial_address = 0x00C1;
  45. uint16_t BaudrateValue = 0x0000;
  46. uint32_t System_version = 0x23081000;
  47. uint8_t bufMain[128] = {0};
  48. /* USER CODE END PV */
  49. /* Private function prototypes -----------------------------------------------*/
  50. void SystemClock_Config(void);
  51. void MX_FREERTOS_Init(void);
  52. /* USER CODE BEGIN PFP */
  53. /* USER CODE END PFP */
  54. /* Private user code ---------------------------------------------------------*/
  55. /* USER CODE BEGIN 0 */
  56. /* USER CODE END 0 */
  57. /**
  58. * @brief The application entry point.
  59. * @retval int
  60. */
  61. int main(void)
  62. {
  63. /* USER CODE BEGIN 1 */
  64. /* USER CODE END 1 */
  65. /* MCU Configuration--------------------------------------------------------*/
  66. /* Reset of all peripherals, Initializes the Flash interface and the Systick. */
  67. HAL_Init();
  68. /* USER CODE BEGIN Init */
  69. /* USER CODE END Init */
  70. /* Configure the system clock */
  71. SystemClock_Config();
  72. /* USER CODE BEGIN SysInit */
  73. /* USER CODE END SysInit */
  74. /* Initialize all configured peripherals */
  75. MX_GPIO_Init();
  76. MX_DMA_Init();
  77. MX_USART1_UART_Init();
  78. MX_ADC1_Init();
  79. MX_TIM2_Init();
  80. MX_USART3_UART_Init();
  81. /* USER CODE BEGIN 2 */
  82. HAL_TIM_Base_Start_IT(&htim2);
  83. update_iaplength(LENGTH_ADDR);
  84. #if IR_ROM1 == 0x08000000
  85. Start_BootLoader();
  86. // app1
  87. #else
  88. SCB->VTOR = 0x08020000;
  89. #endif
  90. //更新标定数据
  91. AdcCalibration_init();
  92. updateiapMd5();
  93. update_sysVersion(StartMode_Addr+14);
  94. read_new_address(addr_FLASH_ADDR);
  95. updatePbStatus(read_flash_16(pbstatus_FLASH_ADDR));
  96. update_baudrate(read_flash_16(baudrate_FLASH_ADDR));
  97. //更新结束
  98. int txLen = sprintf((char *)USART_IAP_RX, "reboot");
  99. HAL_UART_Transmit_IT(&huart1,USART_IAP_RX,txLen);
  100. HAL_UART_Receive_DMA(&huart1,USART_PUB_RX,RX_BUF_SIZE);
  101. __HAL_UART_ENABLE_IT(&huart1, UART_IT_IDLE);
  102. if (App2_MD5_Check(ADD_UPDATE_PROG,all_len))
  103. {
  104. __set_FAULTMASK(0); //先关闭全局中断
  105. jump_to_app(ADD_UPDATE_PROG);
  106. }
  107. /* USER CODE END 2 */
  108. /* Call init function for freertos objects (in freertos.c) */
  109. MX_FREERTOS_Init();
  110. /* Start scheduler */
  111. osKernelStart();
  112. /* We should never get here as control is now taken by the scheduler */
  113. /* Infinite loop */
  114. /* USER CODE BEGIN WHILE */
  115. while (1)
  116. {
  117. /* USER CODE END WHILE */
  118. /* USER CODE BEGIN 3 */
  119. }
  120. /* USER CODE END 3 */
  121. }
  122. /**
  123. * @brief System Clock Configuration
  124. * @retval None
  125. */
  126. void SystemClock_Config(void)
  127. {
  128. RCC_OscInitTypeDef RCC_OscInitStruct = {0};
  129. RCC_ClkInitTypeDef RCC_ClkInitStruct = {0};
  130. RCC_PeriphCLKInitTypeDef PeriphClkInit = {0};
  131. /** Initializes the RCC Oscillators according to the specified parameters
  132. * in the RCC_OscInitTypeDef structure.
  133. */
  134. RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSE;
  135. RCC_OscInitStruct.HSEState = RCC_HSE_ON;
  136. RCC_OscInitStruct.HSEPredivValue = RCC_HSE_PREDIV_DIV1;
  137. RCC_OscInitStruct.HSIState = RCC_HSI_ON;
  138. RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON;
  139. RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_HSE;
  140. RCC_OscInitStruct.PLL.PLLMUL = RCC_PLL_MUL2;
  141. if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK)
  142. {
  143. Error_Handler();
  144. }
  145. /** Initializes the CPU, AHB and APB buses clocks
  146. */
  147. RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK|RCC_CLOCKTYPE_SYSCLK
  148. |RCC_CLOCKTYPE_PCLK1|RCC_CLOCKTYPE_PCLK2;
  149. RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK;
  150. RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV2;
  151. RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV2;
  152. RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV1;
  153. if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_0) != HAL_OK)
  154. {
  155. Error_Handler();
  156. }
  157. PeriphClkInit.PeriphClockSelection = RCC_PERIPHCLK_ADC;
  158. PeriphClkInit.AdcClockSelection = RCC_ADCPCLK2_DIV4;
  159. if (HAL_RCCEx_PeriphCLKConfig(&PeriphClkInit) != HAL_OK)
  160. {
  161. Error_Handler();
  162. }
  163. }
  164. /* USER CODE BEGIN 4 */
  165. uint16_t read_flash_16(uint32_t addr){
  166. uint16_t data = *(volatile uint16_t*)addr; // 从Flash中读取2个字节
  167. return data;
  168. }
  169. uint32_t read_flash_32(uint32_t addr){
  170. uint32_t data = *(volatile uint32_t*)addr;
  171. return data;
  172. }
  173. void read_new_address(uint32_t addr){
  174. uint16_t init_address = read_flash_16(addr);
  175. if(init_address == 0xFFFF) {
  176. initial_address = initial_address;
  177. } else {
  178. initial_address = init_address; // 读取新地址并赋值给initial_address
  179. }
  180. }
  181. void erase_flash(uint32_t ADDR_FLASH){ //进行擦除
  182. FLASH_EraseInitTypeDef erase_init;
  183. erase_init.TypeErase = FLASH_TYPEERASE_PAGES; // 擦除类型为页擦除
  184. erase_init.PageAddress = ADDR_FLASH;
  185. erase_init.NbPages = 1; // 擦除的页数
  186. uint32_t page_error = 0;
  187. HAL_FLASH_Unlock(); // 解锁Flash
  188. HAL_StatusTypeDef status = HAL_FLASHEx_Erase(&erase_init, &page_error); // 执行擦除操作
  189. HAL_FLASH_Lock(); // 上锁Flash
  190. if(status == HAL_OK){
  191. if(ADDR_FLASH == addr_FLASH_ADDR) {
  192. initial_address = 0; // 将initial_address清零
  193. }
  194. else if(ADDR_FLASH == pbstatus_FLASH_ADDR) {
  195. gpiobStatus = 0; // 将pb_status清零
  196. }
  197. else if(ADDR_FLASH == baudrate_FLASH_ADDR) {
  198. BaudrateValue = 0xFFFF;
  199. }
  200. else if(ADDR_FLASH == ADC1_FLASH_ADDR) {
  201. Adc2_CalibrationValue = 0x0000; // 清零
  202. }
  203. else if(ADDR_FLASH == ADC2_FLASH_ADDR) {
  204. Adc3_CalibrationValue = 0x0000; // 清零
  205. }
  206. }
  207. }
  208. void Write_Information(uint32_t addr, uint8_t* rx_buffer, uint8_t buffer_index) {
  209. uint16_t newValue = 0;
  210. erase_flash(addr);
  211. HAL_FLASH_Unlock(); // 解锁Flash
  212. if (addr == addr_FLASH_ADDR) { // 写入地址到Flash
  213. newValue = rx_buffer[buffer_index];
  214. HAL_StatusTypeDef status = HAL_FLASH_Program(FLASH_TYPEPROGRAM_HALFWORD, addr_FLASH_ADDR, newValue);
  215. if (status == HAL_OK) {
  216. initial_address = newValue; // 将新地址赋值给initial_address
  217. }
  218. }
  219. else if (addr == pbstatus_FLASH_ADDR) { // 写入PB状态到Flash
  220. newValue = rx_buffer[buffer_index];
  221. HAL_StatusTypeDef status = HAL_FLASH_Program(FLASH_TYPEPROGRAM_HALFWORD, pbstatus_FLASH_ADDR, newValue);
  222. if (status == HAL_OK) {
  223. gpiobStatus = newValue; // 将新状态赋值给gpiobStatus
  224. }
  225. }
  226. else if (addr == baudrate_FLASH_ADDR) { // 写入波特率到Flash
  227. newValue = rx_buffer[buffer_index];
  228. HAL_StatusTypeDef status = HAL_FLASH_Program(FLASH_TYPEPROGRAM_HALFWORD, baudrate_FLASH_ADDR, newValue);
  229. if (status == HAL_OK) {
  230. BaudrateValue = newValue; // 将新状态赋值给BaudrateValue
  231. }
  232. }
  233. else if (addr == ADC1_FLASH_ADDR || addr == ADC2_FLASH_ADDR) { // 写入ADC校准值到Flash
  234. uint16_t Standard_value = (0.6 / (3.3 / 4096));
  235. if (addr == ADC1_FLASH_ADDR) {
  236. if (adc2_rawValue >= Standard_value) {
  237. newValue = adc2_rawValue - Standard_value;
  238. } else {
  239. newValue = Standard_value - adc2_rawValue;
  240. newValue |= 0x8000;
  241. }
  242. HAL_StatusTypeDef status = HAL_FLASH_Program(FLASH_TYPEPROGRAM_HALFWORD, ADC1_FLASH_ADDR, newValue);
  243. if (status == HAL_OK) {
  244. Adc2_CalibrationValue = newValue & 0x7FFF;
  245. Value_old_addr2 = newValue;
  246. }
  247. }
  248. else if (addr == ADC2_FLASH_ADDR) {
  249. if (adc3_rawValue >= Standard_value) {
  250. newValue = adc3_rawValue - Standard_value;
  251. } else {
  252. newValue = Standard_value - adc3_rawValue;
  253. newValue |= 0x8000;
  254. }
  255. HAL_StatusTypeDef status = HAL_FLASH_Program(FLASH_TYPEPROGRAM_HALFWORD, ADC2_FLASH_ADDR, newValue);
  256. if (status == HAL_OK) {
  257. Adc3_CalibrationValue = newValue & 0x7FFF;
  258. Value_old_addr3 = newValue;
  259. }
  260. }
  261. }
  262. HAL_FLASH_Lock(); // 上锁Flash
  263. }
  264. void clear_buf(void){
  265. memset(USART_MODBUS_RX, 0, sizeof(USART_MODBUS_RX));
  266. memset(USART_PUB_RX, 0, RX_BUF_SIZE);
  267. USART_MODBUS_FLAG = 0;
  268. USART_IAP_FLAG = 0;
  269. }
  270. void re_receive(void){
  271. HAL_UART_AbortReceive(&huart1);
  272. HAL_UART_Receive_DMA(&huart1, USART_PUB_RX, RX_BUF_SIZE);
  273. }
  274. void receive_modbus_7(uint16_t addr, uint8_t funcode, uint8_t byteNum, uint16_t byte, int byteSize){
  275. uint8_t data_to_send[] = {(uint8_t)addr, funcode, byteNum, (uint8_t)(byte >> 8), (uint8_t)(byte & 0xFF), 0x00, 0x00};
  276. uint16_t CRC_value = calculate_crc(data_to_send, (byteSize - 2));
  277. data_to_send[(byteSize - 2)] = (uint8_t)(CRC_value & 0xFF);
  278. data_to_send[(byteSize - 1)] = (uint8_t)(CRC_value >> 8);
  279. HAL_UART_Transmit(&huart1, data_to_send, byteSize, byteSize);
  280. clear_buf();
  281. re_receive();
  282. }
  283. void receive_modbus_8(uint16_t addr, uint8_t funcode, uint16_t startaddr, uint16_t reg){
  284. uint8_t data_to_send[] = {(uint8_t)addr, funcode, (uint8_t)(startaddr >> 8), (uint8_t)(startaddr & 0xFF), \
  285. (uint8_t)(reg >> 8), (uint8_t)(reg & 0xFF), 0x00, 0x00};
  286. uint16_t CRC_value = calculate_crc(data_to_send, 6);
  287. data_to_send[6] = (uint8_t)(CRC_value & 0xFF);
  288. data_to_send[7] = (uint8_t)(CRC_value >> 8);
  289. HAL_UART_Transmit(&huart1, data_to_send, 8, 7);
  290. clear_buf();
  291. re_receive();
  292. }
  293. void receive_modbus_9_1(uint16_t addr, uint8_t funcode, uint16_t startaddr, uint16_t reg, uint8_t byteNum){
  294. uint8_t data_to_send[] = {(uint8_t)addr, funcode, (uint8_t)(startaddr >> 8), (uint8_t)(startaddr & 0xFF), \
  295. (uint8_t)(reg >> 8), (uint8_t)(reg & 0xFF), byteNum, 0x00, 0x00};
  296. uint16_t CRC_value = calculate_crc(data_to_send, 7);
  297. data_to_send[7] = (uint8_t)(CRC_value & 0xFF);
  298. data_to_send[8] = (uint8_t)(CRC_value >> 8);
  299. HAL_UART_Transmit(&huart1, data_to_send, 9, 9);
  300. clear_buf();
  301. re_receive();
  302. }
  303. void receive_modbus_9(uint16_t addr, uint8_t funcode, uint8_t byteNum, uint16_t byte1, uint16_t byte2, int byteSize){
  304. uint8_t data_to_send[] = {(uint8_t)addr, funcode, byteNum, (uint8_t)(byte1 >> 8), (uint8_t)(byte1 & 0xFF), (uint8_t)(byte2 >> 8), \
  305. (uint8_t)(byte2 & 0xFF), 0x00, 0x00};
  306. uint16_t CRC_value = calculate_crc(data_to_send, (byteSize - 2));
  307. data_to_send[(byteSize - 2)] = (uint8_t)(CRC_value & 0xFF);
  308. data_to_send[(byteSize - 1)] = (uint8_t)(CRC_value >> 8);
  309. HAL_UART_Transmit(&huart1, data_to_send, byteSize, (byteSize - 1));
  310. clear_buf();
  311. re_receive();
  312. }
  313. void receive_modbus_11(uint16_t addr, uint8_t funcode, uint8_t byteNum, uint16_t byte1, uint16_t byte2, uint16_t byte3, int byteSize){
  314. uint8_t data_to_send[] = {(uint8_t)addr, funcode, byteNum, (uint8_t)(byte1 >> 8), (uint8_t)(byte1 & 0xFF), (uint8_t)(byte2 >> 8), \
  315. (uint8_t)(byte2 & 0xFF), (uint8_t)(byte3 >> 8), (uint8_t)(byte3 & 0xFF), 0x00, 0x00};
  316. uint16_t CRC_value = calculate_crc(data_to_send, (byteSize - 2));
  317. data_to_send[(byteSize - 2)] = (uint8_t)(CRC_value & 0xFF);
  318. data_to_send[(byteSize - 1)] = (uint8_t)(CRC_value >> 8);
  319. HAL_UART_Transmit(&huart1, data_to_send, byteSize, (byteSize - 1));
  320. clear_buf();
  321. re_receive();
  322. }
  323. void receive_modbus_13(uint16_t addr, uint8_t funcode, uint8_t byteNum, uint16_t byte1, uint16_t byte2, uint16_t byte3, uint16_t byte4, int byteSize){
  324. uint8_t data_to_send[] = {(uint8_t)addr, funcode, byteNum, (uint8_t)(byte1 >> 8), (uint8_t)(byte1 & 0xFF), (uint8_t)(byte2 >> 8), \
  325. (uint8_t)(byte2 & 0xFF), (uint8_t)(byte3 >> 8), (uint8_t)(byte3 & 0xFF), (uint8_t)(byte4 >> 8), (uint8_t)(byte4 & 0xFF), 0x00, 0x00};
  326. uint16_t CRC_value = calculate_crc(data_to_send, (byteSize - 2));
  327. data_to_send[(byteSize - 2)] = (uint8_t)(CRC_value & 0xFF);
  328. data_to_send[(byteSize - 1)] = (uint8_t)(CRC_value >> 8);
  329. HAL_UART_Transmit(&huart1, data_to_send, byteSize, (byteSize - 1));
  330. clear_buf();
  331. re_receive();
  332. }
  333. void receive_modbus_15(uint16_t addr, uint8_t funcode, uint8_t byteNum, uint16_t byte1, uint16_t byte2, uint16_t byte3, uint16_t byte4, uint16_t byte5, int byteSize){
  334. uint8_t data_to_send[] = {(uint8_t)addr, funcode, byteNum, (uint8_t)(byte1 >> 8), (uint8_t)(byte1 & 0xFF), (uint8_t)(byte2 >> 8), \
  335. (uint8_t)(byte2 & 0xFF), (uint8_t)(byte3 >> 8), (uint8_t)(byte3 & 0xFF), (uint8_t)(byte4 >> 8), (uint8_t)(byte4 & 0xFF), (uint8_t)(byte5 >> 8),\
  336. (uint8_t)(byte5 & 0xFF), 0x00, 0x00};
  337. uint16_t CRC_value = calculate_crc(data_to_send, (byteSize - 2));
  338. data_to_send[(byteSize - 2)] = (uint8_t)(CRC_value & 0xFF);
  339. data_to_send[(byteSize - 1)] = (uint8_t)(CRC_value >> 8);
  340. HAL_UART_Transmit(&huart1, data_to_send, byteSize, (byteSize - 1));
  341. clear_buf();
  342. re_receive();
  343. }
  344. void ModBus(void) {
  345. if (USART_MODBUS_FLAG == 1 && (calculate_crc(USART_MODBUS_RX,6) == (USART_MODBUS_RX[7] << 8 | USART_MODBUS_RX[6])) && USART_PUB_LENGTH < 10) {
  346. if(USART_MODBUS_RX[0] == (uint8_t)initial_address && USART_MODBUS_RX[1] == 0x03 && USART_MODBUS_RX[2] == 0x00 \
  347. && USART_MODBUS_RX[3] == 0x01 && USART_MODBUS_RX[4] == 0x00 && USART_MODBUS_RX[5] == 0x01){
  348. receive_modbus_7(initial_address, 0x03, 0x02, gpioaStatus, 7);
  349. }
  350. else if(USART_MODBUS_RX[0] == (uint8_t)initial_address && USART_MODBUS_RX[1] == 0x03 && USART_MODBUS_RX[2] == 0x00 \
  351. && USART_MODBUS_RX[3] == 0x02 && USART_MODBUS_RX[4] == 0x00 && USART_MODBUS_RX[5] == 0x01){
  352. receive_modbus_7(initial_address, 0x03, 0x02, gpiobStatus, 7);
  353. }
  354. else if(USART_MODBUS_RX[0] == (uint8_t)initial_address && USART_MODBUS_RX[1] == 0x03 && USART_MODBUS_RX[2] == 0x00 \
  355. && USART_MODBUS_RX[3] == 0x03 && USART_MODBUS_RX[4] == 0x00 && USART_MODBUS_RX[5] == 0x01){
  356. receive_modbus_7(initial_address, 0x03, 0x02, adc2_filtered, 7);
  357. }
  358. else if(USART_MODBUS_RX[0] == (uint8_t)initial_address && USART_MODBUS_RX[1] == 0x03 && USART_MODBUS_RX[2] == 0x00 \
  359. && USART_MODBUS_RX[3] == 0x04 && USART_MODBUS_RX[4] == 0x00 && USART_MODBUS_RX[5] == 0x01){
  360. receive_modbus_7(initial_address, 0x03, 0x02, adc3_filtered, 7);
  361. }
  362. else if(USART_MODBUS_RX[0] == (uint8_t)initial_address && USART_MODBUS_RX[1] == 0x03 && USART_MODBUS_RX[2] == 0x00 \
  363. && USART_MODBUS_RX[3] == 0x05 && USART_MODBUS_RX[4] == 0x00 && USART_MODBUS_RX[5] == 0x01){
  364. receive_modbus_7(initial_address, 0x03, 0x02, adc1_filtered, 7);
  365. }
  366. else if(USART_MODBUS_RX[0] == (uint8_t)initial_address && USART_MODBUS_RX[1] == 0x03 && USART_MODBUS_RX[2] == 0x00 \
  367. && USART_MODBUS_RX[3] == 0x01 && USART_MODBUS_RX[4] == 0x00 && USART_MODBUS_RX[5] == 0x02){
  368. receive_modbus_9(initial_address, 0x03, 0x04, gpioaStatus, gpiobStatus, 9);
  369. }
  370. else if(USART_MODBUS_RX[0] == (uint8_t)initial_address && USART_MODBUS_RX[1] == 0x03 && USART_MODBUS_RX[2] == 0x00 \
  371. && USART_MODBUS_RX[3] == 0x01 && USART_MODBUS_RX[4] == 0x00 && USART_MODBUS_RX[5] == 0x03){
  372. receive_modbus_11(initial_address, 0x03, 0x06, gpioaStatus, gpiobStatus, adc2_filtered, 11);
  373. }
  374. else if(USART_MODBUS_RX[0] == (uint8_t)initial_address && USART_MODBUS_RX[1] == 0x03 && USART_MODBUS_RX[2] == 0x00 \
  375. && USART_MODBUS_RX[3] == 0x01 && USART_MODBUS_RX[4] == 0x00 && USART_MODBUS_RX[5] == 0x04){
  376. receive_modbus_13(initial_address, 0x03, 0x08, gpioaStatus, gpiobStatus, adc2_filtered, adc3_filtered, 13);
  377. }
  378. else if(USART_MODBUS_RX[0] == (uint8_t)initial_address && USART_MODBUS_RX[1] == 0x03 && USART_MODBUS_RX[2] == 0x00 \
  379. && USART_MODBUS_RX[3] == 0x01 && USART_MODBUS_RX[4] == 0x00 && USART_MODBUS_RX[5] == 0x05){
  380. receive_modbus_15(initial_address, 0x03, 0x0A, gpioaStatus, gpiobStatus, adc2_filtered, adc3_filtered, adc1_filtered, 15);
  381. }
  382. else if(USART_MODBUS_RX[0] == (uint8_t)initial_address && USART_MODBUS_RX[1] == 0x03 && USART_MODBUS_RX[2] == 0x00 \
  383. && USART_MODBUS_RX[3] == 0x02 && USART_MODBUS_RX[4] == 0x00 && USART_MODBUS_RX[5] == 0x02){
  384. receive_modbus_9(initial_address, 0x03, 0x04, gpiobStatus, adc2_filtered, 9);
  385. }
  386. else if(USART_MODBUS_RX[0] == (uint8_t)initial_address && USART_MODBUS_RX[1] == 0x03 && USART_MODBUS_RX[2] == 0x00 \
  387. && USART_MODBUS_RX[3] == 0x02 && USART_MODBUS_RX[4] == 0x00 && USART_MODBUS_RX[5] == 0x03){
  388. receive_modbus_11(initial_address, 0x03, 0x06, gpiobStatus, adc2_filtered, adc3_filtered, 11);
  389. }
  390. else if(USART_MODBUS_RX[0] == (uint8_t)initial_address && USART_MODBUS_RX[1] == 0x03 && USART_MODBUS_RX[2] == 0x00 \
  391. && USART_MODBUS_RX[3] == 0x02 && USART_MODBUS_RX[4] == 0x00 && USART_MODBUS_RX[5] == 0x04){
  392. receive_modbus_13(initial_address, 0x03, 0x08, gpiobStatus, adc2_filtered, adc3_filtered, adc1_filtered, 13);
  393. }
  394. else if(USART_MODBUS_RX[0] == (uint8_t)initial_address && USART_MODBUS_RX[1] == 0x03 && USART_MODBUS_RX[2] == 0x00 \
  395. && USART_MODBUS_RX[3] == 0x03 && USART_MODBUS_RX[4] == 0x00 && USART_MODBUS_RX[5] == 0x02){
  396. receive_modbus_9(initial_address, 0x03, 0x04, adc2_filtered, adc3_filtered, 9);
  397. }
  398. else if(USART_MODBUS_RX[0] == (uint8_t)initial_address && USART_MODBUS_RX[1] == 0x03 && USART_MODBUS_RX[2] == 0x00 \
  399. && USART_MODBUS_RX[3] == 0x03 && USART_MODBUS_RX[4] == 0x00 && USART_MODBUS_RX[5] == 0x03){
  400. receive_modbus_11(initial_address, 0x03, 0x06, adc2_filtered, adc3_filtered, adc1_filtered, 11);
  401. }
  402. else if(USART_MODBUS_RX[0] == (uint8_t)initial_address && USART_MODBUS_RX[1] == 0x03 && USART_MODBUS_RX[2] == 0x00 \
  403. && USART_MODBUS_RX[3] == 0x04 && USART_MODBUS_RX[4] == 0x00 && USART_MODBUS_RX[5] == 0x02){
  404. receive_modbus_9(initial_address, 0x03, 0x04, adc3_filtered, adc1_filtered, 9);
  405. }
  406. else if(USART_MODBUS_RX[0] == 0xFA && USART_MODBUS_RX[1] == 0x03 && USART_MODBUS_RX[2] == 0x00 && USART_MODBUS_RX[3] == 0xAA \
  407. && USART_MODBUS_RX[4] == 0x00 && USART_MODBUS_RX[5] == 0x01){
  408. receive_modbus_7(0xFA, 0x03, 0x02, initial_address, 7);
  409. }
  410. else if(USART_MODBUS_RX[0] == (uint8_t)initial_address && USART_MODBUS_RX[1] == 0x03 && USART_MODBUS_RX[2] == 0x50 \
  411. && USART_MODBUS_RX[3] == 0x00 && USART_MODBUS_RX[4] == 0x00 && USART_MODBUS_RX[5] == 0x02){
  412. receive_modbus_9(initial_address, 0x03, 0x04, ((System_version >> 16) & 0xFFFF), (System_version & 0xFFFF), 9);
  413. }
  414. else if(USART_MODBUS_RX[0] == (uint8_t)initial_address && USART_MODBUS_RX[1] == 0x03 && USART_MODBUS_RX[2] == 0x50 \
  415. && USART_MODBUS_RX[3] == 0x02 && USART_MODBUS_RX[4] == 0x00 && USART_MODBUS_RX[5] == 0x02){//断点地址
  416. updatecuraddr(CURaddr_PACKAGE_ADDR);
  417. receive_modbus_9(initial_address, 0x03, 0x04, ((nowcurAddr1 >> 16) & 0xFFFF), (nowcurAddr1 & 0xFFFF), 9);
  418. addrIndex = (nowcurAddr1 & 0xFFFF) << 8 | (nowcurAddr1 & 0xFFFF);
  419. addrIndex-=128;
  420. AddrToWrite = nowcurAddr1 -128;
  421. }
  422. else if(USART_MODBUS_RX[0] == (uint8_t)initial_address && USART_MODBUS_RX[1] == 0x03 && USART_MODBUS_RX[2] == 0x50 \
  423. && USART_MODBUS_RX[3] == 0x04 && USART_MODBUS_RX[4] == 0x00 && USART_MODBUS_RX[5] == 0x01){//断点包索引
  424. updatecurpack(CURaddr_PACKAGE_ADDR);
  425. receive_modbus_7(initial_address, 0x03, 0x02, nowcurpack, 7);
  426. }
  427. else if(USART_MODBUS_RX[0] == (uint8_t)initial_address && USART_MODBUS_RX[1] == 0x03 && USART_MODBUS_RX[2] == 0x50 \
  428. && USART_MODBUS_RX[3] == 0x05 && USART_MODBUS_RX[4] == 0x00 && USART_MODBUS_RX[5] == 0x08){//断点包索引
  429. data_to_send[0] = (uint8_t)initial_address;
  430. data_to_send[1] = 0x03;
  431. data_to_send[2] = 0x10;
  432. for (int i = 0; i < 8; i++) {
  433. data_to_send[3 + i * 2] = (uint8_t)(iapbinMd5[i] >> 8); // 高位字节
  434. data_to_send[3 + i * 2 + 1] = (uint8_t)(iapbinMd5[i] & 0xFF); // 低位字节
  435. }
  436. uint16_t CRC_value = calculate_crc(data_to_send, 19);
  437. data_to_send[19] = (uint8_t)(CRC_value & 0xFF);
  438. data_to_send[20] = (uint8_t)(CRC_value >> 8);
  439. HAL_UART_Transmit(&huart1, data_to_send, 21, 25);
  440. clear_buf();
  441. re_receive();
  442. }
  443. else if(USART_MODBUS_RX[0] == (uint8_t)initial_address && USART_MODBUS_RX[1] == 0x06 && USART_MODBUS_RX[2] == 0x00 \
  444. && USART_MODBUS_RX[3] == 0x02 && USART_MODBUS_RX[4] == 0x00){
  445. updatePbStatus(USART_MODBUS_RX[5]);
  446. Write_Information(pbstatus_FLASH_ADDR, USART_MODBUS_RX, 5);
  447. receive_modbus_8(initial_address, USART_MODBUS_RX[1], ((uint16_t)USART_MODBUS_RX[2] << 8) | USART_MODBUS_RX[3], \
  448. ((uint16_t)USART_MODBUS_RX[4] << 8) | USART_MODBUS_RX[5]);
  449. }
  450. else if(USART_MODBUS_RX[0] == (uint8_t)initial_address && USART_MODBUS_RX[1] == 0x06 && USART_MODBUS_RX[2] == 0x00 \
  451. && USART_MODBUS_RX[3] == 0x0A && USART_MODBUS_RX[4] == 0x00 && USART_MODBUS_RX[5] == 0x01){
  452. Write_Information(ADC1_FLASH_ADDR, USART_MODBUS_RX, 0);
  453. receive_modbus_8(initial_address, USART_MODBUS_RX[1], ((uint16_t)USART_MODBUS_RX[2] << 8) | USART_MODBUS_RX[3], \
  454. ((uint16_t)USART_MODBUS_RX[4] << 8) | USART_MODBUS_RX[5]);
  455. }
  456. else if(USART_MODBUS_RX[0] == (uint8_t)initial_address && USART_MODBUS_RX[1] == 0x06 && USART_MODBUS_RX[2] == 0x00 \
  457. && USART_MODBUS_RX[3] == 0x0B && USART_MODBUS_RX[4] == 0x00 && USART_MODBUS_RX[5] == 0x01){
  458. Write_Information(ADC2_FLASH_ADDR, USART_MODBUS_RX, 0);
  459. receive_modbus_8(initial_address, USART_MODBUS_RX[1], ((uint16_t)USART_MODBUS_RX[2] << 8) | USART_MODBUS_RX[3], \
  460. ((uint16_t)USART_MODBUS_RX[4] << 8) | USART_MODBUS_RX[5]);
  461. }
  462. else if(USART_MODBUS_RX[0] == (uint8_t)initial_address && USART_MODBUS_RX[1] == 0x06 && USART_MODBUS_RX[2] == 0x00 \
  463. && USART_MODBUS_RX[3] == 0x0C && USART_MODBUS_RX[4] == 0x00){
  464. update_baudrate(USART_MODBUS_RX[5]);
  465. Write_Information(baudrate_FLASH_ADDR, USART_MODBUS_RX, 5);
  466. receive_modbus_8(initial_address, USART_MODBUS_RX[1], ((uint16_t)USART_MODBUS_RX[2] << 8) | USART_MODBUS_RX[3], \
  467. ((uint16_t)USART_MODBUS_RX[4] << 8) | USART_MODBUS_RX[5]);
  468. }
  469. else if(USART_MODBUS_RX[0] == (uint8_t)initial_address && USART_MODBUS_RX[1] == 0x06 && USART_MODBUS_RX[2] == 0x00 \
  470. && USART_MODBUS_RX[3] == 0xAA && USART_MODBUS_RX[4] == 0x00){
  471. Write_Information(addr_FLASH_ADDR, USART_MODBUS_RX, 5);
  472. receive_modbus_8(initial_address, USART_MODBUS_RX[1], ((uint16_t)USART_MODBUS_RX[2] << 8) | USART_MODBUS_RX[3], \
  473. ((uint16_t)USART_MODBUS_RX[4] << 8) | USART_MODBUS_RX[5]);
  474. }
  475. else if(USART_MODBUS_RX[0] == (uint8_t)initial_address && USART_MODBUS_RX[1] == 0x06 && USART_MODBUS_RX[2] == 0x00 \
  476. && USART_MODBUS_RX[3] == 0xCC && USART_MODBUS_RX[4] == 0xA5 && USART_MODBUS_RX[5] == 0x5A){
  477. clear_buf();
  478. HAL_NVIC_SystemReset();
  479. }
  480. else {
  481. clear_buf();
  482. re_receive();
  483. }
  484. }
  485. }
  486. /* USER CODE END 4 */
  487. /**
  488. * @brief Period elapsed callback in non blocking mode
  489. * @note This function is called when TIM3 interrupt took place, inside
  490. * HAL_TIM_IRQHandler(). It makes a direct call to HAL_IncTick() to increment
  491. * a global variable "uwTick" used as application time base.
  492. * @param htim : TIM handle
  493. * @retval None
  494. */
  495. void HAL_TIM_PeriodElapsedCallback(TIM_HandleTypeDef *htim)
  496. {
  497. /* USER CODE BEGIN Callback 0 */
  498. /* USER CODE END Callback 0 */
  499. if (htim->Instance == TIM3) {
  500. HAL_IncTick();
  501. }
  502. /* USER CODE BEGIN Callback 1 */
  503. /* USER CODE END Callback 1 */
  504. }
  505. /**
  506. * @brief This function is executed in case of error occurrence.
  507. * @retval None
  508. */
  509. void Error_Handler(void)
  510. {
  511. /* USER CODE BEGIN Error_Handler_Debug */
  512. /* User can add his own implementation to report the HAL error return state */
  513. __disable_irq();
  514. while (1)
  515. {
  516. }
  517. /* USER CODE END Error_Handler_Debug */
  518. }
  519. #ifdef USE_FULL_ASSERT
  520. /**
  521. * @brief Reports the name of the source file and the source line number
  522. * where the assert_param error has occurred.
  523. * @param file: pointer to the source file name
  524. * @param line: assert_param error line source number
  525. * @retval None
  526. */
  527. void assert_failed(uint8_t *file, uint32_t line)
  528. {
  529. /* USER CODE BEGIN 6 */
  530. /* User can add his own implementation to report the file name and line number,
  531. ex: printf("Wrong parameters value: file %s on line %d\r\n", file, line) */
  532. /* USER CODE END 6 */
  533. }
  534. #endif /* USE_FULL_ASSERT */