main.c 23 KB

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