main.c 25 KB

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