main.c 30 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757
  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 "adc.h"
  22. #include "dma.h"
  23. #include "tim.h"
  24. #include "usart.h"
  25. #include "gpio.h"
  26. /* Private includes ----------------------------------------------------------*/
  27. /* USER CODE BEGIN Includes */
  28. /* USER CODE END Includes */
  29. /* Private typedef -----------------------------------------------------------*/
  30. /* USER CODE BEGIN PTD */
  31. /* USER CODE END PTD */
  32. /* Private define ------------------------------------------------------------*/
  33. /* USER CODE BEGIN PD */
  34. /* USER CODE END PD */
  35. /* Private macro -------------------------------------------------------------*/
  36. /* USER CODE BEGIN PM */
  37. /* USER CODE END PM */
  38. /* Private variables ---------------------------------------------------------*/
  39. /* USER CODE BEGIN PV */
  40. int spr000;
  41. uint8_t data_to_send[50];
  42. uint16_t CRC_value = 0;
  43. uint16_t initial_address = 0x00C1;
  44. uint16_t BaudrateValue = 0x0000;
  45. uint16_t Adc2_CalibrationValue ;
  46. uint16_t Adc3_CalibrationValue ;
  47. uint32_t System_version = Version_sys;
  48. uint8_t Rx_Flag = 0;
  49. uint8_t gpioaStatus = 0;
  50. uint8_t gpiobStatus = 0;
  51. uint8_t bufMain[128] = {0};
  52. uint8_t Rx_Buf[Rx_Max] = {0};
  53. uint16_t Rx_Len = 0;
  54. /* USER CODE END PV */
  55. /* Private function prototypes -----------------------------------------------*/
  56. void SystemClock_Config(void);
  57. /* USER CODE BEGIN PFP */
  58. #ifdef iap_
  59. typedef struct _T2C_RemoteCaliData
  60. {
  61. uint16_t FrameHead; //帧头 0-1
  62. uint32_t AddrExtModule; //4字节扩展地址 2--5
  63. uint16_t FunctionCode; //功能码2字节 只能是0x0003、0x0006或者0x0010 6--7
  64. uint16_t AddrRegStart; //寄存器起始地址2字节:合法范围为0x0000~0xffff 8--9
  65. uint16_t NumberOfRegs; //数据个数2字节:最多读取0xffff字节;实际取决于终端限制,目前为256字节 10--11
  66. uint32_t ReserveData001; //保留字4字节 12--15
  67. uint8_t PayLoadData[44+32+32]; //有效载荷具体有三种:44,或者76字节,或者108字节;字节 16--59
  68. uint16_t ReserveData002; //保留字2字节 60--61
  69. uint16_t CheckSum; //校验2字节 62--63
  70. }sT2C_RemoteCaliDat;
  71. typedef struct{
  72. uint16_t USE_RKG; //控制器占用人孔盖总线
  73. uint16_t USE_XYF; //控制器占用卸油阀总线
  74. uint16_t KZQ_ErrorCnt; //校验错误计数
  75. uint16_t KZQ_Error; //控制器通信错误
  76. uint8_t sensor_addr; //操作的传感器地址
  77. uint8_t sensor_RW; //操作的传感器读写属性
  78. uint16_t sensor_reg; //操作的传感器寄存器地址,即功能码
  79. uint8_t sensor_datelen; //操作数据长度
  80. uint8_t data_buf[70]; //下发数据缓存
  81. }KZQ_Inf;
  82. #define ADDR_Is_In_ElecFence 0x05D0 // 1488 车是否在电子围栏内
  83. sT2C_RemoteCaliDat T2C_RemoteCaliDat001 =
  84. {
  85. 0x3901,
  86. 0x9551000,
  87. 0x0003,
  88. ADDR_Is_In_ElecFence,//0x0000,
  89. 0x0001, //操作的数据个数
  90. 0x55AA55AA, //保留字4字节
  91. {1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,\
  92. 25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44},
  93. 0x7788,//保留字2字节
  94. 0x99AA //校验2字节
  95. };
  96. sT2C_RemoteCaliDat *pT2C_RemoteCaliData = &T2C_RemoteCaliDat001;
  97. uint8_t CMD_KZQ[256] =
  98. {0x39,0x01,0x95,0x50,0x00,0x01,0x00,0x03,
  99. 0x00,0x00,0x00,0x00,0x95,0x05,0xAA,0xAA,
  100. 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
  101. 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
  102. 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
  103. 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
  104. 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
  105. 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
  106. };
  107. int flagU2Rx=0;
  108. int data_lengthU2;
  109. uint8_t* ptx = CMD_KZQ;
  110. uint16_t ModbusCRC = 0;
  111. uint16_t SetSuccess = 0;
  112. uint16_t ModbusCRC1 = 0;
  113. uint16_t SetSuccess1 = 0;
  114. uint16_t SetSuccess2 = 0;
  115. uint16_t SetSuccess3 = 0;
  116. int i000;
  117. uint8_t* send_ptr;
  118. uint16_t send_len;
  119. uint32_t tmpU32;
  120. KZQ_Inf kzq_inf;
  121. KZQ_Inf* pkzq = &kzq_inf;
  122. uint8_t USART2_RX_BUF003[128];
  123. uint8_t F_STATE[70] = {0};
  124. uint8_t ptxCang01Temp[150];
  125. uint32_t KZQ_RTerror = 0;
  126. void RstCPU(void)
  127. {
  128. uint16_t j;
  129. __disable_irq();
  130. while(1)
  131. {
  132. __disable_irq();
  133. NVIC_SystemReset();
  134. while(j --)
  135. {
  136. __nop(); __nop(); __nop(); __nop();
  137. }
  138. }
  139. }
  140. #endif
  141. /* USER CODE END PFP */
  142. /* Private user code ---------------------------------------------------------*/
  143. /* USER CODE BEGIN 0 */
  144. /* USER CODE END 0 */
  145. /**
  146. * @brief The application entry point.
  147. * @retval int
  148. */
  149. int main(void)
  150. {
  151. /* USER CODE BEGIN 1 */
  152. #if IR_ROM1 == 0x08000000
  153. Start_BootLoader();
  154. #else
  155. SCB->VTOR = FLASH_BASE | ADD_UPDATE_PROG;
  156. __set_PRIMASK(0);
  157. #endif
  158. /* USER CODE END 1 */
  159. /* MCU Configuration--------------------------------------------------------*/
  160. /* Reset of all peripherals, Initializes the Flash interface and the Systick. */
  161. HAL_Init();
  162. /* USER CODE BEGIN Init */
  163. /* USER CODE END Init */
  164. /* Configure the system clock */
  165. SystemClock_Config();
  166. /* USER CODE BEGIN SysInit */
  167. /* USER CODE END SysInit */
  168. /* Initialize all configured peripherals */
  169. MX_GPIO_Init();
  170. MX_DMA_Init();
  171. MX_USART1_UART_Init();
  172. MX_ADC1_Init();
  173. MX_TIM2_Init();
  174. MX_USART3_UART_Init();
  175. /* USER CODE BEGIN 2 */
  176. HAL_TIM_Base_Start_IT(&htim2);
  177. read_new_address(ADDR_FLASH_PAGE_94);
  178. updatePbStatus(read_flash_16(ADDR_FLASH_PAGE_104));
  179. update_baudrate(read_flash_16(ADDR_FLASH_PAGE_114));
  180. AdcCalibration_init();
  181. spr000 = sprintf((char*)bufMain, "system reboot...");
  182. HAL_UART_Transmit(&huart1, bufMain, spr000, 300);
  183. HAL_UART_Receive_DMA(&huart1,USART2_RX_BUF,Uart2_BUF_SIZE);
  184. __HAL_UART_ENABLE_IT(&huart1, UART_IT_IDLE);
  185. /* USER CODE END 2 */
  186. /* Infinite loop */
  187. /* USER CODE BEGIN WHILE */
  188. while (1)
  189. {
  190. ModBus();
  191. #ifdef iap_
  192. if (flagU2Rx == 1) {
  193. flagU2Rx = 0;
  194. if ((data_lengthU2 > 300) || ((USART2_RX_BUF002[0] == 0xA5) && (USART2_RX_BUF002[1] == 0x5A)))
  195. {
  196. tmpU32 = (USART2_RX_BUF002[0] << 24) | (USART2_RX_BUF002[1] << 16) | (USART2_RX_BUF002[2] << 8) | (USART2_RX_BUF002[3]);
  197. if (StartBytes_IAP == tmpU32)
  198. {
  199. Process_CMD_IAP_Update();
  200. continue;
  201. }
  202. }
  203. }
  204. #endif
  205. HAL_GPIO_WritePin(GPIOB, GPIO_PIN_0, GPIO_PIN_SET);
  206. HAL_Delay(1);
  207. HAL_GPIO_WritePin(GPIOB, GPIO_PIN_0, GPIO_PIN_RESET);
  208. gpioaStatus = GetPaInputStatus();
  209. gpiobStatus = GetPbOutputStatus();
  210. GetADCResults(&hadc1);
  211. /* USER CODE END WHILE */
  212. /* USER CODE BEGIN 3 */
  213. }
  214. /* USER CODE END 3 */
  215. }
  216. /**
  217. * @brief System Clock Configuration
  218. * @retval None
  219. */
  220. void SystemClock_Config(void)
  221. {
  222. RCC_OscInitTypeDef RCC_OscInitStruct = {0};
  223. RCC_ClkInitTypeDef RCC_ClkInitStruct = {0};
  224. RCC_PeriphCLKInitTypeDef PeriphClkInit = {0};
  225. /** Initializes the RCC Oscillators according to the specified parameters
  226. * in the RCC_OscInitTypeDef structure.
  227. */
  228. RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSE;
  229. RCC_OscInitStruct.HSEState = RCC_HSE_ON;
  230. RCC_OscInitStruct.HSEPredivValue = RCC_HSE_PREDIV_DIV1;
  231. RCC_OscInitStruct.HSIState = RCC_HSI_ON;
  232. RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON;
  233. RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_HSE;
  234. RCC_OscInitStruct.PLL.PLLMUL = RCC_PLL_MUL9;
  235. if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK)
  236. {
  237. Error_Handler();
  238. }
  239. /** Initializes the CPU, AHB and APB buses clocks
  240. */
  241. RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK|RCC_CLOCKTYPE_SYSCLK
  242. |RCC_CLOCKTYPE_PCLK1|RCC_CLOCKTYPE_PCLK2;
  243. RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK;
  244. RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1;
  245. RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV2;
  246. RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV1;
  247. if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_2) != HAL_OK)
  248. {
  249. Error_Handler();
  250. }
  251. PeriphClkInit.PeriphClockSelection = RCC_PERIPHCLK_ADC;
  252. PeriphClkInit.AdcClockSelection = RCC_ADCPCLK2_DIV6;
  253. if (HAL_RCCEx_PeriphCLKConfig(&PeriphClkInit) != HAL_OK)
  254. {
  255. Error_Handler();
  256. }
  257. }
  258. /* USER CODE BEGIN 4 */
  259. uint16_t read_flash_16(uint32_t addr){
  260. uint16_t data = *(volatile uint16_t*)addr; // 从Flash中读取2个字节
  261. return data;
  262. }
  263. void read_new_address(uint32_t addr){
  264. uint16_t init_address = read_flash_16(addr);
  265. if(init_address == 0xFFFF) {
  266. initial_address = initial_address;
  267. } else {
  268. initial_address = init_address; // 读取新地址并赋值给initial_address
  269. }
  270. }
  271. void erase_flash(uint32_t ADDR_FLASH){ //进行擦除
  272. FLASH_EraseInitTypeDef erase_init;
  273. erase_init.TypeErase = FLASH_TYPEERASE_PAGES; // 擦除类型为页擦除
  274. erase_init.PageAddress = ADDR_FLASH;
  275. erase_init.NbPages = 1; // 擦除的页数
  276. uint32_t page_error = 0;
  277. HAL_FLASH_Unlock(); // 解锁Flash
  278. HAL_StatusTypeDef status = HAL_FLASHEx_Erase(&erase_init, &page_error); // 执行擦除操作
  279. HAL_FLASH_Lock(); // 上锁Flash
  280. if(status == HAL_OK){
  281. if(ADDR_FLASH == ADDR_FLASH_PAGE_94) {
  282. initial_address = 0; // 将initial_address清零
  283. }
  284. else if(ADDR_FLASH == ADDR_FLASH_PAGE_104) {
  285. gpiobStatus = 0; // 将pb_status清零
  286. }
  287. else if(ADDR_FLASH == ADDR_FLASH_PAGE_114) {
  288. BaudrateValue = 0xFFFF;
  289. }
  290. else if(ADDR_FLASH == ADDR_FLASH_PAGE_124) {
  291. Adc2_CalibrationValue = 0x0000; // 清零
  292. }
  293. else if(ADDR_FLASH == ADDR_FLASH_PAGE_134) {
  294. Adc3_CalibrationValue = 0x0000; // 清零
  295. }
  296. }
  297. }
  298. void Write_Information(uint32_t addr, uint8_t* rx_buffer, uint8_t buffer_index) {
  299. uint16_t newValue = 0;
  300. erase_flash(addr);
  301. HAL_FLASH_Unlock(); // 解锁Flash
  302. if (addr == ADDR_FLASH_PAGE_94) { // 写入地址到Flash
  303. newValue = rx_buffer[buffer_index];
  304. HAL_StatusTypeDef status = HAL_FLASH_Program(FLASH_TYPEPROGRAM_HALFWORD, ADDR_FLASH_PAGE_94, newValue);
  305. if (status == HAL_OK) {
  306. initial_address = newValue; // 将新地址赋值给initial_address
  307. }
  308. }
  309. else if (addr == ADDR_FLASH_PAGE_104) { // 写入PB状态到Flash
  310. newValue = rx_buffer[buffer_index];
  311. HAL_StatusTypeDef status = HAL_FLASH_Program(FLASH_TYPEPROGRAM_HALFWORD, ADDR_FLASH_PAGE_104, newValue);
  312. if (status == HAL_OK) {
  313. gpiobStatus = newValue; // 将新状态赋值给gpiobStatus
  314. }
  315. }
  316. else if (addr == ADDR_FLASH_PAGE_114) { // 写入波特率到Flash
  317. newValue = rx_buffer[buffer_index];
  318. HAL_StatusTypeDef status = HAL_FLASH_Program(FLASH_TYPEPROGRAM_HALFWORD, ADDR_FLASH_PAGE_114, newValue);
  319. if (status == HAL_OK) {
  320. BaudrateValue = newValue; // 将新状态赋值给BaudrateValue
  321. }
  322. }
  323. else if (addr == ADDR_FLASH_PAGE_124 || addr == ADDR_FLASH_PAGE_134) { // 写入ADC校准值到Flash
  324. uint16_t Standard_value = (0.6 / (3.3 / 4096));
  325. if (addr == ADDR_FLASH_PAGE_124) {
  326. if (adc2_rawValue >= Standard_value) {
  327. newValue = adc2_rawValue - Standard_value;
  328. } else {
  329. newValue = Standard_value - adc2_rawValue;
  330. newValue |= 0x8000;
  331. }
  332. HAL_StatusTypeDef status = HAL_FLASH_Program(FLASH_TYPEPROGRAM_HALFWORD, ADDR_FLASH_PAGE_124, newValue);
  333. if (status == HAL_OK) {
  334. Adc2_CalibrationValue = newValue & 0x7FFF;
  335. Value_old_addr2 = newValue;
  336. }
  337. } else if (addr == ADDR_FLASH_PAGE_134) {
  338. if (adc3_rawValue >= Standard_value) {
  339. newValue = adc3_rawValue - Standard_value;
  340. } else {
  341. newValue = Standard_value - adc3_rawValue;
  342. newValue |= 0x8000;
  343. }
  344. HAL_StatusTypeDef status = HAL_FLASH_Program(FLASH_TYPEPROGRAM_HALFWORD, ADDR_FLASH_PAGE_134, newValue);
  345. if (status == HAL_OK) {
  346. Adc3_CalibrationValue = newValue & 0x7FFF;
  347. Value_old_addr3 = newValue;
  348. }
  349. }
  350. }
  351. HAL_FLASH_Lock(); // 上锁Flash
  352. }
  353. void delay_sys_us(uint32_t Delay)//1个delay,大概1.5us
  354. {
  355. uint32_t cnt = Delay * 8;
  356. uint32_t i = 0;
  357. for(i = 0; i < cnt; i++)__NOP();
  358. }
  359. void ModBus(void) {
  360. if (Rx_Flag == 1 && (calculate_crc(Rx_Buf,6) == (Rx_Buf[7] << 8 | Rx_Buf[6])) && data_lengthU2 < 10) {
  361. if(Rx_Buf[0] == (uint8_t)initial_address && Rx_Buf[1] == 0x03 && Rx_Buf[2] == 0x00 && Rx_Buf[3] == 0x01 && Rx_Buf[4] == 0x00 && Rx_Buf[5] == 0x01){
  362. uint8_t data_to_send[] = {(uint8_t)initial_address, 0x03, 0x02, 0x00, gpioaStatus, 0x00, 0x00};
  363. uint16_t CRC_value = calculate_crc(data_to_send, 5);
  364. data_to_send[5] = (uint8_t)(CRC_value & 0xFF);
  365. data_to_send[6] = (uint8_t)(CRC_value >> 8);
  366. HAL_UART_Transmit(&huart1, data_to_send, 7, 6);
  367. memset(Rx_Buf, 0, sizeof(Rx_Buf));
  368. memset(USART2_RX_BUF, 0, Uart2_BUF_SIZE);
  369. Rx_Flag = 0;
  370. HAL_UART_AbortReceive(&huart1);
  371. HAL_UART_Receive_DMA(&huart1, USART2_RX_BUF, Uart2_BUF_SIZE);
  372. }
  373. else if(Rx_Buf[0] == (uint8_t)initial_address && Rx_Buf[1] == 0x03 && Rx_Buf[2] == 0x00 && Rx_Buf[3] == 0x02 && Rx_Buf[4] == 0x00 && Rx_Buf[5] == 0x01){
  374. uint8_t data_to_send[] = {(uint8_t)initial_address, 0x03, 0x02, 0x00, gpiobStatus, 0x00, 0x00};
  375. uint16_t CRC_value = calculate_crc(data_to_send, 5);
  376. data_to_send[5] = (uint8_t)(CRC_value & 0xFF);
  377. data_to_send[6] = (uint8_t)(CRC_value >> 8);
  378. HAL_UART_Transmit(&huart1, data_to_send, 7, 6);
  379. memset(Rx_Buf, 0, sizeof(Rx_Buf));
  380. memset(USART2_RX_BUF, 0, Uart2_BUF_SIZE);
  381. Rx_Flag = 0;
  382. HAL_UART_AbortReceive(&huart1);
  383. HAL_UART_Receive_DMA(&huart1, USART2_RX_BUF, Uart2_BUF_SIZE);
  384. }
  385. else if(Rx_Buf[0] == (uint8_t)initial_address && Rx_Buf[1] == 0x03 && Rx_Buf[2] == 0x00 && Rx_Buf[3] == 0x03 && Rx_Buf[4] == 0x00 && Rx_Buf[5] == 0x01){
  386. uint8_t data_to_send[] = {(uint8_t)initial_address, 0x03, 0x02, adc2_byte1, adc2_byte2, 0x00, 0x00};
  387. uint16_t CRC_value = calculate_crc(data_to_send, 5);
  388. data_to_send[5] = (uint8_t)(CRC_value & 0xFF);
  389. data_to_send[6] = (uint8_t)(CRC_value >> 8);
  390. HAL_UART_Transmit(&huart1, data_to_send, 7, 6);
  391. memset(Rx_Buf, 0, sizeof(Rx_Buf));
  392. memset(USART2_RX_BUF, 0, Uart2_BUF_SIZE);
  393. Rx_Flag = 0;
  394. HAL_UART_AbortReceive(&huart1);
  395. HAL_UART_Receive_DMA(&huart1, USART2_RX_BUF, Uart2_BUF_SIZE);
  396. }
  397. else if(Rx_Buf[0] == (uint8_t)initial_address && Rx_Buf[1] == 0x03 && Rx_Buf[2] == 0x00 && Rx_Buf[3] == 0x04 && Rx_Buf[4] == 0x00 && Rx_Buf[5] == 0x01){
  398. uint8_t data_to_send[] = {(uint8_t)initial_address, 0x03, 0x02, adc3_byte1, adc3_byte2, 0x00, 0x00};
  399. uint16_t CRC_value = calculate_crc(data_to_send, 5);
  400. data_to_send[5] = (uint8_t)(CRC_value & 0xFF);
  401. data_to_send[6] = (uint8_t)(CRC_value >> 8);
  402. HAL_UART_Transmit(&huart1, data_to_send, 7, 6);
  403. memset(Rx_Buf, 0, sizeof(Rx_Buf));
  404. memset(USART2_RX_BUF, 0, Uart2_BUF_SIZE);
  405. Rx_Flag = 0;
  406. HAL_UART_AbortReceive(&huart1);
  407. HAL_UART_Receive_DMA(&huart1, USART2_RX_BUF, Uart2_BUF_SIZE);
  408. }
  409. else if(Rx_Buf[0] == (uint8_t)initial_address && Rx_Buf[1] == 0x03 && Rx_Buf[2] == 0x00 && Rx_Buf[3] == 0x05 && Rx_Buf[4] == 0x00 && Rx_Buf[5] == 0x01){
  410. uint8_t data_to_send[] = {(uint8_t)initial_address, 0x03, 0x02, adc1_byte1, adc1_byte2, 0x00, 0x00};
  411. uint16_t CRC_value = calculate_crc(data_to_send, 5);
  412. data_to_send[5] = (uint8_t)(CRC_value & 0xFF);
  413. data_to_send[6] = (uint8_t)(CRC_value >> 8);
  414. HAL_StatusTypeDef status = HAL_UART_Transmit(&huart1, data_to_send, 7, 6);
  415. memset(Rx_Buf, 0, sizeof(Rx_Buf));
  416. memset(USART2_RX_BUF, 0, Uart2_BUF_SIZE);
  417. Rx_Flag = 0;
  418. HAL_UART_AbortReceive(&huart1);
  419. HAL_UART_Receive_DMA(&huart1, USART2_RX_BUF, Uart2_BUF_SIZE);
  420. }
  421. else if(Rx_Buf[0] == (uint8_t)initial_address && Rx_Buf[1] == 0x03 && Rx_Buf[2] == 0x00 && Rx_Buf[3] == 0x01 && Rx_Buf[4] == 0x00 && Rx_Buf[5] == 0x02){
  422. uint8_t data_to_send[] = {(uint8_t)initial_address, 0x03, 0x04, 0x00, gpioaStatus, 0x00, gpiobStatus, 0x00, 0x00};
  423. uint16_t CRC_value = calculate_crc(data_to_send, 7);
  424. data_to_send[7] = (uint8_t)(CRC_value & 0xFF);
  425. data_to_send[8] = (uint8_t)(CRC_value >> 8);
  426. HAL_StatusTypeDef status = HAL_UART_Transmit(&huart1, data_to_send, 9, 8);
  427. memset(Rx_Buf, 0, sizeof(Rx_Buf));
  428. memset(USART2_RX_BUF, 0, Uart2_BUF_SIZE);
  429. Rx_Flag = 0;
  430. HAL_UART_AbortReceive(&huart1);
  431. HAL_UART_Receive_DMA(&huart1, USART2_RX_BUF, Uart2_BUF_SIZE);
  432. }
  433. else if(Rx_Buf[0] == (uint8_t)initial_address && Rx_Buf[1] == 0x03 && Rx_Buf[2] == 0x00 && Rx_Buf[3] == 0x01 && Rx_Buf[4] == 0x00 && Rx_Buf[5] == 0x03){
  434. uint8_t data_to_send[] = {(uint8_t)initial_address, 0x03, 0x06, 0x00, gpioaStatus, 0x00, gpiobStatus, adc2_byte1, adc2_byte2, 0x00, 0x00};
  435. uint16_t CRC_value = calculate_crc(data_to_send, 9);
  436. data_to_send[9] = (uint8_t)(CRC_value & 0xFF);
  437. data_to_send[10] = (uint8_t)(CRC_value >> 8);
  438. HAL_StatusTypeDef status = HAL_UART_Transmit(&huart1, data_to_send, 11, 10);
  439. memset(Rx_Buf, 0, sizeof(Rx_Buf));
  440. memset(USART2_RX_BUF, 0, Uart2_BUF_SIZE);
  441. Rx_Flag = 0;
  442. HAL_UART_AbortReceive(&huart1);
  443. HAL_UART_Receive_DMA(&huart1, USART2_RX_BUF, Uart2_BUF_SIZE);
  444. }
  445. else if(Rx_Buf[0] == (uint8_t)initial_address && Rx_Buf[1] == 0x03 && Rx_Buf[2] == 0x00 && Rx_Buf[3] == 0x01 && Rx_Buf[4] == 0x00 && Rx_Buf[5] == 0x04){
  446. uint8_t data_to_send[] = {(uint8_t)initial_address, 0x03, 0x08, 0x00, gpioaStatus, 0x00, gpiobStatus, adc2_byte1, adc2_byte2, adc3_byte1, adc3_byte2, 0x00, 0x00};
  447. uint16_t CRC_value = calculate_crc(data_to_send, 11);
  448. data_to_send[11] = (uint8_t)(CRC_value & 0xFF);
  449. data_to_send[12] = (uint8_t)(CRC_value >> 8);
  450. HAL_StatusTypeDef status = HAL_UART_Transmit(&huart1, data_to_send, 13, 12);
  451. memset(Rx_Buf, 0, sizeof(Rx_Buf));
  452. memset(USART2_RX_BUF, 0, Uart2_BUF_SIZE);
  453. Rx_Flag = 0;
  454. HAL_UART_AbortReceive(&huart1);
  455. HAL_UART_Receive_DMA(&huart1, USART2_RX_BUF, Uart2_BUF_SIZE);
  456. }
  457. else if(Rx_Buf[0] == (uint8_t)initial_address && Rx_Buf[1] == 0x03 && Rx_Buf[2] == 0x00 && Rx_Buf[3] == 0x01 && Rx_Buf[4] == 0x00 && Rx_Buf[5] == 0x05){
  458. uint8_t data_to_send[] = {(uint8_t)initial_address, 0x03, 0x0A, 0x00, gpioaStatus, 0x00, gpiobStatus, adc2_byte1, adc2_byte2, adc3_byte1, adc3_byte2, adc1_byte1, adc1_byte2, 0x00, 0x00};
  459. uint16_t CRC_value = calculate_crc(data_to_send, 13);
  460. data_to_send[13] = (uint8_t)(CRC_value & 0xFF);
  461. data_to_send[14] = (uint8_t)(CRC_value >> 8);
  462. HAL_StatusTypeDef status = HAL_UART_Transmit(&huart1, data_to_send, 15, 14);
  463. memset(Rx_Buf, 0, sizeof(Rx_Buf));
  464. memset(USART2_RX_BUF, 0, Uart2_BUF_SIZE);
  465. Rx_Flag = 0;
  466. HAL_UART_AbortReceive(&huart1);
  467. HAL_UART_Receive_DMA(&huart1, USART2_RX_BUF, Uart2_BUF_SIZE);
  468. }
  469. else if(Rx_Buf[0] == (uint8_t)initial_address && Rx_Buf[1] == 0x03 && Rx_Buf[2] == 0x00 && Rx_Buf[3] == 0x02 && Rx_Buf[4] == 0x00 && Rx_Buf[5] == 0x02){
  470. uint8_t data_to_send[] = {(uint8_t)initial_address, 0x03, 0x04, 0x00, gpiobStatus, adc2_byte1, adc2_byte2, 0x00, 0x00};
  471. uint16_t CRC_value = calculate_crc(data_to_send, 7);
  472. data_to_send[7] = (uint8_t)(CRC_value & 0xFF);
  473. data_to_send[8] = (uint8_t)(CRC_value >> 8);
  474. HAL_StatusTypeDef status = HAL_UART_Transmit(&huart1, data_to_send, 9, 8);
  475. memset(Rx_Buf, 0, sizeof(Rx_Buf));
  476. memset(USART2_RX_BUF, 0, Uart2_BUF_SIZE);
  477. Rx_Flag = 0;
  478. HAL_UART_AbortReceive(&huart1);
  479. HAL_UART_Receive_DMA(&huart1, USART2_RX_BUF, Uart2_BUF_SIZE);
  480. }
  481. else if(Rx_Buf[0] == (uint8_t)initial_address && Rx_Buf[1] == 0x03 && Rx_Buf[2] == 0x00 && Rx_Buf[3] == 0x02 && Rx_Buf[4] == 0x00 && Rx_Buf[5] == 0x03){
  482. uint8_t data_to_send[] = {(uint8_t)initial_address, 0x03, 0x06, 0x00, gpiobStatus, adc2_byte1, adc2_byte2, adc3_byte1, adc3_byte2, 0x00, 0x00};
  483. uint16_t CRC_value = calculate_crc(data_to_send, 9);
  484. data_to_send[9] = (uint8_t)(CRC_value & 0xFF);
  485. data_to_send[10] = (uint8_t)(CRC_value >> 8);
  486. HAL_StatusTypeDef status = HAL_UART_Transmit(&huart1, data_to_send, 11, 10);
  487. memset(Rx_Buf, 0, sizeof(Rx_Buf));
  488. memset(USART2_RX_BUF, 0, Uart2_BUF_SIZE);
  489. Rx_Flag = 0;
  490. HAL_UART_AbortReceive(&huart1);
  491. HAL_UART_Receive_DMA(&huart1, USART2_RX_BUF, Uart2_BUF_SIZE);
  492. }
  493. else if(Rx_Buf[0] == (uint8_t)initial_address && Rx_Buf[1] == 0x03 && Rx_Buf[2] == 0x00 && Rx_Buf[3] == 0x02 && Rx_Buf[4] == 0x00 && Rx_Buf[5] == 0x04){
  494. uint8_t data_to_send[] = {(uint8_t)initial_address, 0x03, 0x08, 0x00, gpiobStatus, adc2_byte1, adc2_byte2, adc3_byte1, adc3_byte2, adc1_byte1, adc1_byte2, 0x00, 0x00};
  495. uint16_t CRC_value = calculate_crc(data_to_send, 11);
  496. data_to_send[11] = (uint8_t)(CRC_value & 0xFF);
  497. data_to_send[12] = (uint8_t)(CRC_value >> 8);
  498. HAL_StatusTypeDef status = HAL_UART_Transmit(&huart1, data_to_send, 13, 12);
  499. memset(Rx_Buf, 0, sizeof(Rx_Buf));
  500. memset(USART2_RX_BUF, 0, Uart2_BUF_SIZE);
  501. Rx_Flag = 0;
  502. HAL_UART_AbortReceive(&huart1);
  503. HAL_UART_Receive_DMA(&huart1, USART2_RX_BUF, Uart2_BUF_SIZE);
  504. }
  505. else if(Rx_Buf[0] == (uint8_t)initial_address && Rx_Buf[1] == 0x03 && Rx_Buf[2] == 0x00 && Rx_Buf[3] == 0x03 && Rx_Buf[4] == 0x00 && Rx_Buf[5] == 0x02){
  506. uint8_t data_to_send[] = {(uint8_t)initial_address, 0x03, 0x04, adc2_byte1, adc2_byte2, adc3_byte1, adc3_byte2, 0x00, 0x00};
  507. uint16_t CRC_value = calculate_crc(data_to_send, 7);
  508. data_to_send[7] = (uint8_t)(CRC_value & 0xFF);
  509. data_to_send[8] = (uint8_t)(CRC_value >> 8);
  510. HAL_StatusTypeDef status = HAL_UART_Transmit(&huart1, data_to_send, 9, 8);
  511. memset(Rx_Buf, 0, sizeof(Rx_Buf));
  512. memset(USART2_RX_BUF, 0, Uart2_BUF_SIZE);
  513. Rx_Flag = 0;
  514. HAL_UART_AbortReceive(&huart1);
  515. HAL_UART_Receive_DMA(&huart1, USART2_RX_BUF, Uart2_BUF_SIZE);
  516. }
  517. else if(Rx_Buf[0] == (uint8_t)initial_address && Rx_Buf[1] == 0x03 && Rx_Buf[2] == 0x00 && Rx_Buf[3] == 0x03 && Rx_Buf[4] == 0x00 && Rx_Buf[5] == 0x03){
  518. uint8_t data_to_send[] = {(uint8_t)initial_address, 0x03, 0x06, adc2_byte1, adc2_byte2, adc3_byte1, adc3_byte2, adc1_byte1, adc1_byte2, 0x00, 0x00};
  519. uint16_t CRC_value = calculate_crc(data_to_send, 9);
  520. data_to_send[9] = (uint8_t)(CRC_value & 0xFF);
  521. data_to_send[10] = (uint8_t)(CRC_value >> 8);
  522. HAL_StatusTypeDef status = HAL_UART_Transmit(&huart1, data_to_send, 11, 10);
  523. memset(Rx_Buf, 0, sizeof(Rx_Buf));
  524. memset(USART2_RX_BUF, 0, Uart2_BUF_SIZE);
  525. Rx_Flag = 0;
  526. HAL_UART_AbortReceive(&huart1);
  527. HAL_UART_Receive_DMA(&huart1, USART2_RX_BUF, Uart2_BUF_SIZE);
  528. }
  529. else if(Rx_Buf[0] == (uint8_t)initial_address && Rx_Buf[1] == 0x03 && Rx_Buf[2] == 0x00 && Rx_Buf[3] == 0x04 && Rx_Buf[4] == 0x00 && Rx_Buf[5] == 0x02){
  530. uint8_t data_to_send[] = {(uint8_t)initial_address, 0x03, 0x04, adc3_byte1, adc3_byte2, adc1_byte1, adc1_byte2, 0x00, 0x00};
  531. uint16_t CRC_value = calculate_crc(data_to_send, 7);
  532. data_to_send[7] = (uint8_t)(CRC_value & 0xFF);
  533. data_to_send[8] = (uint8_t)(CRC_value >> 8);
  534. HAL_StatusTypeDef status = HAL_UART_Transmit(&huart1, data_to_send, 9, 8);
  535. memset(Rx_Buf, 0, sizeof(Rx_Buf));
  536. memset(USART2_RX_BUF, 0, Uart2_BUF_SIZE);
  537. Rx_Flag = 0;
  538. HAL_UART_AbortReceive(&huart1);
  539. HAL_UART_Receive_DMA(&huart1, USART2_RX_BUF, Uart2_BUF_SIZE);
  540. }
  541. else if(Rx_Buf[0] == 0xFA && Rx_Buf[1] == 0x03 && Rx_Buf[2] == 0x00 && Rx_Buf[3] == 0xAA && Rx_Buf[4] == 0x00 && Rx_Buf[5] == 0x01){
  542. uint8_t data_to_send[] = {0xFA, 0x03, 0x02, 0x00, (uint8_t)initial_address, 0x00, 0x00};
  543. uint16_t CRC_value = calculate_crc(data_to_send, 5);
  544. data_to_send[5] = (uint8_t)(CRC_value & 0xFF);
  545. data_to_send[6] = (uint8_t)(CRC_value >> 8);
  546. HAL_StatusTypeDef status = HAL_UART_Transmit(&huart1, data_to_send, 7, 6);
  547. memset(Rx_Buf, 0, sizeof(Rx_Buf));
  548. memset(USART2_RX_BUF, 0, Uart2_BUF_SIZE);
  549. Rx_Flag = 0;
  550. HAL_UART_AbortReceive(&huart1);
  551. HAL_UART_Receive_DMA(&huart1, USART2_RX_BUF, Uart2_BUF_SIZE);
  552. }
  553. else if(Rx_Buf[0] == (uint8_t)initial_address && Rx_Buf[1] == 0x03 && Rx_Buf[2] == 0x00 && Rx_Buf[3] == 0xBB && Rx_Buf[4] == 0x00 && Rx_Buf[5] == 0x02){
  554. uint8_t data_to_send[] = {(uint8_t)initial_address, 0x03, 0x04, (uint8_t)(System_version >> 24), (uint8_t)(System_version >> 16), (uint8_t)(System_version >> 8), (uint8_t)(System_version ), 0x00, 0x00};
  555. uint16_t CRC_value = calculate_crc(data_to_send, 7);
  556. data_to_send[7] = (uint8_t)(CRC_value & 0xFF);
  557. data_to_send[8] = (uint8_t)(CRC_value >> 8);
  558. HAL_StatusTypeDef status = HAL_UART_Transmit(&huart1, data_to_send, 9, 8);
  559. memset(Rx_Buf, 0, sizeof(Rx_Buf));
  560. memset(USART2_RX_BUF, 0, Uart2_BUF_SIZE);
  561. Rx_Flag = 0;
  562. HAL_UART_AbortReceive(&huart1);
  563. HAL_UART_Receive_DMA(&huart1, USART2_RX_BUF, Uart2_BUF_SIZE);
  564. }
  565. else if(Rx_Buf[0] == (uint8_t)initial_address && Rx_Buf[1] == 0x06 && Rx_Buf[2] == 0x00 && Rx_Buf[3] == 0x02 && Rx_Buf[4] == 0x00){
  566. updatePbStatus(Rx_Buf[5]);
  567. Write_Information(ADDR_FLASH_PAGE_104, Rx_Buf, 5); // 写入Flash
  568. uint8_t data_to_send[] = {(uint8_t)initial_address, 0x06, 0x02, 0x00, Rx_Buf[5], 0x00, 0x00};
  569. uint16_t CRC_value = calculate_crc(data_to_send, 5);
  570. data_to_send[5] = (uint8_t)(CRC_value & 0xFF);
  571. data_to_send[6] = (uint8_t)(CRC_value >> 8);
  572. HAL_StatusTypeDef status = HAL_UART_Transmit(&huart1, data_to_send, 7, 7);
  573. memset(Rx_Buf, 0, sizeof(Rx_Buf));
  574. memset(USART2_RX_BUF, 0, Uart2_BUF_SIZE);
  575. Rx_Flag = 0;
  576. HAL_UART_AbortReceive(&huart1);
  577. HAL_UART_Receive_DMA(&huart1, USART2_RX_BUF, Uart2_BUF_SIZE);
  578. }
  579. else if(Rx_Buf[0] == (uint8_t)initial_address && Rx_Buf[1] == 0x06 && Rx_Buf[2] == 0x00 && Rx_Buf[3] == 0x0A && Rx_Buf[4] == 0x00 && Rx_Buf[5] == 0x01){
  580. Write_Information(ADDR_FLASH_PAGE_124, Rx_Buf, 0);
  581. uint16_t now_calibrationValue = Adc2_CalibrationValue;
  582. uint8_t data_to_send[] = {(uint8_t)initial_address, 0x06, 0x02, (uint8_t)((now_calibrationValue >> 8) & 0xFF), (uint8_t)(now_calibrationValue & 0xFF), 0x00, 0x00};
  583. uint16_t CRC_value = calculate_crc(data_to_send, 5);
  584. data_to_send[5] = (uint8_t)(CRC_value & 0xFF);
  585. data_to_send[6] = (uint8_t)(CRC_value >> 8);
  586. HAL_StatusTypeDef status = HAL_UART_Transmit(&huart1, data_to_send, 7, 7);
  587. memset(Rx_Buf, 0, sizeof(Rx_Buf));
  588. memset(USART2_RX_BUF, 0, Uart2_BUF_SIZE);
  589. Rx_Flag = 0;
  590. HAL_UART_AbortReceive(&huart1);
  591. HAL_UART_Receive_DMA(&huart1, USART2_RX_BUF, Uart2_BUF_SIZE);
  592. }
  593. else if(Rx_Buf[0] == (uint8_t)initial_address && Rx_Buf[1] == 0x06 && Rx_Buf[2] == 0x00 && Rx_Buf[3] == 0x0B && Rx_Buf[4] == 0x00 && Rx_Buf[5] == 0x01){
  594. Write_Information(ADDR_FLASH_PAGE_134, Rx_Buf, 0);
  595. uint16_t now_calibrationValue = Adc3_CalibrationValue;
  596. uint8_t data_to_send[] = {(uint8_t)initial_address, 0x06, 0x02, (uint8_t)((now_calibrationValue >> 8) & 0xFF), (uint8_t)(now_calibrationValue & 0xFF), 0x00, 0x00};
  597. uint16_t CRC_value = calculate_crc(data_to_send, 5);
  598. data_to_send[5] = (uint8_t)(CRC_value & 0xFF);
  599. data_to_send[6] = (uint8_t)(CRC_value >> 8);
  600. HAL_StatusTypeDef status = HAL_UART_Transmit(&huart1, data_to_send, 7, 7);
  601. memset(Rx_Buf, 0, sizeof(Rx_Buf));
  602. memset(USART2_RX_BUF, 0, Uart2_BUF_SIZE);
  603. Rx_Flag = 0;
  604. HAL_UART_AbortReceive(&huart1);
  605. HAL_UART_Receive_DMA(&huart1, USART2_RX_BUF, Uart2_BUF_SIZE);
  606. }
  607. else if(Rx_Buf[0] == (uint8_t)initial_address && Rx_Buf[1] == 0x06 && Rx_Buf[2] == 0x00 && Rx_Buf[3] == 0x0C && Rx_Buf[4] == 0x00){
  608. update_baudrate(Rx_Buf[5]);
  609. Write_Information(ADDR_FLASH_PAGE_114, Rx_Buf, 5); // 写入Flash
  610. uint8_t data_to_send[] = {(uint8_t)initial_address, 0x06, 0x00, 0x0C, 0x00, Rx_Buf[5], 0x00, 0x00};
  611. uint16_t CRC_value = calculate_crc(data_to_send, 6);
  612. data_to_send[6] = (uint8_t)(CRC_value & 0xFF);
  613. data_to_send[7] = (uint8_t)(CRC_value >> 8);
  614. HAL_StatusTypeDef status = HAL_UART_Transmit(&huart1, data_to_send, 8, 8);
  615. memset(Rx_Buf, 0, sizeof(Rx_Buf));
  616. memset(USART2_RX_BUF, 0, Uart2_BUF_SIZE);
  617. Rx_Flag = 0;
  618. HAL_UART_AbortReceive(&huart1);
  619. HAL_UART_Receive_DMA(&huart1, USART2_RX_BUF, Uart2_BUF_SIZE);
  620. }
  621. else if(Rx_Buf[0] == (uint8_t)initial_address && Rx_Buf[1] == 0x06 && Rx_Buf[2] == 0x00 && Rx_Buf[3] == 0xAA && Rx_Buf[4] == 0x00){
  622. Write_Information(ADDR_FLASH_PAGE_94, Rx_Buf, 5); // 写入Flash
  623. uint8_t data_to_send[] = {(uint8_t)initial_address, 0x06, 0x02, 0x00, (uint8_t)initial_address, 0x00, 0x00};
  624. uint16_t CRC_value = calculate_crc(data_to_send, 5);
  625. data_to_send[5] = (uint8_t)(CRC_value & 0xFF);
  626. data_to_send[6] = (uint8_t)(CRC_value >> 8);
  627. HAL_StatusTypeDef status = HAL_UART_Transmit(&huart1, data_to_send, 7, 7);
  628. memset(Rx_Buf, 0, sizeof(Rx_Buf));
  629. memset(USART2_RX_BUF, 0, Uart2_BUF_SIZE);
  630. Rx_Flag = 0;
  631. HAL_UART_AbortReceive(&huart1);
  632. HAL_UART_Receive_DMA(&huart1, USART2_RX_BUF, Uart2_BUF_SIZE);
  633. }
  634. else if(Rx_Buf[0] == (uint8_t)initial_address && Rx_Buf[1] == 0x06 && Rx_Buf[2] == 0x00 && Rx_Buf[3] == 0xCC && Rx_Buf[4] == 0xA5 && Rx_Buf[5] == 0x5A){
  635. Rx_Flag = 0; // 将标志位重新置为0
  636. memset(Rx_Buf,0,sizeof(Rx_Buf));
  637. memset(USART2_RX_BUF, 0, Uart2_BUF_SIZE);
  638. HAL_NVIC_SystemReset();
  639. }
  640. else {
  641. memset(Rx_Buf, 0, sizeof(Rx_Buf));
  642. memset(USART2_RX_BUF, 0, Uart2_BUF_SIZE);
  643. Rx_Flag = 0;
  644. HAL_UART_AbortReceive(&huart1);
  645. HAL_UART_Receive_DMA(&huart1, USART2_RX_BUF, Uart2_BUF_SIZE);
  646. }
  647. }
  648. }
  649. /* USER CODE END 4 */
  650. /**
  651. * @brief This function is executed in case of error occurrence.
  652. * @retval None
  653. */
  654. void Error_Handler(void)
  655. {
  656. /* USER CODE BEGIN Error_Handler_Debug */
  657. /* User can add his own implementation to report the HAL error return state */
  658. __disable_irq();
  659. while (1)
  660. {
  661. }
  662. /* USER CODE END Error_Handler_Debug */
  663. }
  664. #ifdef USE_FULL_ASSERT
  665. /**
  666. * @brief Reports the name of the source file and the source line number
  667. * where the assert_param error has occurred.
  668. * @param file: pointer to the source file name
  669. * @param line: assert_param error line source number
  670. * @retval None
  671. */
  672. void assert_failed(uint8_t *file, uint32_t line)
  673. {
  674. /* USER CODE BEGIN 6 */
  675. /* User can add his own implementation to report the file name and line number,
  676. ex: printf("Wrong parameters value: file %s on line %d\r\n", file, line) */
  677. /* USER CODE END 6 */
  678. }
  679. #endif /* USE_FULL_ASSERT */