can.c 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254
  1. /* USER CODE BEGIN Header */
  2. /**
  3. ******************************************************************************
  4. * @file can.c
  5. * @brief This file provides code for the configuration
  6. * of the CAN instances.
  7. ******************************************************************************
  8. * @attention
  9. *
  10. * Copyright (c) 2025 STMicroelectronics.
  11. * All rights reserved.
  12. *
  13. * This software is licensed under terms that can be found in the LICENSE file
  14. * in the root directory of this software component.
  15. * If no LICENSE file comes with this software, it is provided AS-IS.
  16. *
  17. ******************************************************************************
  18. */
  19. /* USER CODE END Header */
  20. /* Includes ------------------------------------------------------------------*/
  21. #include "can.h"
  22. /* USER CODE BEGIN 0 */
  23. #include "UDS.h"
  24. CAN_TxHeaderTypeDef TxHeader; //发送
  25. CAN_RxHeaderTypeDef RxHeader; //接收
  26. /* USER CODE END 0 */
  27. CAN_HandleTypeDef hcan1;
  28. /* CAN1 init function */
  29. void MX_CAN1_Init(void)
  30. {
  31. /* USER CODE BEGIN CAN1_Init 0 */
  32. /* USER CODE END CAN1_Init 0 */
  33. /* USER CODE BEGIN CAN1_Init 1 */
  34. /* USER CODE END CAN1_Init 1 */
  35. hcan1.Instance = CAN1;
  36. // hcan1.Init.Prescaler = 12;//250k
  37. hcan1.Init.Prescaler = 6;//500k
  38. // hcan1.Init.Prescaler = 3;//1000k
  39. hcan1.Init.Mode = CAN_MODE_NORMAL;
  40. hcan1.Init.SyncJumpWidth = CAN_SJW_1TQ;
  41. hcan1.Init.TimeSeg1 = CAN_BS1_11TQ;
  42. hcan1.Init.TimeSeg2 = CAN_BS2_2TQ;
  43. hcan1.Init.TimeTriggeredMode = DISABLE;
  44. hcan1.Init.AutoBusOff = ENABLE;
  45. hcan1.Init.AutoWakeUp = ENABLE;
  46. hcan1.Init.AutoRetransmission = ENABLE;
  47. hcan1.Init.ReceiveFifoLocked = DISABLE;
  48. hcan1.Init.TransmitFifoPriority = DISABLE;
  49. if (HAL_CAN_Init(&hcan1) != HAL_OK)
  50. {
  51. Error_Handler();
  52. }
  53. /* USER CODE BEGIN CAN1_Init 2 */
  54. /* USER CODE END CAN1_Init 2 */
  55. }
  56. void HAL_CAN_MspInit(CAN_HandleTypeDef* canHandle)
  57. {
  58. GPIO_InitTypeDef GPIO_InitStruct = {0};
  59. if(canHandle->Instance==CAN1)
  60. {
  61. /* USER CODE BEGIN CAN1_MspInit 0 */
  62. /* USER CODE END CAN1_MspInit 0 */
  63. /* CAN1 clock enable */
  64. __HAL_RCC_CAN1_CLK_ENABLE();
  65. __HAL_RCC_GPIOB_CLK_ENABLE();
  66. /**CAN1 GPIO Configuration
  67. PB8 ------> CAN1_RX
  68. PB9 ------> CAN1_TX
  69. */
  70. GPIO_InitStruct.Pin = GPIO_PIN_8|GPIO_PIN_9;
  71. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  72. GPIO_InitStruct.Pull = GPIO_NOPULL;
  73. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_VERY_HIGH;
  74. GPIO_InitStruct.Alternate = GPIO_AF9_CAN1;
  75. HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
  76. /* CAN1 interrupt Init */
  77. HAL_NVIC_SetPriority(CAN1_RX0_IRQn, 0, 0);
  78. HAL_NVIC_EnableIRQ(CAN1_RX0_IRQn);
  79. /* USER CODE BEGIN CAN1_MspInit 1 */
  80. /* USER CODE END CAN1_MspInit 1 */
  81. }
  82. }
  83. void HAL_CAN_MspDeInit(CAN_HandleTypeDef* canHandle)
  84. {
  85. if(canHandle->Instance==CAN1)
  86. {
  87. /* USER CODE BEGIN CAN1_MspDeInit 0 */
  88. /* USER CODE END CAN1_MspDeInit 0 */
  89. /* Peripheral clock disable */
  90. __HAL_RCC_CAN1_CLK_DISABLE();
  91. /**CAN1 GPIO Configuration
  92. PB8 ------> CAN1_RX
  93. PB9 ------> CAN1_TX
  94. */
  95. HAL_GPIO_DeInit(GPIOB, GPIO_PIN_8|GPIO_PIN_9);
  96. /* CAN1 interrupt Deinit */
  97. HAL_NVIC_DisableIRQ(CAN1_RX0_IRQn);
  98. /* USER CODE BEGIN CAN1_MspDeInit 1 */
  99. /* USER CODE END CAN1_MspDeInit 1 */
  100. }
  101. }
  102. /* USER CODE BEGIN 1 */
  103. extern uint8_t app2_crc_flag;//crc校验成功标志位,成功后应答版本号位新的。
  104. uint16_t get_hardware_version(void) {
  105. return *(volatile uint16_t*)(0x08000188);
  106. }
  107. // 获取版本信息的函数
  108. uint32_t get_software_version(void) {
  109. if(*(volatile uint32_t*)0x0800C188 == 0xFFFFFFFF)
  110. {
  111. return *(volatile uint32_t*)0x08060188;
  112. }
  113. else
  114. {
  115. return *(volatile uint32_t*)0x0800C188;
  116. }
  117. }
  118. uint32_t get_publish_data(void) {
  119. if(*(volatile uint32_t*)(0x0800C188+4) == 0xFFFFFFFF)
  120. {
  121. return *(volatile uint32_t*)(0x08060188+4);
  122. }
  123. else
  124. {
  125. return *(volatile uint32_t*)(0x0800C188+4);
  126. }
  127. }
  128. void CAN_Filter_config(void)
  129. {
  130. CAN_FilterTypeDef sFilterConfig;
  131. /* 配置CAN过滤器 */
  132. sFilterConfig.FilterBank = 0; /* 过滤器0 */
  133. sFilterConfig.FilterMode = CAN_FILTERMODE_IDMASK;
  134. sFilterConfig.FilterScale = CAN_FILTERSCALE_32BIT;
  135. sFilterConfig.FilterIdHigh = 0x0000; /* 32位ID */
  136. sFilterConfig.FilterIdLow = 0x0000;
  137. sFilterConfig.FilterMaskIdHigh = 0x0000; /* 32位MASK */
  138. sFilterConfig.FilterMaskIdLow = 0x0000;
  139. sFilterConfig.FilterFIFOAssignment = CAN_FILTER_FIFO0; /* 过滤器0关联到FIFO0 */
  140. sFilterConfig.FilterActivation = CAN_FILTER_ENABLE; /* 激活滤波器0 */
  141. sFilterConfig.SlaveStartFilterBank = 14;
  142. /* 过滤器配置 */
  143. if (HAL_CAN_ConfigFilter(&hcan1, &sFilterConfig) != HAL_OK)
  144. {
  145. Error_Handler();
  146. }
  147. HAL_CAN_Start(&hcan1);//开启CAN
  148. HAL_CAN_ActivateNotification(&hcan1 ,CAN_IT_RX_FIFO0_MSG_PENDING);//开启CAN的中断
  149. }
  150. void CAN_SendData(uint8_t canCom, uint32_t mailbox, uint32_t messageId, uint8_t * data, uint32_t len)
  151. {
  152. uint32_t start_time = HAL_GetTick(); // 使用系统时间戳,更精确
  153. uint32_t TxMailbox = CAN_TX_MAILBOX0;
  154. TxHeader.StdId = messageId; /* 标准标识符 */
  155. TxHeader.ExtId = messageId; /* 扩展标识符(29位) */
  156. TxHeader.IDE = CAN_ID_EXT; /* 使用标准帧 or 扩展帧 */
  157. TxHeader.RTR = CAN_RTR_DATA; /* 数据帧 */
  158. if(len > 8)
  159. {
  160. len=8;
  161. }
  162. TxHeader.DLC = len;
  163. if (HAL_CAN_AddTxMessage(&hcan1 , &TxHeader, data, &TxMailbox) != HAL_OK) /* 发送消息 */
  164. {
  165. //return 1;
  166. }
  167. // 超时时间:100ms
  168. while (HAL_CAN_IsTxMessagePending(&hcan1, TxMailbox))
  169. {
  170. if (HAL_GetTick() - start_time > 100) // 100ms超时
  171. {
  172. HAL_CAN_AbortTxRequest(&hcan1, TxMailbox); /* 超时,直接中止邮箱的发送请求 */
  173. //return 1;
  174. }
  175. }
  176. //return 0;
  177. }
  178. /*CAN接收中断函数*/
  179. void HAL_CAN_RxFifo0MsgPendingCallback(CAN_HandleTypeDef *hcan){
  180. uint8_t RxData[8];
  181. if(hcan->Instance == CAN1){
  182. HAL_CAN_GetRxMessage(&hcan1, CAN_RX_FIFO0, &RxHeader, RxData);
  183. if (RxHeader.ExtId == 0x701 && RxHeader.IDE == CAN_ID_EXT) {
  184. can_rx_isr_i(0,RxHeader.ExtId,RxData, RxHeader.DLC);
  185. //can_rx_isr_i(0,,id,data,len);
  186. }
  187. //读取版本号
  188. if (RxHeader.ExtId == 0x21D && RxHeader.IDE == CAN_ID_EXT) {
  189. uint16_t hardware_version = get_hardware_version();
  190. uint16_t software_version;
  191. if(app2_crc_flag == 1)//crc校验成功标志位,成功后应答版本号位新的。
  192. {
  193. software_version = *(volatile uint32_t*)0x08060188;
  194. }
  195. else
  196. {
  197. software_version = *(volatile uint32_t*)0x0800C188;
  198. }
  199. uint32_t publish_data = get_publish_data();
  200. uint8_t version[8];
  201. version[0] = hardware_version >> 8;
  202. version[1] = hardware_version & 0xFF;
  203. version[2] = software_version >> 8;
  204. version[3] = software_version & 0xFF;
  205. version[4] = publish_data >> 24;
  206. version[5] = publish_data >> 16;
  207. version[6] = publish_data >> 8;
  208. version[7] = publish_data & 0xFF;
  209. CAN_SendData(1, 2, 0x21D, version,8);
  210. }
  211. }
  212. }
  213. /* USER CODE END 1 */