main.c 23 KB

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