main.c 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975
  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 "string.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. ETH_TxPacketConfig TxConfig;
  36. ETH_DMADescTypeDef DMARxDscrTab[ETH_RX_DESC_CNT]; /* Ethernet Rx DMA Descriptors */
  37. ETH_DMADescTypeDef DMATxDscrTab[ETH_TX_DESC_CNT]; /* Ethernet Tx DMA Descriptors */
  38. DAC_HandleTypeDef hdac;
  39. ETH_HandleTypeDef heth;
  40. IWDG_HandleTypeDef hiwdg;
  41. RTC_HandleTypeDef hrtc;
  42. SD_HandleTypeDef hsd;
  43. SPI_HandleTypeDef hspi1;
  44. SPI_HandleTypeDef hspi2;
  45. TIM_HandleTypeDef htim2;
  46. TIM_HandleTypeDef htim3;
  47. TIM_HandleTypeDef htim4;
  48. TIM_HandleTypeDef htim11;
  49. TIM_HandleTypeDef htim13;
  50. TIM_HandleTypeDef htim14;
  51. UART_HandleTypeDef huart1;
  52. UART_HandleTypeDef huart3;
  53. PCD_HandleTypeDef hpcd_USB_OTG_FS;
  54. SRAM_HandleTypeDef hsram1;
  55. /* USER CODE BEGIN PV */
  56. /* USER CODE END PV */
  57. /* Private function prototypes -----------------------------------------------*/
  58. void SystemClock_Config(void);
  59. static void MX_GPIO_Init(void);
  60. static void MX_USART1_UART_Init(void);
  61. static void MX_SPI1_Init(void);
  62. static void MX_ETH_Init(void);
  63. static void MX_USART3_UART_Init(void);
  64. static void MX_RTC_Init(void);
  65. static void MX_IWDG_Init(void);
  66. static void MX_TIM14_Init(void);
  67. static void MX_TIM13_Init(void);
  68. static void MX_TIM11_Init(void);
  69. static void MX_SDIO_SD_Init(void);
  70. static void MX_TIM2_Init(void);
  71. static void MX_SPI2_Init(void);
  72. static void MX_TIM4_Init(void);
  73. static void MX_USB_OTG_FS_PCD_Init(void);
  74. static void MX_FSMC_Init(void);
  75. static void MX_DAC_Init(void);
  76. static void MX_TIM3_Init(void);
  77. /* USER CODE BEGIN PFP */
  78. /* USER CODE END PFP */
  79. /* Private user code ---------------------------------------------------------*/
  80. /* USER CODE BEGIN 0 */
  81. /* USER CODE END 0 */
  82. /**
  83. * @brief The application entry point.
  84. * @retval int
  85. */
  86. int main(void)
  87. {
  88. /* USER CODE BEGIN 1 */
  89. /* USER CODE END 1 */
  90. /* MCU Configuration--------------------------------------------------------*/
  91. /* Reset of all peripherals, Initializes the Flash interface and the Systick. */
  92. HAL_Init();
  93. /* USER CODE BEGIN Init */
  94. /* USER CODE END Init */
  95. /* Configure the system clock */
  96. SystemClock_Config();
  97. /* USER CODE BEGIN SysInit */
  98. /* USER CODE END SysInit */
  99. /* Initialize all configured peripherals */
  100. MX_GPIO_Init();
  101. MX_USART1_UART_Init();
  102. MX_SPI1_Init();
  103. MX_ETH_Init();
  104. MX_USART3_UART_Init();
  105. MX_RTC_Init();
  106. MX_IWDG_Init();
  107. MX_TIM14_Init();
  108. MX_TIM13_Init();
  109. MX_TIM11_Init();
  110. MX_SDIO_SD_Init();
  111. MX_TIM2_Init();
  112. MX_SPI2_Init();
  113. MX_TIM4_Init();
  114. MX_USB_OTG_FS_PCD_Init();
  115. MX_FSMC_Init();
  116. MX_DAC_Init();
  117. MX_TIM3_Init();
  118. /* USER CODE BEGIN 2 */
  119. /* USER CODE END 2 */
  120. /* Infinite loop */
  121. /* USER CODE BEGIN WHILE */
  122. while (1)
  123. {
  124. /* USER CODE END WHILE */
  125. /* USER CODE BEGIN 3 */
  126. }
  127. /* USER CODE END 3 */
  128. }
  129. /**
  130. * @brief System Clock Configuration
  131. * @retval None
  132. */
  133. void SystemClock_Config(void)
  134. {
  135. RCC_OscInitTypeDef RCC_OscInitStruct = {0};
  136. RCC_ClkInitTypeDef RCC_ClkInitStruct = {0};
  137. /** Configure the main internal regulator output voltage
  138. */
  139. __HAL_RCC_PWR_CLK_ENABLE();
  140. __HAL_PWR_VOLTAGESCALING_CONFIG(PWR_REGULATOR_VOLTAGE_SCALE1);
  141. /** Initializes the RCC Oscillators according to the specified parameters
  142. * in the RCC_OscInitTypeDef structure.
  143. */
  144. RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_LSI|RCC_OSCILLATORTYPE_HSE
  145. |RCC_OSCILLATORTYPE_LSE;
  146. RCC_OscInitStruct.HSEState = RCC_HSE_ON;
  147. RCC_OscInitStruct.LSEState = RCC_LSE_ON;
  148. RCC_OscInitStruct.LSIState = RCC_LSI_ON;
  149. RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON;
  150. RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_HSE;
  151. RCC_OscInitStruct.PLL.PLLM = 4;
  152. RCC_OscInitStruct.PLL.PLLN = 168;
  153. RCC_OscInitStruct.PLL.PLLP = RCC_PLLP_DIV2;
  154. RCC_OscInitStruct.PLL.PLLQ = 7;
  155. if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK)
  156. {
  157. Error_Handler();
  158. }
  159. /** Initializes the CPU, AHB and APB buses clocks
  160. */
  161. RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK|RCC_CLOCKTYPE_SYSCLK
  162. |RCC_CLOCKTYPE_PCLK1|RCC_CLOCKTYPE_PCLK2;
  163. RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK;
  164. RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1;
  165. RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV4;
  166. RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV2;
  167. if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_5) != HAL_OK)
  168. {
  169. Error_Handler();
  170. }
  171. }
  172. /**
  173. * @brief DAC Initialization Function
  174. * @param None
  175. * @retval None
  176. */
  177. static void MX_DAC_Init(void)
  178. {
  179. /* USER CODE BEGIN DAC_Init 0 */
  180. /* USER CODE END DAC_Init 0 */
  181. DAC_ChannelConfTypeDef sConfig = {0};
  182. /* USER CODE BEGIN DAC_Init 1 */
  183. /* USER CODE END DAC_Init 1 */
  184. /** DAC Initialization
  185. */
  186. hdac.Instance = DAC;
  187. if (HAL_DAC_Init(&hdac) != HAL_OK)
  188. {
  189. Error_Handler();
  190. }
  191. /** DAC channel OUT1 config
  192. */
  193. sConfig.DAC_Trigger = DAC_TRIGGER_NONE;
  194. sConfig.DAC_OutputBuffer = DAC_OUTPUTBUFFER_ENABLE;
  195. if (HAL_DAC_ConfigChannel(&hdac, &sConfig, DAC_CHANNEL_1) != HAL_OK)
  196. {
  197. Error_Handler();
  198. }
  199. /** DAC channel OUT2 config
  200. */
  201. if (HAL_DAC_ConfigChannel(&hdac, &sConfig, DAC_CHANNEL_2) != HAL_OK)
  202. {
  203. Error_Handler();
  204. }
  205. /* USER CODE BEGIN DAC_Init 2 */
  206. /* USER CODE END DAC_Init 2 */
  207. }
  208. /**
  209. * @brief ETH Initialization Function
  210. * @param None
  211. * @retval None
  212. */
  213. static void MX_ETH_Init(void)
  214. {
  215. /* USER CODE BEGIN ETH_Init 0 */
  216. /* USER CODE END ETH_Init 0 */
  217. static uint8_t MACAddr[6];
  218. /* USER CODE BEGIN ETH_Init 1 */
  219. /* USER CODE END ETH_Init 1 */
  220. heth.Instance = ETH;
  221. MACAddr[0] = 0x00;
  222. MACAddr[1] = 0x80;
  223. MACAddr[2] = 0xE1;
  224. MACAddr[3] = 0x00;
  225. MACAddr[4] = 0x00;
  226. MACAddr[5] = 0x00;
  227. heth.Init.MACAddr = &MACAddr[0];
  228. heth.Init.MediaInterface = HAL_ETH_RMII_MODE;
  229. heth.Init.TxDesc = DMATxDscrTab;
  230. heth.Init.RxDesc = DMARxDscrTab;
  231. heth.Init.RxBuffLen = 1524;
  232. /* USER CODE BEGIN MACADDRESS */
  233. /* USER CODE END MACADDRESS */
  234. if (HAL_ETH_Init(&heth) != HAL_OK)
  235. {
  236. Error_Handler();
  237. }
  238. memset(&TxConfig, 0 , sizeof(ETH_TxPacketConfig));
  239. TxConfig.Attributes = ETH_TX_PACKETS_FEATURES_CSUM | ETH_TX_PACKETS_FEATURES_CRCPAD;
  240. TxConfig.ChecksumCtrl = ETH_CHECKSUM_IPHDR_PAYLOAD_INSERT_PHDR_CALC;
  241. TxConfig.CRCPadCtrl = ETH_CRC_PAD_INSERT;
  242. /* USER CODE BEGIN ETH_Init 2 */
  243. /* USER CODE END ETH_Init 2 */
  244. }
  245. /**
  246. * @brief IWDG Initialization Function
  247. * @param None
  248. * @retval None
  249. */
  250. static void MX_IWDG_Init(void)
  251. {
  252. /* USER CODE BEGIN IWDG_Init 0 */
  253. /* USER CODE END IWDG_Init 0 */
  254. /* USER CODE BEGIN IWDG_Init 1 */
  255. /* USER CODE END IWDG_Init 1 */
  256. hiwdg.Instance = IWDG;
  257. hiwdg.Init.Prescaler = IWDG_PRESCALER_4;
  258. hiwdg.Init.Reload = 4095;
  259. if (HAL_IWDG_Init(&hiwdg) != HAL_OK)
  260. {
  261. Error_Handler();
  262. }
  263. /* USER CODE BEGIN IWDG_Init 2 */
  264. /* USER CODE END IWDG_Init 2 */
  265. }
  266. /**
  267. * @brief RTC Initialization Function
  268. * @param None
  269. * @retval None
  270. */
  271. static void MX_RTC_Init(void)
  272. {
  273. /* USER CODE BEGIN RTC_Init 0 */
  274. /* USER CODE END RTC_Init 0 */
  275. /* USER CODE BEGIN RTC_Init 1 */
  276. /* USER CODE END RTC_Init 1 */
  277. /** Initialize RTC Only
  278. */
  279. hrtc.Instance = RTC;
  280. hrtc.Init.HourFormat = RTC_HOURFORMAT_24;
  281. hrtc.Init.AsynchPrediv = 127;
  282. hrtc.Init.SynchPrediv = 255;
  283. hrtc.Init.OutPut = RTC_OUTPUT_DISABLE;
  284. hrtc.Init.OutPutPolarity = RTC_OUTPUT_POLARITY_HIGH;
  285. hrtc.Init.OutPutType = RTC_OUTPUT_TYPE_OPENDRAIN;
  286. if (HAL_RTC_Init(&hrtc) != HAL_OK)
  287. {
  288. Error_Handler();
  289. }
  290. /* USER CODE BEGIN RTC_Init 2 */
  291. /* USER CODE END RTC_Init 2 */
  292. }
  293. /**
  294. * @brief SDIO Initialization Function
  295. * @param None
  296. * @retval None
  297. */
  298. static void MX_SDIO_SD_Init(void)
  299. {
  300. /* USER CODE BEGIN SDIO_Init 0 */
  301. /* USER CODE END SDIO_Init 0 */
  302. /* USER CODE BEGIN SDIO_Init 1 */
  303. /* USER CODE END SDIO_Init 1 */
  304. hsd.Instance = SDIO;
  305. hsd.Init.ClockEdge = SDIO_CLOCK_EDGE_RISING;
  306. hsd.Init.ClockBypass = SDIO_CLOCK_BYPASS_DISABLE;
  307. hsd.Init.ClockPowerSave = SDIO_CLOCK_POWER_SAVE_DISABLE;
  308. hsd.Init.BusWide = SDIO_BUS_WIDE_4B;
  309. hsd.Init.HardwareFlowControl = SDIO_HARDWARE_FLOW_CONTROL_DISABLE;
  310. hsd.Init.ClockDiv = 0;
  311. if (HAL_SD_Init(&hsd) != HAL_OK)
  312. {
  313. Error_Handler();
  314. }
  315. if (HAL_SD_ConfigWideBusOperation(&hsd, SDIO_BUS_WIDE_4B) != HAL_OK)
  316. {
  317. Error_Handler();
  318. }
  319. /* USER CODE BEGIN SDIO_Init 2 */
  320. /* USER CODE END SDIO_Init 2 */
  321. }
  322. /**
  323. * @brief SPI1 Initialization Function
  324. * @param None
  325. * @retval None
  326. */
  327. static void MX_SPI1_Init(void)
  328. {
  329. /* USER CODE BEGIN SPI1_Init 0 */
  330. /* USER CODE END SPI1_Init 0 */
  331. /* USER CODE BEGIN SPI1_Init 1 */
  332. /* USER CODE END SPI1_Init 1 */
  333. /* SPI1 parameter configuration*/
  334. hspi1.Instance = SPI1;
  335. hspi1.Init.Mode = SPI_MODE_MASTER;
  336. hspi1.Init.Direction = SPI_DIRECTION_2LINES;
  337. hspi1.Init.DataSize = SPI_DATASIZE_8BIT;
  338. hspi1.Init.CLKPolarity = SPI_POLARITY_LOW;
  339. hspi1.Init.CLKPhase = SPI_PHASE_1EDGE;
  340. hspi1.Init.NSS = SPI_NSS_SOFT;
  341. hspi1.Init.BaudRatePrescaler = SPI_BAUDRATEPRESCALER_2;
  342. hspi1.Init.FirstBit = SPI_FIRSTBIT_MSB;
  343. hspi1.Init.TIMode = SPI_TIMODE_DISABLE;
  344. hspi1.Init.CRCCalculation = SPI_CRCCALCULATION_DISABLE;
  345. hspi1.Init.CRCPolynomial = 10;
  346. if (HAL_SPI_Init(&hspi1) != HAL_OK)
  347. {
  348. Error_Handler();
  349. }
  350. /* USER CODE BEGIN SPI1_Init 2 */
  351. /* USER CODE END SPI1_Init 2 */
  352. }
  353. /**
  354. * @brief SPI2 Initialization Function
  355. * @param None
  356. * @retval None
  357. */
  358. static void MX_SPI2_Init(void)
  359. {
  360. /* USER CODE BEGIN SPI2_Init 0 */
  361. /* USER CODE END SPI2_Init 0 */
  362. /* USER CODE BEGIN SPI2_Init 1 */
  363. /* USER CODE END SPI2_Init 1 */
  364. /* SPI2 parameter configuration*/
  365. hspi2.Instance = SPI2;
  366. hspi2.Init.Mode = SPI_MODE_MASTER;
  367. hspi2.Init.Direction = SPI_DIRECTION_2LINES;
  368. hspi2.Init.DataSize = SPI_DATASIZE_8BIT;
  369. hspi2.Init.CLKPolarity = SPI_POLARITY_LOW;
  370. hspi2.Init.CLKPhase = SPI_PHASE_1EDGE;
  371. hspi2.Init.NSS = SPI_NSS_SOFT;
  372. hspi2.Init.BaudRatePrescaler = SPI_BAUDRATEPRESCALER_2;
  373. hspi2.Init.FirstBit = SPI_FIRSTBIT_MSB;
  374. hspi2.Init.TIMode = SPI_TIMODE_DISABLE;
  375. hspi2.Init.CRCCalculation = SPI_CRCCALCULATION_DISABLE;
  376. hspi2.Init.CRCPolynomial = 10;
  377. if (HAL_SPI_Init(&hspi2) != HAL_OK)
  378. {
  379. Error_Handler();
  380. }
  381. /* USER CODE BEGIN SPI2_Init 2 */
  382. /* USER CODE END SPI2_Init 2 */
  383. }
  384. /**
  385. * @brief TIM2 Initialization Function
  386. * @param None
  387. * @retval None
  388. */
  389. static void MX_TIM2_Init(void)
  390. {
  391. /* USER CODE BEGIN TIM2_Init 0 */
  392. /* USER CODE END TIM2_Init 0 */
  393. TIM_ClockConfigTypeDef sClockSourceConfig = {0};
  394. TIM_MasterConfigTypeDef sMasterConfig = {0};
  395. TIM_OC_InitTypeDef sConfigOC = {0};
  396. /* USER CODE BEGIN TIM2_Init 1 */
  397. /* USER CODE END TIM2_Init 1 */
  398. htim2.Instance = TIM2;
  399. htim2.Init.Prescaler = 0;
  400. htim2.Init.CounterMode = TIM_COUNTERMODE_UP;
  401. htim2.Init.Period = 4294967295;
  402. htim2.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1;
  403. htim2.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_DISABLE;
  404. if (HAL_TIM_Base_Init(&htim2) != HAL_OK)
  405. {
  406. Error_Handler();
  407. }
  408. sClockSourceConfig.ClockSource = TIM_CLOCKSOURCE_INTERNAL;
  409. if (HAL_TIM_ConfigClockSource(&htim2, &sClockSourceConfig) != HAL_OK)
  410. {
  411. Error_Handler();
  412. }
  413. if (HAL_TIM_PWM_Init(&htim2) != HAL_OK)
  414. {
  415. Error_Handler();
  416. }
  417. sMasterConfig.MasterOutputTrigger = TIM_TRGO_RESET;
  418. sMasterConfig.MasterSlaveMode = TIM_MASTERSLAVEMODE_DISABLE;
  419. if (HAL_TIMEx_MasterConfigSynchronization(&htim2, &sMasterConfig) != HAL_OK)
  420. {
  421. Error_Handler();
  422. }
  423. sConfigOC.OCMode = TIM_OCMODE_PWM1;
  424. sConfigOC.Pulse = 0;
  425. sConfigOC.OCPolarity = TIM_OCPOLARITY_HIGH;
  426. sConfigOC.OCFastMode = TIM_OCFAST_DISABLE;
  427. if (HAL_TIM_PWM_ConfigChannel(&htim2, &sConfigOC, TIM_CHANNEL_4) != HAL_OK)
  428. {
  429. Error_Handler();
  430. }
  431. /* USER CODE BEGIN TIM2_Init 2 */
  432. /* USER CODE END TIM2_Init 2 */
  433. HAL_TIM_MspPostInit(&htim2);
  434. }
  435. /**
  436. * @brief TIM3 Initialization Function
  437. * @param None
  438. * @retval None
  439. */
  440. static void MX_TIM3_Init(void)
  441. {
  442. /* USER CODE BEGIN TIM3_Init 0 */
  443. /* USER CODE END TIM3_Init 0 */
  444. TIM_ClockConfigTypeDef sClockSourceConfig = {0};
  445. TIM_MasterConfigTypeDef sMasterConfig = {0};
  446. TIM_OC_InitTypeDef sConfigOC = {0};
  447. /* USER CODE BEGIN TIM3_Init 1 */
  448. /* USER CODE END TIM3_Init 1 */
  449. htim3.Instance = TIM3;
  450. htim3.Init.Prescaler = 0;
  451. htim3.Init.CounterMode = TIM_COUNTERMODE_UP;
  452. htim3.Init.Period = 65535;
  453. htim3.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1;
  454. htim3.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_DISABLE;
  455. if (HAL_TIM_Base_Init(&htim3) != HAL_OK)
  456. {
  457. Error_Handler();
  458. }
  459. sClockSourceConfig.ClockSource = TIM_CLOCKSOURCE_INTERNAL;
  460. if (HAL_TIM_ConfigClockSource(&htim3, &sClockSourceConfig) != HAL_OK)
  461. {
  462. Error_Handler();
  463. }
  464. if (HAL_TIM_PWM_Init(&htim3) != HAL_OK)
  465. {
  466. Error_Handler();
  467. }
  468. sMasterConfig.MasterOutputTrigger = TIM_TRGO_RESET;
  469. sMasterConfig.MasterSlaveMode = TIM_MASTERSLAVEMODE_DISABLE;
  470. if (HAL_TIMEx_MasterConfigSynchronization(&htim3, &sMasterConfig) != HAL_OK)
  471. {
  472. Error_Handler();
  473. }
  474. sConfigOC.OCMode = TIM_OCMODE_PWM1;
  475. sConfigOC.Pulse = 0;
  476. sConfigOC.OCPolarity = TIM_OCPOLARITY_HIGH;
  477. sConfigOC.OCFastMode = TIM_OCFAST_DISABLE;
  478. if (HAL_TIM_PWM_ConfigChannel(&htim3, &sConfigOC, TIM_CHANNEL_4) != HAL_OK)
  479. {
  480. Error_Handler();
  481. }
  482. /* USER CODE BEGIN TIM3_Init 2 */
  483. /* USER CODE END TIM3_Init 2 */
  484. HAL_TIM_MspPostInit(&htim3);
  485. }
  486. /**
  487. * @brief TIM4 Initialization Function
  488. * @param None
  489. * @retval None
  490. */
  491. static void MX_TIM4_Init(void)
  492. {
  493. /* USER CODE BEGIN TIM4_Init 0 */
  494. /* USER CODE END TIM4_Init 0 */
  495. TIM_Encoder_InitTypeDef sConfig = {0};
  496. TIM_MasterConfigTypeDef sMasterConfig = {0};
  497. /* USER CODE BEGIN TIM4_Init 1 */
  498. /* USER CODE END TIM4_Init 1 */
  499. htim4.Instance = TIM4;
  500. htim4.Init.Prescaler = 0;
  501. htim4.Init.CounterMode = TIM_COUNTERMODE_UP;
  502. htim4.Init.Period = 65535;
  503. htim4.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1;
  504. htim4.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_DISABLE;
  505. sConfig.EncoderMode = TIM_ENCODERMODE_TI1;
  506. sConfig.IC1Polarity = TIM_ICPOLARITY_RISING;
  507. sConfig.IC1Selection = TIM_ICSELECTION_DIRECTTI;
  508. sConfig.IC1Prescaler = TIM_ICPSC_DIV1;
  509. sConfig.IC1Filter = 0;
  510. sConfig.IC2Polarity = TIM_ICPOLARITY_RISING;
  511. sConfig.IC2Selection = TIM_ICSELECTION_DIRECTTI;
  512. sConfig.IC2Prescaler = TIM_ICPSC_DIV1;
  513. sConfig.IC2Filter = 0;
  514. if (HAL_TIM_Encoder_Init(&htim4, &sConfig) != HAL_OK)
  515. {
  516. Error_Handler();
  517. }
  518. sMasterConfig.MasterOutputTrigger = TIM_TRGO_RESET;
  519. sMasterConfig.MasterSlaveMode = TIM_MASTERSLAVEMODE_DISABLE;
  520. if (HAL_TIMEx_MasterConfigSynchronization(&htim4, &sMasterConfig) != HAL_OK)
  521. {
  522. Error_Handler();
  523. }
  524. /* USER CODE BEGIN TIM4_Init 2 */
  525. /* USER CODE END TIM4_Init 2 */
  526. }
  527. /**
  528. * @brief TIM11 Initialization Function
  529. * @param None
  530. * @retval None
  531. */
  532. static void MX_TIM11_Init(void)
  533. {
  534. /* USER CODE BEGIN TIM11_Init 0 */
  535. /* USER CODE END TIM11_Init 0 */
  536. /* USER CODE BEGIN TIM11_Init 1 */
  537. /* USER CODE END TIM11_Init 1 */
  538. htim11.Instance = TIM11;
  539. htim11.Init.Prescaler = 0;
  540. htim11.Init.CounterMode = TIM_COUNTERMODE_UP;
  541. htim11.Init.Period = 65535;
  542. htim11.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1;
  543. htim11.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_DISABLE;
  544. if (HAL_TIM_Base_Init(&htim11) != HAL_OK)
  545. {
  546. Error_Handler();
  547. }
  548. /* USER CODE BEGIN TIM11_Init 2 */
  549. /* USER CODE END TIM11_Init 2 */
  550. }
  551. /**
  552. * @brief TIM13 Initialization Function
  553. * @param None
  554. * @retval None
  555. */
  556. static void MX_TIM13_Init(void)
  557. {
  558. /* USER CODE BEGIN TIM13_Init 0 */
  559. /* USER CODE END TIM13_Init 0 */
  560. /* USER CODE BEGIN TIM13_Init 1 */
  561. /* USER CODE END TIM13_Init 1 */
  562. htim13.Instance = TIM13;
  563. htim13.Init.Prescaler = 0;
  564. htim13.Init.CounterMode = TIM_COUNTERMODE_UP;
  565. htim13.Init.Period = 65535;
  566. htim13.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1;
  567. htim13.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_DISABLE;
  568. if (HAL_TIM_Base_Init(&htim13) != HAL_OK)
  569. {
  570. Error_Handler();
  571. }
  572. /* USER CODE BEGIN TIM13_Init 2 */
  573. /* USER CODE END TIM13_Init 2 */
  574. }
  575. /**
  576. * @brief TIM14 Initialization Function
  577. * @param None
  578. * @retval None
  579. */
  580. static void MX_TIM14_Init(void)
  581. {
  582. /* USER CODE BEGIN TIM14_Init 0 */
  583. /* USER CODE END TIM14_Init 0 */
  584. TIM_OC_InitTypeDef sConfigOC = {0};
  585. /* USER CODE BEGIN TIM14_Init 1 */
  586. /* USER CODE END TIM14_Init 1 */
  587. htim14.Instance = TIM14;
  588. htim14.Init.Prescaler = 0;
  589. htim14.Init.CounterMode = TIM_COUNTERMODE_UP;
  590. htim14.Init.Period = 65535;
  591. htim14.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1;
  592. htim14.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_DISABLE;
  593. if (HAL_TIM_Base_Init(&htim14) != HAL_OK)
  594. {
  595. Error_Handler();
  596. }
  597. if (HAL_TIM_PWM_Init(&htim14) != HAL_OK)
  598. {
  599. Error_Handler();
  600. }
  601. sConfigOC.OCMode = TIM_OCMODE_PWM1;
  602. sConfigOC.Pulse = 0;
  603. sConfigOC.OCPolarity = TIM_OCPOLARITY_HIGH;
  604. sConfigOC.OCFastMode = TIM_OCFAST_DISABLE;
  605. if (HAL_TIM_PWM_ConfigChannel(&htim14, &sConfigOC, TIM_CHANNEL_1) != HAL_OK)
  606. {
  607. Error_Handler();
  608. }
  609. /* USER CODE BEGIN TIM14_Init 2 */
  610. /* USER CODE END TIM14_Init 2 */
  611. HAL_TIM_MspPostInit(&htim14);
  612. }
  613. /**
  614. * @brief USART1 Initialization Function
  615. * @param None
  616. * @retval None
  617. */
  618. static void MX_USART1_UART_Init(void)
  619. {
  620. /* USER CODE BEGIN USART1_Init 0 */
  621. /* USER CODE END USART1_Init 0 */
  622. /* USER CODE BEGIN USART1_Init 1 */
  623. /* USER CODE END USART1_Init 1 */
  624. huart1.Instance = USART1;
  625. huart1.Init.BaudRate = 115200;
  626. huart1.Init.WordLength = UART_WORDLENGTH_8B;
  627. huart1.Init.StopBits = UART_STOPBITS_1;
  628. huart1.Init.Parity = UART_PARITY_NONE;
  629. huart1.Init.Mode = UART_MODE_TX_RX;
  630. huart1.Init.HwFlowCtl = UART_HWCONTROL_NONE;
  631. huart1.Init.OverSampling = UART_OVERSAMPLING_16;
  632. if (HAL_UART_Init(&huart1) != HAL_OK)
  633. {
  634. Error_Handler();
  635. }
  636. /* USER CODE BEGIN USART1_Init 2 */
  637. /* USER CODE END USART1_Init 2 */
  638. }
  639. /**
  640. * @brief USART3 Initialization Function
  641. * @param None
  642. * @retval None
  643. */
  644. static void MX_USART3_UART_Init(void)
  645. {
  646. /* USER CODE BEGIN USART3_Init 0 */
  647. /* USER CODE END USART3_Init 0 */
  648. /* USER CODE BEGIN USART3_Init 1 */
  649. /* USER CODE END USART3_Init 1 */
  650. huart3.Instance = USART3;
  651. huart3.Init.BaudRate = 115200;
  652. huart3.Init.WordLength = UART_WORDLENGTH_8B;
  653. huart3.Init.StopBits = UART_STOPBITS_1;
  654. huart3.Init.Parity = UART_PARITY_NONE;
  655. huart3.Init.Mode = UART_MODE_TX_RX;
  656. huart3.Init.HwFlowCtl = UART_HWCONTROL_NONE;
  657. huart3.Init.OverSampling = UART_OVERSAMPLING_16;
  658. if (HAL_UART_Init(&huart3) != HAL_OK)
  659. {
  660. Error_Handler();
  661. }
  662. /* USER CODE BEGIN USART3_Init 2 */
  663. /* USER CODE END USART3_Init 2 */
  664. }
  665. /**
  666. * @brief USB_OTG_FS Initialization Function
  667. * @param None
  668. * @retval None
  669. */
  670. static void MX_USB_OTG_FS_PCD_Init(void)
  671. {
  672. /* USER CODE BEGIN USB_OTG_FS_Init 0 */
  673. /* USER CODE END USB_OTG_FS_Init 0 */
  674. /* USER CODE BEGIN USB_OTG_FS_Init 1 */
  675. /* USER CODE END USB_OTG_FS_Init 1 */
  676. hpcd_USB_OTG_FS.Instance = USB_OTG_FS;
  677. hpcd_USB_OTG_FS.Init.dev_endpoints = 4;
  678. hpcd_USB_OTG_FS.Init.speed = PCD_SPEED_FULL;
  679. hpcd_USB_OTG_FS.Init.dma_enable = DISABLE;
  680. hpcd_USB_OTG_FS.Init.phy_itface = PCD_PHY_EMBEDDED;
  681. hpcd_USB_OTG_FS.Init.Sof_enable = DISABLE;
  682. hpcd_USB_OTG_FS.Init.low_power_enable = DISABLE;
  683. hpcd_USB_OTG_FS.Init.lpm_enable = DISABLE;
  684. hpcd_USB_OTG_FS.Init.vbus_sensing_enable = DISABLE;
  685. hpcd_USB_OTG_FS.Init.use_dedicated_ep1 = DISABLE;
  686. if (HAL_PCD_Init(&hpcd_USB_OTG_FS) != HAL_OK)
  687. {
  688. Error_Handler();
  689. }
  690. /* USER CODE BEGIN USB_OTG_FS_Init 2 */
  691. /* USER CODE END USB_OTG_FS_Init 2 */
  692. }
  693. /**
  694. * @brief GPIO Initialization Function
  695. * @param None
  696. * @retval None
  697. */
  698. static void MX_GPIO_Init(void)
  699. {
  700. /* USER CODE BEGIN MX_GPIO_Init_1 */
  701. /* USER CODE END MX_GPIO_Init_1 */
  702. /* GPIO Ports Clock Enable */
  703. __HAL_RCC_GPIOC_CLK_ENABLE();
  704. __HAL_RCC_GPIOF_CLK_ENABLE();
  705. __HAL_RCC_GPIOH_CLK_ENABLE();
  706. __HAL_RCC_GPIOA_CLK_ENABLE();
  707. __HAL_RCC_GPIOB_CLK_ENABLE();
  708. __HAL_RCC_GPIOE_CLK_ENABLE();
  709. __HAL_RCC_GPIOD_CLK_ENABLE();
  710. __HAL_RCC_GPIOG_CLK_ENABLE();
  711. /* USER CODE BEGIN MX_GPIO_Init_2 */
  712. /* USER CODE END MX_GPIO_Init_2 */
  713. }
  714. /* FSMC initialization function */
  715. static void MX_FSMC_Init(void)
  716. {
  717. /* USER CODE BEGIN FSMC_Init 0 */
  718. /* USER CODE END FSMC_Init 0 */
  719. FSMC_NORSRAM_TimingTypeDef Timing = {0};
  720. /* USER CODE BEGIN FSMC_Init 1 */
  721. /* USER CODE END FSMC_Init 1 */
  722. /** Perform the SRAM1 memory initialization sequence
  723. */
  724. hsram1.Instance = FSMC_NORSRAM_DEVICE;
  725. hsram1.Extended = FSMC_NORSRAM_EXTENDED_DEVICE;
  726. /* hsram1.Init */
  727. hsram1.Init.NSBank = FSMC_NORSRAM_BANK3;
  728. hsram1.Init.DataAddressMux = FSMC_DATA_ADDRESS_MUX_DISABLE;
  729. hsram1.Init.MemoryType = FSMC_MEMORY_TYPE_SRAM;
  730. hsram1.Init.MemoryDataWidth = FSMC_NORSRAM_MEM_BUS_WIDTH_8;
  731. hsram1.Init.BurstAccessMode = FSMC_BURST_ACCESS_MODE_DISABLE;
  732. hsram1.Init.WaitSignalPolarity = FSMC_WAIT_SIGNAL_POLARITY_LOW;
  733. hsram1.Init.WrapMode = FSMC_WRAP_MODE_DISABLE;
  734. hsram1.Init.WaitSignalActive = FSMC_WAIT_TIMING_BEFORE_WS;
  735. hsram1.Init.WriteOperation = FSMC_WRITE_OPERATION_ENABLE;
  736. hsram1.Init.WaitSignal = FSMC_WAIT_SIGNAL_DISABLE;
  737. hsram1.Init.ExtendedMode = FSMC_EXTENDED_MODE_DISABLE;
  738. hsram1.Init.AsynchronousWait = FSMC_ASYNCHRONOUS_WAIT_DISABLE;
  739. hsram1.Init.WriteBurst = FSMC_WRITE_BURST_DISABLE;
  740. hsram1.Init.PageSize = FSMC_PAGE_SIZE_NONE;
  741. /* Timing */
  742. Timing.AddressSetupTime = 15;
  743. Timing.AddressHoldTime = 15;
  744. Timing.DataSetupTime = 255;
  745. Timing.BusTurnAroundDuration = 15;
  746. Timing.CLKDivision = 16;
  747. Timing.DataLatency = 17;
  748. Timing.AccessMode = FSMC_ACCESS_MODE_A;
  749. /* ExtTiming */
  750. if (HAL_SRAM_Init(&hsram1, &Timing, NULL) != HAL_OK)
  751. {
  752. Error_Handler( );
  753. }
  754. /* USER CODE BEGIN FSMC_Init 2 */
  755. /* USER CODE END FSMC_Init 2 */
  756. }
  757. /* USER CODE BEGIN 4 */
  758. /* USER CODE END 4 */
  759. /**
  760. * @brief This function is executed in case of error occurrence.
  761. * @retval None
  762. */
  763. void Error_Handler(void)
  764. {
  765. /* USER CODE BEGIN Error_Handler_Debug */
  766. /* User can add his own implementation to report the HAL error return state */
  767. __disable_irq();
  768. while (1)
  769. {
  770. }
  771. /* USER CODE END Error_Handler_Debug */
  772. }
  773. #ifdef USE_FULL_ASSERT
  774. /**
  775. * @brief Reports the name of the source file and the source line number
  776. * where the assert_param error has occurred.
  777. * @param file: pointer to the source file name
  778. * @param line: assert_param error line source number
  779. * @retval None
  780. */
  781. void assert_failed(uint8_t *file, uint32_t line)
  782. {
  783. /* USER CODE BEGIN 6 */
  784. /* User can add his own implementation to report the file name and line number,
  785. ex: printf("Wrong parameters value: file %s on line %d\r\n", file, line) */
  786. /* USER CODE END 6 */
  787. }
  788. #endif /* USE_FULL_ASSERT */