main.c 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460
  1. /* USER CODE BEGIN Header */
  2. /**
  3. ******************************************************************************
  4. * @file : main.c
  5. * @brief : Main program body
  6. ******************************************************************************
  7. * @attention
  8. *
  9. * <h2><center>&copy; Copyright (c) 2021 STMicroelectronics.
  10. * All rights reserved.</center></h2>
  11. *
  12. * This software component is licensed by ST under BSD 3-Clause license,
  13. * the "License"; You may not use this file except in compliance with the
  14. * License. You may obtain a copy of the License at:
  15. * opensource.org/licenses/BSD-3-Clause
  16. *
  17. ******************************************************************************
  18. */
  19. /* USER CODE END Header */
  20. /* Includes ------------------------------------------------------------------*/
  21. #include "main.h"
  22. /* Private includes ----------------------------------------------------------*/
  23. /* USER CODE BEGIN Includes */
  24. /* USER CODE END Includes */
  25. /* Private typedef -----------------------------------------------------------*/
  26. /* USER CODE BEGIN PTD */
  27. /* USER CODE END PTD */
  28. /* Private define ------------------------------------------------------------*/
  29. /* USER CODE BEGIN PD */
  30. /* USER CODE END PD */
  31. /* Private macro -------------------------------------------------------------*/
  32. /* USER CODE BEGIN PM */
  33. /* USER CODE END PM */
  34. /* Private variables ---------------------------------------------------------*/
  35. CAN_HandleTypeDef hcan;
  36. I2C_HandleTypeDef hi2c1;
  37. SPI_HandleTypeDef hspi1;
  38. UART_HandleTypeDef huart4;
  39. UART_HandleTypeDef huart1;
  40. /* USER CODE BEGIN PV */
  41. /* USER CODE END PV */
  42. /* Private function prototypes -----------------------------------------------*/
  43. void SystemClock_Config(void);
  44. static void MX_GPIO_Init(void);
  45. static void MX_I2C1_Init(void);
  46. static void MX_SPI1_Init(void);
  47. static void MX_USART1_UART_Init(void);
  48. static void MX_CAN_Init(void);
  49. static void MX_UART4_Init(void);
  50. /* USER CODE BEGIN PFP */
  51. /* USER CODE END PFP */
  52. /* Private user code ---------------------------------------------------------*/
  53. /* USER CODE BEGIN 0 */
  54. /* USER CODE END 0 */
  55. /**
  56. * @brief The application entry point.
  57. * @retval int
  58. */
  59. int main(void)
  60. {
  61. /* USER CODE BEGIN 1 */
  62. /* USER CODE END 1 */
  63. /* MCU Configuration--------------------------------------------------------*/
  64. /* Reset of all peripherals, Initializes the Flash interface and the Systick. */
  65. HAL_Init();
  66. /* USER CODE BEGIN Init */
  67. /* USER CODE END Init */
  68. /* Configure the system clock */
  69. SystemClock_Config();
  70. /* USER CODE BEGIN SysInit */
  71. /* USER CODE END SysInit */
  72. /* Initialize all configured peripherals */
  73. MX_GPIO_Init();
  74. MX_I2C1_Init();
  75. MX_SPI1_Init();
  76. MX_USART1_UART_Init();
  77. MX_CAN_Init();
  78. MX_UART4_Init();
  79. /* USER CODE BEGIN 2 */
  80. HAL_GPIO_WritePin(LD4_GPIO_Port, LD4_Pin, GPIO_PIN_SET);
  81. HAL_GPIO_WritePin(LD6_GPIO_Port, LD6_Pin, GPIO_PIN_SET);
  82. HAL_GPIO_WritePin(LD7_GPIO_Port, LD7_Pin, GPIO_PIN_SET);
  83. HAL_GPIO_WritePin(LD9_GPIO_Port, LD9_Pin, GPIO_PIN_SET);
  84. /* USER CODE END 2 */
  85. /* Infinite loop */
  86. /* USER CODE BEGIN WHILE */
  87. while (1)
  88. {
  89. /* USER CODE END WHILE */
  90. /* USER CODE BEGIN 3 */
  91. }
  92. /* USER CODE END 3 */
  93. }
  94. /**
  95. * @brief System Clock Configuration
  96. * @retval None
  97. */
  98. void SystemClock_Config(void)
  99. {
  100. RCC_OscInitTypeDef RCC_OscInitStruct = {0};
  101. RCC_ClkInitTypeDef RCC_ClkInitStruct = {0};
  102. RCC_PeriphCLKInitTypeDef PeriphClkInit = {0};
  103. /** Initializes the RCC Oscillators according to the specified parameters
  104. * in the RCC_OscInitTypeDef structure.
  105. */
  106. RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSI|RCC_OSCILLATORTYPE_HSE;
  107. RCC_OscInitStruct.HSEState = RCC_HSE_BYPASS;
  108. RCC_OscInitStruct.HSEPredivValue = RCC_HSE_PREDIV_DIV1;
  109. RCC_OscInitStruct.HSIState = RCC_HSI_ON;
  110. RCC_OscInitStruct.HSICalibrationValue = RCC_HSICALIBRATION_DEFAULT;
  111. RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON;
  112. RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_HSE;
  113. RCC_OscInitStruct.PLL.PLLMUL = RCC_PLL_MUL6;
  114. if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK)
  115. {
  116. Error_Handler();
  117. }
  118. /** Initializes the CPU, AHB and APB buses clocks
  119. */
  120. RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK|RCC_CLOCKTYPE_SYSCLK
  121. |RCC_CLOCKTYPE_PCLK1|RCC_CLOCKTYPE_PCLK2;
  122. RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK;
  123. RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1;
  124. RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV2;
  125. RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV1;
  126. if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_1) != HAL_OK)
  127. {
  128. Error_Handler();
  129. }
  130. PeriphClkInit.PeriphClockSelection = RCC_PERIPHCLK_USART1|RCC_PERIPHCLK_UART4
  131. |RCC_PERIPHCLK_I2C1;
  132. PeriphClkInit.Usart1ClockSelection = RCC_USART1CLKSOURCE_PCLK2;
  133. PeriphClkInit.Uart4ClockSelection = RCC_UART4CLKSOURCE_PCLK1;
  134. PeriphClkInit.I2c1ClockSelection = RCC_I2C1CLKSOURCE_HSI;
  135. if (HAL_RCCEx_PeriphCLKConfig(&PeriphClkInit) != HAL_OK)
  136. {
  137. Error_Handler();
  138. }
  139. }
  140. /**
  141. * @brief CAN Initialization Function
  142. * @param None
  143. * @retval None
  144. */
  145. static void MX_CAN_Init(void)
  146. {
  147. /* USER CODE BEGIN CAN_Init 0 */
  148. /* USER CODE END CAN_Init 0 */
  149. /* USER CODE BEGIN CAN_Init 1 */
  150. /* USER CODE END CAN_Init 1 */
  151. hcan.Instance = CAN;
  152. hcan.Init.Prescaler = 16;
  153. hcan.Init.Mode = CAN_MODE_NORMAL;
  154. hcan.Init.SyncJumpWidth = CAN_SJW_1TQ;
  155. hcan.Init.TimeSeg1 = CAN_BS1_1TQ;
  156. hcan.Init.TimeSeg2 = CAN_BS2_1TQ;
  157. hcan.Init.TimeTriggeredMode = DISABLE;
  158. hcan.Init.AutoBusOff = DISABLE;
  159. hcan.Init.AutoWakeUp = DISABLE;
  160. hcan.Init.AutoRetransmission = DISABLE;
  161. hcan.Init.ReceiveFifoLocked = DISABLE;
  162. hcan.Init.TransmitFifoPriority = DISABLE;
  163. if (HAL_CAN_Init(&hcan) != HAL_OK)
  164. {
  165. Error_Handler();
  166. }
  167. /* USER CODE BEGIN CAN_Init 2 */
  168. /* USER CODE END CAN_Init 2 */
  169. }
  170. /**
  171. * @brief I2C1 Initialization Function
  172. * @param None
  173. * @retval None
  174. */
  175. static void MX_I2C1_Init(void)
  176. {
  177. /* USER CODE BEGIN I2C1_Init 0 */
  178. /* USER CODE END I2C1_Init 0 */
  179. /* USER CODE BEGIN I2C1_Init 1 */
  180. /* USER CODE END I2C1_Init 1 */
  181. hi2c1.Instance = I2C1;
  182. hi2c1.Init.Timing = 0x2000090E;
  183. hi2c1.Init.OwnAddress1 = 0;
  184. hi2c1.Init.AddressingMode = I2C_ADDRESSINGMODE_7BIT;
  185. hi2c1.Init.DualAddressMode = I2C_DUALADDRESS_DISABLE;
  186. hi2c1.Init.OwnAddress2 = 0;
  187. hi2c1.Init.OwnAddress2Masks = I2C_OA2_NOMASK;
  188. hi2c1.Init.GeneralCallMode = I2C_GENERALCALL_DISABLE;
  189. hi2c1.Init.NoStretchMode = I2C_NOSTRETCH_DISABLE;
  190. if (HAL_I2C_Init(&hi2c1) != HAL_OK)
  191. {
  192. Error_Handler();
  193. }
  194. /** Configure Analogue filter
  195. */
  196. if (HAL_I2CEx_ConfigAnalogFilter(&hi2c1, I2C_ANALOGFILTER_ENABLE) != HAL_OK)
  197. {
  198. Error_Handler();
  199. }
  200. /** Configure Digital filter
  201. */
  202. if (HAL_I2CEx_ConfigDigitalFilter(&hi2c1, 0) != HAL_OK)
  203. {
  204. Error_Handler();
  205. }
  206. /* USER CODE BEGIN I2C1_Init 2 */
  207. /* USER CODE END I2C1_Init 2 */
  208. }
  209. /**
  210. * @brief SPI1 Initialization Function
  211. * @param None
  212. * @retval None
  213. */
  214. static void MX_SPI1_Init(void)
  215. {
  216. /* USER CODE BEGIN SPI1_Init 0 */
  217. /* USER CODE END SPI1_Init 0 */
  218. /* USER CODE BEGIN SPI1_Init 1 */
  219. /* USER CODE END SPI1_Init 1 */
  220. /* SPI1 parameter configuration*/
  221. hspi1.Instance = SPI1;
  222. hspi1.Init.Mode = SPI_MODE_MASTER;
  223. hspi1.Init.Direction = SPI_DIRECTION_2LINES;
  224. hspi1.Init.DataSize = SPI_DATASIZE_4BIT;
  225. hspi1.Init.CLKPolarity = SPI_POLARITY_LOW;
  226. hspi1.Init.CLKPhase = SPI_PHASE_1EDGE;
  227. hspi1.Init.NSS = SPI_NSS_SOFT;
  228. hspi1.Init.BaudRatePrescaler = SPI_BAUDRATEPRESCALER_4;
  229. hspi1.Init.FirstBit = SPI_FIRSTBIT_MSB;
  230. hspi1.Init.TIMode = SPI_TIMODE_DISABLE;
  231. hspi1.Init.CRCCalculation = SPI_CRCCALCULATION_DISABLE;
  232. hspi1.Init.CRCPolynomial = 7;
  233. hspi1.Init.CRCLength = SPI_CRC_LENGTH_DATASIZE;
  234. hspi1.Init.NSSPMode = SPI_NSS_PULSE_ENABLE;
  235. if (HAL_SPI_Init(&hspi1) != HAL_OK)
  236. {
  237. Error_Handler();
  238. }
  239. /* USER CODE BEGIN SPI1_Init 2 */
  240. /* USER CODE END SPI1_Init 2 */
  241. }
  242. /**
  243. * @brief UART4 Initialization Function
  244. * @param None
  245. * @retval None
  246. */
  247. static void MX_UART4_Init(void)
  248. {
  249. /* USER CODE BEGIN UART4_Init 0 */
  250. /* USER CODE END UART4_Init 0 */
  251. /* USER CODE BEGIN UART4_Init 1 */
  252. /* USER CODE END UART4_Init 1 */
  253. huart4.Instance = UART4;
  254. huart4.Init.BaudRate = 115200;
  255. huart4.Init.WordLength = UART_WORDLENGTH_8B;
  256. huart4.Init.StopBits = UART_STOPBITS_1;
  257. huart4.Init.Parity = UART_PARITY_NONE;
  258. huart4.Init.Mode = UART_MODE_TX_RX;
  259. huart4.Init.HwFlowCtl = UART_HWCONTROL_NONE;
  260. huart4.Init.OverSampling = UART_OVERSAMPLING_16;
  261. huart4.Init.OneBitSampling = UART_ONE_BIT_SAMPLE_DISABLE;
  262. huart4.AdvancedInit.AdvFeatureInit = UART_ADVFEATURE_NO_INIT;
  263. if (HAL_UART_Init(&huart4) != HAL_OK)
  264. {
  265. Error_Handler();
  266. }
  267. /* USER CODE BEGIN UART4_Init 2 */
  268. /* USER CODE END UART4_Init 2 */
  269. }
  270. /**
  271. * @brief USART1 Initialization Function
  272. * @param None
  273. * @retval None
  274. */
  275. static void MX_USART1_UART_Init(void)
  276. {
  277. /* USER CODE BEGIN USART1_Init 0 */
  278. /* USER CODE END USART1_Init 0 */
  279. /* USER CODE BEGIN USART1_Init 1 */
  280. /* USER CODE END USART1_Init 1 */
  281. huart1.Instance = USART1;
  282. huart1.Init.BaudRate = 115200;
  283. huart1.Init.WordLength = UART_WORDLENGTH_8B;
  284. huart1.Init.StopBits = UART_STOPBITS_1;
  285. huart1.Init.Parity = UART_PARITY_NONE;
  286. huart1.Init.Mode = UART_MODE_TX_RX;
  287. huart1.Init.HwFlowCtl = UART_HWCONTROL_NONE;
  288. huart1.Init.OverSampling = UART_OVERSAMPLING_16;
  289. huart1.Init.OneBitSampling = UART_ONE_BIT_SAMPLE_DISABLE;
  290. huart1.AdvancedInit.AdvFeatureInit = UART_ADVFEATURE_NO_INIT;
  291. if (HAL_UART_Init(&huart1) != HAL_OK)
  292. {
  293. Error_Handler();
  294. }
  295. /* USER CODE BEGIN USART1_Init 2 */
  296. /* USER CODE END USART1_Init 2 */
  297. }
  298. /**
  299. * @brief GPIO Initialization Function
  300. * @param None
  301. * @retval None
  302. */
  303. static void MX_GPIO_Init(void)
  304. {
  305. GPIO_InitTypeDef GPIO_InitStruct = {0};
  306. /* GPIO Ports Clock Enable */
  307. __HAL_RCC_GPIOE_CLK_ENABLE();
  308. __HAL_RCC_GPIOC_CLK_ENABLE();
  309. __HAL_RCC_GPIOF_CLK_ENABLE();
  310. __HAL_RCC_GPIOA_CLK_ENABLE();
  311. __HAL_RCC_GPIOB_CLK_ENABLE();
  312. /*Configure GPIO pin Output Level */
  313. HAL_GPIO_WritePin(GPIOE, CS_I2C_SPI_Pin|LD4_Pin|LD3_Pin|LD5_Pin
  314. |LD7_Pin|LD9_Pin|LD10_Pin|LD8_Pin
  315. |LD6_Pin, GPIO_PIN_RESET);
  316. /*Configure GPIO pins : DRDY_Pin MEMS_INT3_Pin MEMS_INT4_Pin MEMS_INT1_Pin
  317. MEMS_INT2_Pin */
  318. GPIO_InitStruct.Pin = DRDY_Pin|MEMS_INT3_Pin|MEMS_INT4_Pin|MEMS_INT1_Pin
  319. |MEMS_INT2_Pin;
  320. GPIO_InitStruct.Mode = GPIO_MODE_EVT_RISING;
  321. GPIO_InitStruct.Pull = GPIO_NOPULL;
  322. HAL_GPIO_Init(GPIOE, &GPIO_InitStruct);
  323. /*Configure GPIO pins : CS_I2C_SPI_Pin LD4_Pin LD3_Pin LD5_Pin
  324. LD7_Pin LD9_Pin LD10_Pin LD8_Pin
  325. LD6_Pin */
  326. GPIO_InitStruct.Pin = CS_I2C_SPI_Pin|LD4_Pin|LD3_Pin|LD5_Pin
  327. |LD7_Pin|LD9_Pin|LD10_Pin|LD8_Pin
  328. |LD6_Pin;
  329. GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
  330. GPIO_InitStruct.Pull = GPIO_NOPULL;
  331. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
  332. HAL_GPIO_Init(GPIOE, &GPIO_InitStruct);
  333. /*Configure GPIO pin : B1_Pin */
  334. GPIO_InitStruct.Pin = B1_Pin;
  335. GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
  336. GPIO_InitStruct.Pull = GPIO_NOPULL;
  337. HAL_GPIO_Init(B1_GPIO_Port, &GPIO_InitStruct);
  338. /*Configure GPIO pins : PA11 PA12 */
  339. GPIO_InitStruct.Pin = GPIO_PIN_11|GPIO_PIN_12;
  340. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  341. GPIO_InitStruct.Pull = GPIO_NOPULL;
  342. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
  343. GPIO_InitStruct.Alternate = GPIO_AF14_USB;
  344. HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
  345. }
  346. /* USER CODE BEGIN 4 */
  347. /* USER CODE END 4 */
  348. /**
  349. * @brief This function is executed in case of error occurrence.
  350. * @retval None
  351. */
  352. void Error_Handler(void)
  353. {
  354. /* USER CODE BEGIN Error_Handler_Debug */
  355. /* User can add his own implementation to report the HAL error return state */
  356. __disable_irq();
  357. while (1)
  358. {
  359. }
  360. /* USER CODE END Error_Handler_Debug */
  361. }
  362. #ifdef USE_FULL_ASSERT
  363. /**
  364. * @brief Reports the name of the source file and the source line number
  365. * where the assert_param error has occurred.
  366. * @param file: pointer to the source file name
  367. * @param line: assert_param error line source number
  368. * @retval None
  369. */
  370. void assert_failed(uint8_t *file, uint32_t line)
  371. {
  372. /* USER CODE BEGIN 6 */
  373. /* User can add his own implementation to report the file name and line number,
  374. ex: printf("Wrong parameters value: file %s on line %d\r\n", file, line) */
  375. /* USER CODE END 6 */
  376. }
  377. #endif /* USE_FULL_ASSERT */
  378. /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/