main.c 32 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201
  1. /* USER CODE BEGIN Header */
  2. /**
  3. ******************************************************************************
  4. * @file : main.c
  5. * @brief : Main program body
  6. ******************************************************************************
  7. ** This notice applies to any and all portions of this file
  8. * that are not between comment pairs USER CODE BEGIN and
  9. * USER CODE END. Other portions of this file, whether
  10. * inserted by the user or by software development tools
  11. * are owned by their respective copyright owners.
  12. *
  13. * COPYRIGHT(c) 2018 STMicroelectronics
  14. *
  15. * Redistribution and use in source and binary forms, with or without modification,
  16. * are permitted provided that the following conditions are met:
  17. * 1. Redistributions of source code must retain the above copyright notice,
  18. * this list of conditions and the following disclaimer.
  19. * 2. Redistributions in binary form must reproduce the above copyright notice,
  20. * this list of conditions and the following disclaimer in the documentation
  21. * and/or other materials provided with the distribution.
  22. * 3. Neither the name of STMicroelectronics nor the names of its contributors
  23. * may be used to endorse or promote products derived from this software
  24. * without specific prior written permission.
  25. *
  26. * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
  27. * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  28. * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
  29. * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
  30. * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  31. * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
  32. * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
  33. * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
  34. * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
  35. * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  36. *
  37. ******************************************************************************
  38. */
  39. /* USER CODE END Header */
  40. /* Includes ------------------------------------------------------------------*/
  41. #include "main.h"
  42. /* Private includes ----------------------------------------------------------*/
  43. /* USER CODE BEGIN Includes */
  44. /* USER CODE END Includes */
  45. /* Private typedef -----------------------------------------------------------*/
  46. /* USER CODE BEGIN PTD */
  47. /* USER CODE END PTD */
  48. /* Private define ------------------------------------------------------------*/
  49. /* USER CODE BEGIN PD */
  50. /* USER CODE END PD */
  51. /* Private macro -------------------------------------------------------------*/
  52. /* USER CODE BEGIN PM */
  53. /* USER CODE END PM */
  54. /* Private variables ---------------------------------------------------------*/
  55. ADC_HandleTypeDef hadc1;
  56. DAC_HandleTypeDef hdac1;
  57. IWDG_HandleTypeDef hiwdg;
  58. LPTIM_HandleTypeDef hlptim1;
  59. QSPI_HandleTypeDef hqspi;
  60. RTC_HandleTypeDef hrtc;
  61. SAI_HandleTypeDef hsai_BlockA1;
  62. SAI_HandleTypeDef hsai_BlockB1;
  63. SD_HandleTypeDef hsd1;
  64. SPI_HandleTypeDef hspi1;
  65. SPI_HandleTypeDef hspi2;
  66. SPI_HandleTypeDef hspi3;
  67. TIM_HandleTypeDef htim1;
  68. TIM_HandleTypeDef htim2;
  69. TIM_HandleTypeDef htim4;
  70. TIM_HandleTypeDef htim15;
  71. TIM_HandleTypeDef htim16;
  72. TIM_HandleTypeDef htim17;
  73. UART_HandleTypeDef huart1;
  74. UART_HandleTypeDef huart2;
  75. PCD_HandleTypeDef hpcd_USB_OTG_FS;
  76. /* USER CODE BEGIN PV */
  77. /* Private variables ---------------------------------------------------------*/
  78. /* USER CODE END PV */
  79. /* Private function prototypes -----------------------------------------------*/
  80. void SystemClock_Config(void);
  81. void PeriphCommonClock_Config(void);
  82. static void MX_GPIO_Init(void);
  83. static void MX_USART1_UART_Init(void);
  84. static void MX_USART2_UART_Init(void);
  85. static void MX_QUADSPI_Init(void);
  86. static void MX_SPI1_Init(void);
  87. static void MX_SPI2_Init(void);
  88. static void MX_RTC_Init(void);
  89. static void MX_ADC1_Init(void);
  90. static void MX_IWDG_Init(void);
  91. static void MX_TIM17_Init(void);
  92. static void MX_TIM16_Init(void);
  93. static void MX_TIM15_Init(void);
  94. static void MX_TIM4_Init(void);
  95. static void MX_TIM1_Init(void);
  96. static void MX_SAI1_Init(void);
  97. static void MX_SPI3_Init(void);
  98. static void MX_TIM2_Init(void);
  99. static void MX_USB_OTG_FS_PCD_Init(void);
  100. static void MX_LPTIM1_Init(void);
  101. static void MX_SDMMC1_SD_Init(void);
  102. static void MX_DAC1_Init(void);
  103. /* USER CODE BEGIN PFP */
  104. /* Private function prototypes -----------------------------------------------*/
  105. /* USER CODE END PFP */
  106. /* Private user code ---------------------------------------------------------*/
  107. /* USER CODE BEGIN 0 */
  108. /* USER CODE END 0 */
  109. /**
  110. * @brief The application entry point.
  111. * @retval int
  112. */
  113. int main(void)
  114. {
  115. /* USER CODE BEGIN 1 */
  116. /* USER CODE END 1 */
  117. /* MCU Configuration--------------------------------------------------------*/
  118. /* Reset of all peripherals, Initializes the Flash interface and the Systick. */
  119. HAL_Init();
  120. /* USER CODE BEGIN Init */
  121. /* USER CODE END Init */
  122. /* Configure the system clock */
  123. SystemClock_Config();
  124. /* Configure the peripherals common clocks */
  125. PeriphCommonClock_Config();
  126. /* USER CODE BEGIN SysInit */
  127. /* USER CODE END SysInit */
  128. /* Initialize all configured peripherals */
  129. MX_GPIO_Init();
  130. MX_USART1_UART_Init();
  131. MX_USART2_UART_Init();
  132. MX_QUADSPI_Init();
  133. MX_SPI1_Init();
  134. MX_SPI2_Init();
  135. MX_RTC_Init();
  136. MX_ADC1_Init();
  137. MX_IWDG_Init();
  138. MX_TIM17_Init();
  139. MX_TIM16_Init();
  140. MX_TIM15_Init();
  141. MX_TIM4_Init();
  142. MX_TIM1_Init();
  143. MX_SAI1_Init();
  144. MX_SPI3_Init();
  145. MX_TIM2_Init();
  146. MX_USB_OTG_FS_PCD_Init();
  147. MX_LPTIM1_Init();
  148. MX_SDMMC1_SD_Init();
  149. MX_DAC1_Init();
  150. /* USER CODE BEGIN 2 */
  151. /* USER CODE END 2 */
  152. /* Infinite loop */
  153. /* USER CODE BEGIN WHILE */
  154. while (1)
  155. {
  156. /* USER CODE END WHILE */
  157. /* USER CODE BEGIN 3 */
  158. }
  159. /* USER CODE END 3 */
  160. }
  161. /**
  162. * @brief System Clock Configuration
  163. * @retval None
  164. */
  165. void SystemClock_Config(void)
  166. {
  167. RCC_OscInitTypeDef RCC_OscInitStruct = {0};
  168. RCC_ClkInitTypeDef RCC_ClkInitStruct = {0};
  169. /** Configure the main internal regulator output voltage
  170. */
  171. if (HAL_PWREx_ControlVoltageScaling(PWR_REGULATOR_VOLTAGE_SCALE1) != HAL_OK)
  172. {
  173. Error_Handler();
  174. }
  175. /** Configure LSE Drive Capability
  176. */
  177. HAL_PWR_EnableBkUpAccess();
  178. __HAL_RCC_LSEDRIVE_CONFIG(RCC_LSEDRIVE_LOW);
  179. /** Initializes the RCC Oscillators according to the specified parameters
  180. * in the RCC_OscInitTypeDef structure.
  181. */
  182. RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_LSI|RCC_OSCILLATORTYPE_HSE
  183. |RCC_OSCILLATORTYPE_LSE;
  184. RCC_OscInitStruct.HSEState = RCC_HSE_ON;
  185. RCC_OscInitStruct.LSEState = RCC_LSE_ON;
  186. RCC_OscInitStruct.LSIState = RCC_LSI_ON;
  187. RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON;
  188. RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_HSE;
  189. RCC_OscInitStruct.PLL.PLLM = 1;
  190. RCC_OscInitStruct.PLL.PLLN = 20;
  191. RCC_OscInitStruct.PLL.PLLP = RCC_PLLP_DIV7;
  192. RCC_OscInitStruct.PLL.PLLQ = RCC_PLLQ_DIV2;
  193. RCC_OscInitStruct.PLL.PLLR = RCC_PLLR_DIV2;
  194. if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK)
  195. {
  196. Error_Handler();
  197. }
  198. /** Initializes the CPU, AHB and APB buses clocks
  199. */
  200. RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK|RCC_CLOCKTYPE_SYSCLK
  201. |RCC_CLOCKTYPE_PCLK1|RCC_CLOCKTYPE_PCLK2;
  202. RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK;
  203. RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1;
  204. RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV1;
  205. RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV1;
  206. if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_4) != HAL_OK)
  207. {
  208. Error_Handler();
  209. }
  210. }
  211. /**
  212. * @brief Peripherals Common Clock Configuration
  213. * @retval None
  214. */
  215. void PeriphCommonClock_Config(void)
  216. {
  217. RCC_PeriphCLKInitTypeDef PeriphClkInit = {0};
  218. /** Initializes the peripherals clock
  219. */
  220. PeriphClkInit.PeriphClockSelection = RCC_PERIPHCLK_SAI1|RCC_PERIPHCLK_USB
  221. |RCC_PERIPHCLK_SDMMC1|RCC_PERIPHCLK_ADC;
  222. PeriphClkInit.Sai1ClockSelection = RCC_SAI1CLKSOURCE_PLLSAI1;
  223. PeriphClkInit.AdcClockSelection = RCC_ADCCLKSOURCE_PLLSAI1;
  224. PeriphClkInit.UsbClockSelection = RCC_USBCLKSOURCE_PLLSAI1;
  225. PeriphClkInit.Sdmmc1ClockSelection = RCC_SDMMC1CLKSOURCE_PLLSAI1;
  226. PeriphClkInit.PLLSAI1.PLLSAI1Source = RCC_PLLSOURCE_HSE;
  227. PeriphClkInit.PLLSAI1.PLLSAI1M = 1;
  228. PeriphClkInit.PLLSAI1.PLLSAI1N = 12;
  229. PeriphClkInit.PLLSAI1.PLLSAI1P = RCC_PLLP_DIV7;
  230. PeriphClkInit.PLLSAI1.PLLSAI1Q = RCC_PLLQ_DIV2;
  231. PeriphClkInit.PLLSAI1.PLLSAI1R = RCC_PLLR_DIV2;
  232. PeriphClkInit.PLLSAI1.PLLSAI1ClockOut = RCC_PLLSAI1_SAI1CLK|RCC_PLLSAI1_48M2CLK
  233. |RCC_PLLSAI1_ADC1CLK;
  234. if (HAL_RCCEx_PeriphCLKConfig(&PeriphClkInit) != HAL_OK)
  235. {
  236. Error_Handler();
  237. }
  238. }
  239. /**
  240. * @brief ADC1 Initialization Function
  241. * @param None
  242. * @retval None
  243. */
  244. static void MX_ADC1_Init(void)
  245. {
  246. /* USER CODE BEGIN ADC1_Init 0 */
  247. /* USER CODE END ADC1_Init 0 */
  248. ADC_MultiModeTypeDef multimode = {0};
  249. ADC_ChannelConfTypeDef sConfig = {0};
  250. /* USER CODE BEGIN ADC1_Init 1 */
  251. /* USER CODE END ADC1_Init 1 */
  252. /** Common config
  253. */
  254. hadc1.Instance = ADC1;
  255. hadc1.Init.ClockPrescaler = ADC_CLOCK_ASYNC_DIV1;
  256. hadc1.Init.Resolution = ADC_RESOLUTION_12B;
  257. hadc1.Init.DataAlign = ADC_DATAALIGN_RIGHT;
  258. hadc1.Init.ScanConvMode = ADC_SCAN_DISABLE;
  259. hadc1.Init.EOCSelection = ADC_EOC_SINGLE_CONV;
  260. hadc1.Init.LowPowerAutoWait = DISABLE;
  261. hadc1.Init.ContinuousConvMode = DISABLE;
  262. hadc1.Init.NbrOfConversion = 1;
  263. hadc1.Init.DiscontinuousConvMode = DISABLE;
  264. hadc1.Init.ExternalTrigConv = ADC_SOFTWARE_START;
  265. hadc1.Init.ExternalTrigConvEdge = ADC_EXTERNALTRIGCONVEDGE_NONE;
  266. hadc1.Init.DMAContinuousRequests = DISABLE;
  267. hadc1.Init.Overrun = ADC_OVR_DATA_PRESERVED;
  268. hadc1.Init.OversamplingMode = DISABLE;
  269. if (HAL_ADC_Init(&hadc1) != HAL_OK)
  270. {
  271. Error_Handler();
  272. }
  273. /** Configure the ADC multi-mode
  274. */
  275. multimode.Mode = ADC_MODE_INDEPENDENT;
  276. if (HAL_ADCEx_MultiModeConfigChannel(&hadc1, &multimode) != HAL_OK)
  277. {
  278. Error_Handler();
  279. }
  280. /** Configure Regular Channel
  281. */
  282. sConfig.Channel = ADC_CHANNEL_14;
  283. sConfig.Rank = ADC_REGULAR_RANK_1;
  284. sConfig.SamplingTime = ADC_SAMPLETIME_2CYCLES_5;
  285. sConfig.SingleDiff = ADC_SINGLE_ENDED;
  286. sConfig.OffsetNumber = ADC_OFFSET_NONE;
  287. sConfig.Offset = 0;
  288. if (HAL_ADC_ConfigChannel(&hadc1, &sConfig) != HAL_OK)
  289. {
  290. Error_Handler();
  291. }
  292. /* USER CODE BEGIN ADC1_Init 2 */
  293. /* USER CODE END ADC1_Init 2 */
  294. }
  295. /**
  296. * @brief DAC1 Initialization Function
  297. * @param None
  298. * @retval None
  299. */
  300. static void MX_DAC1_Init(void)
  301. {
  302. /* USER CODE BEGIN DAC1_Init 0 */
  303. /* USER CODE END DAC1_Init 0 */
  304. DAC_ChannelConfTypeDef sConfig = {0};
  305. /* USER CODE BEGIN DAC1_Init 1 */
  306. /* USER CODE END DAC1_Init 1 */
  307. /** DAC Initialization
  308. */
  309. hdac1.Instance = DAC1;
  310. if (HAL_DAC_Init(&hdac1) != HAL_OK)
  311. {
  312. Error_Handler();
  313. }
  314. /** DAC channel OUT1 config
  315. */
  316. sConfig.DAC_SampleAndHold = DAC_SAMPLEANDHOLD_DISABLE;
  317. sConfig.DAC_Trigger = DAC_TRIGGER_NONE;
  318. sConfig.DAC_OutputBuffer = DAC_OUTPUTBUFFER_ENABLE;
  319. sConfig.DAC_ConnectOnChipPeripheral = DAC_CHIPCONNECT_DISABLE;
  320. sConfig.DAC_UserTrimming = DAC_TRIMMING_FACTORY;
  321. if (HAL_DAC_ConfigChannel(&hdac1, &sConfig, DAC_CHANNEL_1) != HAL_OK)
  322. {
  323. Error_Handler();
  324. }
  325. /* USER CODE BEGIN DAC1_Init 2 */
  326. /* USER CODE END DAC1_Init 2 */
  327. }
  328. /**
  329. * @brief IWDG Initialization Function
  330. * @param None
  331. * @retval None
  332. */
  333. static void MX_IWDG_Init(void)
  334. {
  335. /* USER CODE BEGIN IWDG_Init 0 */
  336. /* USER CODE END IWDG_Init 0 */
  337. /* USER CODE BEGIN IWDG_Init 1 */
  338. /* USER CODE END IWDG_Init 1 */
  339. hiwdg.Instance = IWDG;
  340. hiwdg.Init.Prescaler = IWDG_PRESCALER_4;
  341. hiwdg.Init.Window = 4095;
  342. hiwdg.Init.Reload = 4095;
  343. if (HAL_IWDG_Init(&hiwdg) != HAL_OK)
  344. {
  345. Error_Handler();
  346. }
  347. /* USER CODE BEGIN IWDG_Init 2 */
  348. /* USER CODE END IWDG_Init 2 */
  349. }
  350. /**
  351. * @brief LPTIM1 Initialization Function
  352. * @param None
  353. * @retval None
  354. */
  355. static void MX_LPTIM1_Init(void)
  356. {
  357. /* USER CODE BEGIN LPTIM1_Init 0 */
  358. /* USER CODE END LPTIM1_Init 0 */
  359. /* USER CODE BEGIN LPTIM1_Init 1 */
  360. /* USER CODE END LPTIM1_Init 1 */
  361. hlptim1.Instance = LPTIM1;
  362. hlptim1.Init.Clock.Source = LPTIM_CLOCKSOURCE_APBCLOCK_LPOSC;
  363. hlptim1.Init.Clock.Prescaler = LPTIM_PRESCALER_DIV1;
  364. hlptim1.Init.Trigger.Source = LPTIM_TRIGSOURCE_SOFTWARE;
  365. hlptim1.Init.OutputPolarity = LPTIM_OUTPUTPOLARITY_HIGH;
  366. hlptim1.Init.UpdateMode = LPTIM_UPDATE_IMMEDIATE;
  367. hlptim1.Init.CounterSource = LPTIM_COUNTERSOURCE_INTERNAL;
  368. hlptim1.Init.Input1Source = LPTIM_INPUT1SOURCE_GPIO;
  369. hlptim1.Init.Input2Source = LPTIM_INPUT2SOURCE_GPIO;
  370. if (HAL_LPTIM_Init(&hlptim1) != HAL_OK)
  371. {
  372. Error_Handler();
  373. }
  374. /* USER CODE BEGIN LPTIM1_Init 2 */
  375. /* USER CODE END LPTIM1_Init 2 */
  376. }
  377. /**
  378. * @brief QUADSPI Initialization Function
  379. * @param None
  380. * @retval None
  381. */
  382. static void MX_QUADSPI_Init(void)
  383. {
  384. /* USER CODE BEGIN QUADSPI_Init 0 */
  385. /* USER CODE END QUADSPI_Init 0 */
  386. /* USER CODE BEGIN QUADSPI_Init 1 */
  387. /* USER CODE END QUADSPI_Init 1 */
  388. /* QUADSPI parameter configuration*/
  389. hqspi.Instance = QUADSPI;
  390. hqspi.Init.ClockPrescaler = 255;
  391. hqspi.Init.FifoThreshold = 1;
  392. hqspi.Init.SampleShifting = QSPI_SAMPLE_SHIFTING_NONE;
  393. hqspi.Init.FlashSize = 1;
  394. hqspi.Init.ChipSelectHighTime = QSPI_CS_HIGH_TIME_1_CYCLE;
  395. hqspi.Init.ClockMode = QSPI_CLOCK_MODE_0;
  396. if (HAL_QSPI_Init(&hqspi) != HAL_OK)
  397. {
  398. Error_Handler();
  399. }
  400. /* USER CODE BEGIN QUADSPI_Init 2 */
  401. /* USER CODE END QUADSPI_Init 2 */
  402. }
  403. /**
  404. * @brief RTC Initialization Function
  405. * @param None
  406. * @retval None
  407. */
  408. static void MX_RTC_Init(void)
  409. {
  410. /* USER CODE BEGIN RTC_Init 0 */
  411. /* USER CODE END RTC_Init 0 */
  412. /* USER CODE BEGIN RTC_Init 1 */
  413. /* USER CODE END RTC_Init 1 */
  414. /** Initialize RTC Only
  415. */
  416. hrtc.Instance = RTC;
  417. hrtc.Init.HourFormat = RTC_HOURFORMAT_24;
  418. hrtc.Init.AsynchPrediv = 127;
  419. hrtc.Init.SynchPrediv = 255;
  420. hrtc.Init.OutPut = RTC_OUTPUT_DISABLE;
  421. hrtc.Init.OutPutRemap = RTC_OUTPUT_REMAP_NONE;
  422. hrtc.Init.OutPutPolarity = RTC_OUTPUT_POLARITY_HIGH;
  423. hrtc.Init.OutPutType = RTC_OUTPUT_TYPE_OPENDRAIN;
  424. if (HAL_RTC_Init(&hrtc) != HAL_OK)
  425. {
  426. Error_Handler();
  427. }
  428. /* USER CODE BEGIN RTC_Init 2 */
  429. /* USER CODE END RTC_Init 2 */
  430. }
  431. /**
  432. * @brief SAI1 Initialization Function
  433. * @param None
  434. * @retval None
  435. */
  436. static void MX_SAI1_Init(void)
  437. {
  438. /* USER CODE BEGIN SAI1_Init 0 */
  439. /* USER CODE END SAI1_Init 0 */
  440. /* USER CODE BEGIN SAI1_Init 1 */
  441. /* USER CODE END SAI1_Init 1 */
  442. hsai_BlockA1.Instance = SAI1_Block_A;
  443. hsai_BlockA1.Init.AudioMode = SAI_MODEMASTER_TX;
  444. hsai_BlockA1.Init.Synchro = SAI_ASYNCHRONOUS;
  445. hsai_BlockA1.Init.OutputDrive = SAI_OUTPUTDRIVE_ENABLE;
  446. hsai_BlockA1.Init.NoDivider = SAI_MASTERDIVIDER_ENABLE;
  447. hsai_BlockA1.Init.FIFOThreshold = SAI_FIFOTHRESHOLD_EMPTY;
  448. hsai_BlockA1.Init.AudioFrequency = SAI_AUDIO_FREQUENCY_44K;
  449. hsai_BlockA1.Init.SynchroExt = SAI_SYNCEXT_DISABLE;
  450. hsai_BlockA1.Init.MonoStereoMode = SAI_STEREOMODE;
  451. hsai_BlockA1.Init.CompandingMode = SAI_NOCOMPANDING;
  452. hsai_BlockA1.Init.TriState = SAI_OUTPUT_NOTRELEASED;
  453. if (HAL_SAI_InitProtocol(&hsai_BlockA1, SAI_I2S_STANDARD, SAI_PROTOCOL_DATASIZE_16BIT, 2) != HAL_OK)
  454. {
  455. Error_Handler();
  456. }
  457. hsai_BlockB1.Instance = SAI1_Block_B;
  458. hsai_BlockB1.Init.AudioMode = SAI_MODESLAVE_RX;
  459. hsai_BlockB1.Init.Synchro = SAI_SYNCHRONOUS;
  460. hsai_BlockB1.Init.OutputDrive = SAI_OUTPUTDRIVE_DISABLE;
  461. hsai_BlockB1.Init.FIFOThreshold = SAI_FIFOTHRESHOLD_EMPTY;
  462. hsai_BlockB1.Init.SynchroExt = SAI_SYNCEXT_DISABLE;
  463. hsai_BlockB1.Init.MonoStereoMode = SAI_STEREOMODE;
  464. hsai_BlockB1.Init.CompandingMode = SAI_NOCOMPANDING;
  465. hsai_BlockB1.Init.TriState = SAI_OUTPUT_NOTRELEASED;
  466. if (HAL_SAI_InitProtocol(&hsai_BlockB1, SAI_I2S_STANDARD, SAI_PROTOCOL_DATASIZE_16BIT, 2) != HAL_OK)
  467. {
  468. Error_Handler();
  469. }
  470. /* USER CODE BEGIN SAI1_Init 2 */
  471. /* USER CODE END SAI1_Init 2 */
  472. }
  473. /**
  474. * @brief SDMMC1 Initialization Function
  475. * @param None
  476. * @retval None
  477. */
  478. static void MX_SDMMC1_SD_Init(void)
  479. {
  480. /* USER CODE BEGIN SDMMC1_Init 0 */
  481. /* USER CODE END SDMMC1_Init 0 */
  482. /* USER CODE BEGIN SDMMC1_Init 1 */
  483. /* USER CODE END SDMMC1_Init 1 */
  484. hsd1.Instance = SDMMC1;
  485. hsd1.Init.ClockEdge = SDMMC_CLOCK_EDGE_RISING;
  486. hsd1.Init.ClockBypass = SDMMC_CLOCK_BYPASS_DISABLE;
  487. hsd1.Init.ClockPowerSave = SDMMC_CLOCK_POWER_SAVE_DISABLE;
  488. hsd1.Init.BusWide = SDMMC_BUS_WIDE_1B;
  489. hsd1.Init.HardwareFlowControl = SDMMC_HARDWARE_FLOW_CONTROL_DISABLE;
  490. hsd1.Init.ClockDiv = 0;
  491. if (HAL_SD_Init(&hsd1) != HAL_OK)
  492. {
  493. Error_Handler();
  494. }
  495. if (HAL_SD_ConfigWideBusOperation(&hsd1, SDMMC_BUS_WIDE_4B) != HAL_OK)
  496. {
  497. Error_Handler();
  498. }
  499. /* USER CODE BEGIN SDMMC1_Init 2 */
  500. /* USER CODE END SDMMC1_Init 2 */
  501. }
  502. /**
  503. * @brief SPI1 Initialization Function
  504. * @param None
  505. * @retval None
  506. */
  507. static void MX_SPI1_Init(void)
  508. {
  509. /* USER CODE BEGIN SPI1_Init 0 */
  510. /* USER CODE END SPI1_Init 0 */
  511. /* USER CODE BEGIN SPI1_Init 1 */
  512. /* USER CODE END SPI1_Init 1 */
  513. /* SPI1 parameter configuration*/
  514. hspi1.Instance = SPI1;
  515. hspi1.Init.Mode = SPI_MODE_MASTER;
  516. hspi1.Init.Direction = SPI_DIRECTION_2LINES;
  517. hspi1.Init.DataSize = SPI_DATASIZE_4BIT;
  518. hspi1.Init.CLKPolarity = SPI_POLARITY_LOW;
  519. hspi1.Init.CLKPhase = SPI_PHASE_1EDGE;
  520. hspi1.Init.NSS = SPI_NSS_SOFT;
  521. hspi1.Init.BaudRatePrescaler = SPI_BAUDRATEPRESCALER_2;
  522. hspi1.Init.FirstBit = SPI_FIRSTBIT_MSB;
  523. hspi1.Init.TIMode = SPI_TIMODE_DISABLE;
  524. hspi1.Init.CRCCalculation = SPI_CRCCALCULATION_DISABLE;
  525. hspi1.Init.CRCPolynomial = 7;
  526. hspi1.Init.CRCLength = SPI_CRC_LENGTH_DATASIZE;
  527. hspi1.Init.NSSPMode = SPI_NSS_PULSE_ENABLE;
  528. if (HAL_SPI_Init(&hspi1) != HAL_OK)
  529. {
  530. Error_Handler();
  531. }
  532. /* USER CODE BEGIN SPI1_Init 2 */
  533. /* USER CODE END SPI1_Init 2 */
  534. }
  535. /**
  536. * @brief SPI2 Initialization Function
  537. * @param None
  538. * @retval None
  539. */
  540. static void MX_SPI2_Init(void)
  541. {
  542. /* USER CODE BEGIN SPI2_Init 0 */
  543. /* USER CODE END SPI2_Init 0 */
  544. /* USER CODE BEGIN SPI2_Init 1 */
  545. /* USER CODE END SPI2_Init 1 */
  546. /* SPI2 parameter configuration*/
  547. hspi2.Instance = SPI2;
  548. hspi2.Init.Mode = SPI_MODE_MASTER;
  549. hspi2.Init.Direction = SPI_DIRECTION_2LINES;
  550. hspi2.Init.DataSize = SPI_DATASIZE_4BIT;
  551. hspi2.Init.CLKPolarity = SPI_POLARITY_LOW;
  552. hspi2.Init.CLKPhase = SPI_PHASE_1EDGE;
  553. hspi2.Init.NSS = SPI_NSS_SOFT;
  554. hspi2.Init.BaudRatePrescaler = SPI_BAUDRATEPRESCALER_2;
  555. hspi2.Init.FirstBit = SPI_FIRSTBIT_MSB;
  556. hspi2.Init.TIMode = SPI_TIMODE_DISABLE;
  557. hspi2.Init.CRCCalculation = SPI_CRCCALCULATION_DISABLE;
  558. hspi2.Init.CRCPolynomial = 7;
  559. hspi2.Init.CRCLength = SPI_CRC_LENGTH_DATASIZE;
  560. hspi2.Init.NSSPMode = SPI_NSS_PULSE_ENABLE;
  561. if (HAL_SPI_Init(&hspi2) != HAL_OK)
  562. {
  563. Error_Handler();
  564. }
  565. /* USER CODE BEGIN SPI2_Init 2 */
  566. /* USER CODE END SPI2_Init 2 */
  567. }
  568. /**
  569. * @brief SPI3 Initialization Function
  570. * @param None
  571. * @retval None
  572. */
  573. static void MX_SPI3_Init(void)
  574. {
  575. /* USER CODE BEGIN SPI3_Init 0 */
  576. /* USER CODE END SPI3_Init 0 */
  577. /* USER CODE BEGIN SPI3_Init 1 */
  578. /* USER CODE END SPI3_Init 1 */
  579. /* SPI3 parameter configuration*/
  580. hspi3.Instance = SPI3;
  581. hspi3.Init.Mode = SPI_MODE_MASTER;
  582. hspi3.Init.Direction = SPI_DIRECTION_2LINES;
  583. hspi3.Init.DataSize = SPI_DATASIZE_4BIT;
  584. hspi3.Init.CLKPolarity = SPI_POLARITY_LOW;
  585. hspi3.Init.CLKPhase = SPI_PHASE_1EDGE;
  586. hspi3.Init.NSS = SPI_NSS_SOFT;
  587. hspi3.Init.BaudRatePrescaler = SPI_BAUDRATEPRESCALER_2;
  588. hspi3.Init.FirstBit = SPI_FIRSTBIT_MSB;
  589. hspi3.Init.TIMode = SPI_TIMODE_DISABLE;
  590. hspi3.Init.CRCCalculation = SPI_CRCCALCULATION_DISABLE;
  591. hspi3.Init.CRCPolynomial = 7;
  592. hspi3.Init.CRCLength = SPI_CRC_LENGTH_DATASIZE;
  593. hspi3.Init.NSSPMode = SPI_NSS_PULSE_ENABLE;
  594. if (HAL_SPI_Init(&hspi3) != HAL_OK)
  595. {
  596. Error_Handler();
  597. }
  598. /* USER CODE BEGIN SPI3_Init 2 */
  599. /* USER CODE END SPI3_Init 2 */
  600. }
  601. /**
  602. * @brief TIM1 Initialization Function
  603. * @param None
  604. * @retval None
  605. */
  606. static void MX_TIM1_Init(void)
  607. {
  608. /* USER CODE BEGIN TIM1_Init 0 */
  609. /* USER CODE END TIM1_Init 0 */
  610. TIM_ClockConfigTypeDef sClockSourceConfig = {0};
  611. TIM_MasterConfigTypeDef sMasterConfig = {0};
  612. TIM_OC_InitTypeDef sConfigOC = {0};
  613. TIM_BreakDeadTimeConfigTypeDef sBreakDeadTimeConfig = {0};
  614. /* USER CODE BEGIN TIM1_Init 1 */
  615. /* USER CODE END TIM1_Init 1 */
  616. htim1.Instance = TIM1;
  617. htim1.Init.Prescaler = 0;
  618. htim1.Init.CounterMode = TIM_COUNTERMODE_UP;
  619. htim1.Init.Period = 65535;
  620. htim1.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1;
  621. htim1.Init.RepetitionCounter = 0;
  622. htim1.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_DISABLE;
  623. if (HAL_TIM_Base_Init(&htim1) != HAL_OK)
  624. {
  625. Error_Handler();
  626. }
  627. sClockSourceConfig.ClockSource = TIM_CLOCKSOURCE_INTERNAL;
  628. if (HAL_TIM_ConfigClockSource(&htim1, &sClockSourceConfig) != HAL_OK)
  629. {
  630. Error_Handler();
  631. }
  632. if (HAL_TIM_PWM_Init(&htim1) != HAL_OK)
  633. {
  634. Error_Handler();
  635. }
  636. sMasterConfig.MasterOutputTrigger = TIM_TRGO_RESET;
  637. sMasterConfig.MasterOutputTrigger2 = TIM_TRGO2_RESET;
  638. sMasterConfig.MasterSlaveMode = TIM_MASTERSLAVEMODE_DISABLE;
  639. if (HAL_TIMEx_MasterConfigSynchronization(&htim1, &sMasterConfig) != HAL_OK)
  640. {
  641. Error_Handler();
  642. }
  643. sConfigOC.OCMode = TIM_OCMODE_PWM1;
  644. sConfigOC.Pulse = 0;
  645. sConfigOC.OCPolarity = TIM_OCPOLARITY_HIGH;
  646. sConfigOC.OCNPolarity = TIM_OCNPOLARITY_HIGH;
  647. sConfigOC.OCFastMode = TIM_OCFAST_DISABLE;
  648. sConfigOC.OCIdleState = TIM_OCIDLESTATE_RESET;
  649. sConfigOC.OCNIdleState = TIM_OCNIDLESTATE_RESET;
  650. if (HAL_TIM_PWM_ConfigChannel(&htim1, &sConfigOC, TIM_CHANNEL_1) != HAL_OK)
  651. {
  652. Error_Handler();
  653. }
  654. sBreakDeadTimeConfig.OffStateRunMode = TIM_OSSR_DISABLE;
  655. sBreakDeadTimeConfig.OffStateIDLEMode = TIM_OSSI_DISABLE;
  656. sBreakDeadTimeConfig.LockLevel = TIM_LOCKLEVEL_OFF;
  657. sBreakDeadTimeConfig.DeadTime = 0;
  658. sBreakDeadTimeConfig.BreakState = TIM_BREAK_DISABLE;
  659. sBreakDeadTimeConfig.BreakPolarity = TIM_BREAKPOLARITY_HIGH;
  660. sBreakDeadTimeConfig.BreakFilter = 0;
  661. sBreakDeadTimeConfig.Break2State = TIM_BREAK2_DISABLE;
  662. sBreakDeadTimeConfig.Break2Polarity = TIM_BREAK2POLARITY_HIGH;
  663. sBreakDeadTimeConfig.Break2Filter = 0;
  664. sBreakDeadTimeConfig.AutomaticOutput = TIM_AUTOMATICOUTPUT_DISABLE;
  665. if (HAL_TIMEx_ConfigBreakDeadTime(&htim1, &sBreakDeadTimeConfig) != HAL_OK)
  666. {
  667. Error_Handler();
  668. }
  669. /* USER CODE BEGIN TIM1_Init 2 */
  670. /* USER CODE END TIM1_Init 2 */
  671. HAL_TIM_MspPostInit(&htim1);
  672. }
  673. /**
  674. * @brief TIM2 Initialization Function
  675. * @param None
  676. * @retval None
  677. */
  678. static void MX_TIM2_Init(void)
  679. {
  680. /* USER CODE BEGIN TIM2_Init 0 */
  681. /* USER CODE END TIM2_Init 0 */
  682. TIM_ClockConfigTypeDef sClockSourceConfig = {0};
  683. TIM_MasterConfigTypeDef sMasterConfig = {0};
  684. TIM_OC_InitTypeDef sConfigOC = {0};
  685. /* USER CODE BEGIN TIM2_Init 1 */
  686. /* USER CODE END TIM2_Init 1 */
  687. htim2.Instance = TIM2;
  688. htim2.Init.Prescaler = 0;
  689. htim2.Init.CounterMode = TIM_COUNTERMODE_UP;
  690. htim2.Init.Period = 4294967295;
  691. htim2.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1;
  692. htim2.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_DISABLE;
  693. if (HAL_TIM_Base_Init(&htim2) != HAL_OK)
  694. {
  695. Error_Handler();
  696. }
  697. sClockSourceConfig.ClockSource = TIM_CLOCKSOURCE_INTERNAL;
  698. if (HAL_TIM_ConfigClockSource(&htim2, &sClockSourceConfig) != HAL_OK)
  699. {
  700. Error_Handler();
  701. }
  702. if (HAL_TIM_PWM_Init(&htim2) != HAL_OK)
  703. {
  704. Error_Handler();
  705. }
  706. sMasterConfig.MasterOutputTrigger = TIM_TRGO_RESET;
  707. sMasterConfig.MasterSlaveMode = TIM_MASTERSLAVEMODE_DISABLE;
  708. if (HAL_TIMEx_MasterConfigSynchronization(&htim2, &sMasterConfig) != HAL_OK)
  709. {
  710. Error_Handler();
  711. }
  712. sConfigOC.OCMode = TIM_OCMODE_PWM1;
  713. sConfigOC.Pulse = 0;
  714. sConfigOC.OCPolarity = TIM_OCPOLARITY_HIGH;
  715. sConfigOC.OCFastMode = TIM_OCFAST_DISABLE;
  716. if (HAL_TIM_PWM_ConfigChannel(&htim2, &sConfigOC, TIM_CHANNEL_3) != HAL_OK)
  717. {
  718. Error_Handler();
  719. }
  720. if (HAL_TIM_PWM_ConfigChannel(&htim2, &sConfigOC, TIM_CHANNEL_4) != HAL_OK)
  721. {
  722. Error_Handler();
  723. }
  724. /* USER CODE BEGIN TIM2_Init 2 */
  725. /* USER CODE END TIM2_Init 2 */
  726. HAL_TIM_MspPostInit(&htim2);
  727. }
  728. /**
  729. * @brief TIM4 Initialization Function
  730. * @param None
  731. * @retval None
  732. */
  733. static void MX_TIM4_Init(void)
  734. {
  735. /* USER CODE BEGIN TIM4_Init 0 */
  736. /* USER CODE END TIM4_Init 0 */
  737. TIM_ClockConfigTypeDef sClockSourceConfig = {0};
  738. TIM_MasterConfigTypeDef sMasterConfig = {0};
  739. TIM_OC_InitTypeDef sConfigOC = {0};
  740. /* USER CODE BEGIN TIM4_Init 1 */
  741. /* USER CODE END TIM4_Init 1 */
  742. htim4.Instance = TIM4;
  743. htim4.Init.Prescaler = 0;
  744. htim4.Init.CounterMode = TIM_COUNTERMODE_UP;
  745. htim4.Init.Period = 65535;
  746. htim4.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1;
  747. htim4.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_DISABLE;
  748. if (HAL_TIM_Base_Init(&htim4) != HAL_OK)
  749. {
  750. Error_Handler();
  751. }
  752. sClockSourceConfig.ClockSource = TIM_CLOCKSOURCE_INTERNAL;
  753. if (HAL_TIM_ConfigClockSource(&htim4, &sClockSourceConfig) != HAL_OK)
  754. {
  755. Error_Handler();
  756. }
  757. if (HAL_TIM_PWM_Init(&htim4) != HAL_OK)
  758. {
  759. Error_Handler();
  760. }
  761. sMasterConfig.MasterOutputTrigger = TIM_TRGO_RESET;
  762. sMasterConfig.MasterSlaveMode = TIM_MASTERSLAVEMODE_DISABLE;
  763. if (HAL_TIMEx_MasterConfigSynchronization(&htim4, &sMasterConfig) != HAL_OK)
  764. {
  765. Error_Handler();
  766. }
  767. sConfigOC.OCMode = TIM_OCMODE_PWM1;
  768. sConfigOC.Pulse = 0;
  769. sConfigOC.OCPolarity = TIM_OCPOLARITY_HIGH;
  770. sConfigOC.OCFastMode = TIM_OCFAST_DISABLE;
  771. if (HAL_TIM_PWM_ConfigChannel(&htim4, &sConfigOC, TIM_CHANNEL_2) != HAL_OK)
  772. {
  773. Error_Handler();
  774. }
  775. if (HAL_TIM_PWM_ConfigChannel(&htim4, &sConfigOC, TIM_CHANNEL_3) != HAL_OK)
  776. {
  777. Error_Handler();
  778. }
  779. /* USER CODE BEGIN TIM4_Init 2 */
  780. /* USER CODE END TIM4_Init 2 */
  781. HAL_TIM_MspPostInit(&htim4);
  782. }
  783. /**
  784. * @brief TIM15 Initialization Function
  785. * @param None
  786. * @retval None
  787. */
  788. static void MX_TIM15_Init(void)
  789. {
  790. /* USER CODE BEGIN TIM15_Init 0 */
  791. /* USER CODE END TIM15_Init 0 */
  792. TIM_ClockConfigTypeDef sClockSourceConfig = {0};
  793. TIM_MasterConfigTypeDef sMasterConfig = {0};
  794. /* USER CODE BEGIN TIM15_Init 1 */
  795. /* USER CODE END TIM15_Init 1 */
  796. htim15.Instance = TIM15;
  797. htim15.Init.Prescaler = 0;
  798. htim15.Init.CounterMode = TIM_COUNTERMODE_UP;
  799. htim15.Init.Period = 65535;
  800. htim15.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1;
  801. htim15.Init.RepetitionCounter = 0;
  802. htim15.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_DISABLE;
  803. if (HAL_TIM_Base_Init(&htim15) != HAL_OK)
  804. {
  805. Error_Handler();
  806. }
  807. sClockSourceConfig.ClockSource = TIM_CLOCKSOURCE_INTERNAL;
  808. if (HAL_TIM_ConfigClockSource(&htim15, &sClockSourceConfig) != HAL_OK)
  809. {
  810. Error_Handler();
  811. }
  812. sMasterConfig.MasterOutputTrigger = TIM_TRGO_RESET;
  813. sMasterConfig.MasterSlaveMode = TIM_MASTERSLAVEMODE_DISABLE;
  814. if (HAL_TIMEx_MasterConfigSynchronization(&htim15, &sMasterConfig) != HAL_OK)
  815. {
  816. Error_Handler();
  817. }
  818. /* USER CODE BEGIN TIM15_Init 2 */
  819. /* USER CODE END TIM15_Init 2 */
  820. }
  821. /**
  822. * @brief TIM16 Initialization Function
  823. * @param None
  824. * @retval None
  825. */
  826. static void MX_TIM16_Init(void)
  827. {
  828. /* USER CODE BEGIN TIM16_Init 0 */
  829. /* USER CODE END TIM16_Init 0 */
  830. /* USER CODE BEGIN TIM16_Init 1 */
  831. /* USER CODE END TIM16_Init 1 */
  832. htim16.Instance = TIM16;
  833. htim16.Init.Prescaler = 0;
  834. htim16.Init.CounterMode = TIM_COUNTERMODE_UP;
  835. htim16.Init.Period = 65535;
  836. htim16.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1;
  837. htim16.Init.RepetitionCounter = 0;
  838. htim16.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_DISABLE;
  839. if (HAL_TIM_Base_Init(&htim16) != HAL_OK)
  840. {
  841. Error_Handler();
  842. }
  843. /* USER CODE BEGIN TIM16_Init 2 */
  844. /* USER CODE END TIM16_Init 2 */
  845. }
  846. /**
  847. * @brief TIM17 Initialization Function
  848. * @param None
  849. * @retval None
  850. */
  851. static void MX_TIM17_Init(void)
  852. {
  853. /* USER CODE BEGIN TIM17_Init 0 */
  854. /* USER CODE END TIM17_Init 0 */
  855. /* USER CODE BEGIN TIM17_Init 1 */
  856. /* USER CODE END TIM17_Init 1 */
  857. htim17.Instance = TIM17;
  858. htim17.Init.Prescaler = 0;
  859. htim17.Init.CounterMode = TIM_COUNTERMODE_UP;
  860. htim17.Init.Period = 65535;
  861. htim17.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1;
  862. htim17.Init.RepetitionCounter = 0;
  863. htim17.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_DISABLE;
  864. if (HAL_TIM_Base_Init(&htim17) != HAL_OK)
  865. {
  866. Error_Handler();
  867. }
  868. /* USER CODE BEGIN TIM17_Init 2 */
  869. /* USER CODE END TIM17_Init 2 */
  870. }
  871. /**
  872. * @brief USART1 Initialization Function
  873. * @param None
  874. * @retval None
  875. */
  876. static void MX_USART1_UART_Init(void)
  877. {
  878. /* USER CODE BEGIN USART1_Init 0 */
  879. /* USER CODE END USART1_Init 0 */
  880. /* USER CODE BEGIN USART1_Init 1 */
  881. /* USER CODE END USART1_Init 1 */
  882. huart1.Instance = USART1;
  883. huart1.Init.BaudRate = 115200;
  884. huart1.Init.WordLength = UART_WORDLENGTH_8B;
  885. huart1.Init.StopBits = UART_STOPBITS_1;
  886. huart1.Init.Parity = UART_PARITY_NONE;
  887. huart1.Init.Mode = UART_MODE_TX_RX;
  888. huart1.Init.HwFlowCtl = UART_HWCONTROL_NONE;
  889. huart1.Init.OverSampling = UART_OVERSAMPLING_16;
  890. huart1.Init.OneBitSampling = UART_ONE_BIT_SAMPLE_DISABLE;
  891. huart1.AdvancedInit.AdvFeatureInit = UART_ADVFEATURE_NO_INIT;
  892. if (HAL_UART_Init(&huart1) != HAL_OK)
  893. {
  894. Error_Handler();
  895. }
  896. /* USER CODE BEGIN USART1_Init 2 */
  897. /* USER CODE END USART1_Init 2 */
  898. }
  899. /**
  900. * @brief USART2 Initialization Function
  901. * @param None
  902. * @retval None
  903. */
  904. static void MX_USART2_UART_Init(void)
  905. {
  906. /* USER CODE BEGIN USART2_Init 0 */
  907. /* USER CODE END USART2_Init 0 */
  908. /* USER CODE BEGIN USART2_Init 1 */
  909. /* USER CODE END USART2_Init 1 */
  910. huart2.Instance = USART2;
  911. huart2.Init.BaudRate = 115200;
  912. huart2.Init.WordLength = UART_WORDLENGTH_8B;
  913. huart2.Init.StopBits = UART_STOPBITS_1;
  914. huart2.Init.Parity = UART_PARITY_NONE;
  915. huart2.Init.Mode = UART_MODE_TX_RX;
  916. huart2.Init.HwFlowCtl = UART_HWCONTROL_NONE;
  917. huart2.Init.OverSampling = UART_OVERSAMPLING_16;
  918. huart2.Init.OneBitSampling = UART_ONE_BIT_SAMPLE_DISABLE;
  919. huart2.AdvancedInit.AdvFeatureInit = UART_ADVFEATURE_NO_INIT;
  920. if (HAL_UART_Init(&huart2) != HAL_OK)
  921. {
  922. Error_Handler();
  923. }
  924. /* USER CODE BEGIN USART2_Init 2 */
  925. /* USER CODE END USART2_Init 2 */
  926. }
  927. /**
  928. * @brief USB_OTG_FS Initialization Function
  929. * @param None
  930. * @retval None
  931. */
  932. static void MX_USB_OTG_FS_PCD_Init(void)
  933. {
  934. /* USER CODE BEGIN USB_OTG_FS_Init 0 */
  935. /* USER CODE END USB_OTG_FS_Init 0 */
  936. /* USER CODE BEGIN USB_OTG_FS_Init 1 */
  937. /* USER CODE END USB_OTG_FS_Init 1 */
  938. hpcd_USB_OTG_FS.Instance = USB_OTG_FS;
  939. hpcd_USB_OTG_FS.Init.dev_endpoints = 6;
  940. hpcd_USB_OTG_FS.Init.speed = PCD_SPEED_FULL;
  941. hpcd_USB_OTG_FS.Init.phy_itface = PCD_PHY_EMBEDDED;
  942. hpcd_USB_OTG_FS.Init.Sof_enable = DISABLE;
  943. hpcd_USB_OTG_FS.Init.low_power_enable = DISABLE;
  944. hpcd_USB_OTG_FS.Init.lpm_enable = DISABLE;
  945. hpcd_USB_OTG_FS.Init.battery_charging_enable = DISABLE;
  946. hpcd_USB_OTG_FS.Init.use_dedicated_ep1 = DISABLE;
  947. hpcd_USB_OTG_FS.Init.vbus_sensing_enable = DISABLE;
  948. if (HAL_PCD_Init(&hpcd_USB_OTG_FS) != HAL_OK)
  949. {
  950. Error_Handler();
  951. }
  952. /* USER CODE BEGIN USB_OTG_FS_Init 2 */
  953. /* USER CODE END USB_OTG_FS_Init 2 */
  954. }
  955. /**
  956. * @brief GPIO Initialization Function
  957. * @param None
  958. * @retval None
  959. */
  960. static void MX_GPIO_Init(void)
  961. {
  962. /* GPIO Ports Clock Enable */
  963. __HAL_RCC_GPIOE_CLK_ENABLE();
  964. __HAL_RCC_GPIOC_CLK_ENABLE();
  965. __HAL_RCC_GPIOH_CLK_ENABLE();
  966. __HAL_RCC_GPIOA_CLK_ENABLE();
  967. __HAL_RCC_GPIOB_CLK_ENABLE();
  968. __HAL_RCC_GPIOD_CLK_ENABLE();
  969. }
  970. /* USER CODE BEGIN 4 */
  971. /* USER CODE END 4 */
  972. /**
  973. * @brief This function is executed in case of error occurrence.
  974. * @retval None
  975. */
  976. void Error_Handler(void)
  977. {
  978. /* USER CODE BEGIN Error_Handler_Debug */
  979. /* User can add his own implementation to report the HAL error return state */
  980. while(1)
  981. {
  982. }
  983. /* USER CODE END Error_Handler_Debug */
  984. }
  985. #ifdef USE_FULL_ASSERT
  986. /**
  987. * @brief Reports the name of the source file and the source line number
  988. * where the assert_param error has occurred.
  989. * @param file: pointer to the source file name
  990. * @param line: assert_param error line source number
  991. * @retval None
  992. */
  993. void assert_failed(uint8_t *file, uint32_t line)
  994. {
  995. /* USER CODE BEGIN 6 */
  996. /* User can add his own implementation to report the file name and line number,
  997. tex: printf("Wrong parameters value: file %s on line %d\r\n", file, line) */
  998. /* USER CODE END 6 */
  999. }
  1000. #endif /* USE_FULL_ASSERT */