tim.c 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432
  1. /* USER CODE BEGIN Header */
  2. /**
  3. ******************************************************************************
  4. * @file tim.c
  5. * @brief This file provides code for the configuration
  6. * of the TIM 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 "tim.h"
  22. /* USER CODE BEGIN 0 */
  23. /* USER CODE END 0 */
  24. TIM_HandleTypeDef htim1;
  25. TIM_HandleTypeDef htim2;
  26. TIM_HandleTypeDef htim7;
  27. TIM_HandleTypeDef htim15;
  28. DMA_HandleTypeDef hdma_tim1_ch1;
  29. DMA_HandleTypeDef hdma_tim1_ch2;
  30. /* TIM1 init function */
  31. void MX_TIM1_Init(void)
  32. {
  33. /* USER CODE BEGIN TIM1_Init 0 */
  34. /* USER CODE END TIM1_Init 0 */
  35. TIM_ClockConfigTypeDef sClockSourceConfig = {0};
  36. TIM_SlaveConfigTypeDef sSlaveConfig = {0};
  37. TIM_MasterConfigTypeDef sMasterConfig = {0};
  38. TIM_IC_InitTypeDef sConfigIC = {0};
  39. /* USER CODE BEGIN TIM1_Init 1 */
  40. /* USER CODE END TIM1_Init 1 */
  41. htim1.Instance = TIM1;
  42. htim1.Init.Prescaler = 80-1;
  43. htim1.Init.CounterMode = TIM_COUNTERMODE_UP;
  44. htim1.Init.Period = 65535;
  45. htim1.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1;
  46. htim1.Init.RepetitionCounter = 0;
  47. htim1.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_ENABLE;
  48. if (HAL_TIM_Base_Init(&htim1) != HAL_OK)
  49. {
  50. Error_Handler();
  51. }
  52. sClockSourceConfig.ClockSource = TIM_CLOCKSOURCE_INTERNAL;
  53. if (HAL_TIM_ConfigClockSource(&htim1, &sClockSourceConfig) != HAL_OK)
  54. {
  55. Error_Handler();
  56. }
  57. if (HAL_TIM_IC_Init(&htim1) != HAL_OK)
  58. {
  59. Error_Handler();
  60. }
  61. sSlaveConfig.SlaveMode = TIM_SLAVEMODE_RESET;
  62. sSlaveConfig.InputTrigger = TIM_TS_TI1FP1;
  63. sSlaveConfig.TriggerPolarity = TIM_INPUTCHANNELPOLARITY_RISING;
  64. sSlaveConfig.TriggerFilter = 0;
  65. if (HAL_TIM_SlaveConfigSynchro(&htim1, &sSlaveConfig) != HAL_OK)
  66. {
  67. Error_Handler();
  68. }
  69. sMasterConfig.MasterOutputTrigger = TIM_TRGO_RESET;
  70. sMasterConfig.MasterOutputTrigger2 = TIM_TRGO2_RESET;
  71. sMasterConfig.MasterSlaveMode = TIM_MASTERSLAVEMODE_DISABLE;
  72. if (HAL_TIMEx_MasterConfigSynchronization(&htim1, &sMasterConfig) != HAL_OK)
  73. {
  74. Error_Handler();
  75. }
  76. sConfigIC.ICPolarity = TIM_INPUTCHANNELPOLARITY_RISING;
  77. sConfigIC.ICSelection = TIM_ICSELECTION_DIRECTTI;
  78. sConfigIC.ICPrescaler = TIM_ICPSC_DIV1;
  79. sConfigIC.ICFilter = 0;
  80. if (HAL_TIM_IC_ConfigChannel(&htim1, &sConfigIC, TIM_CHANNEL_1) != HAL_OK)
  81. {
  82. Error_Handler();
  83. }
  84. sConfigIC.ICPolarity = TIM_INPUTCHANNELPOLARITY_FALLING;
  85. sConfigIC.ICSelection = TIM_ICSELECTION_INDIRECTTI;
  86. if (HAL_TIM_IC_ConfigChannel(&htim1, &sConfigIC, TIM_CHANNEL_2) != HAL_OK)
  87. {
  88. Error_Handler();
  89. }
  90. /* USER CODE BEGIN TIM1_Init 2 */
  91. /* USER CODE END TIM1_Init 2 */
  92. }
  93. /* TIM2 init function */
  94. void MX_TIM2_Init(void)
  95. {
  96. /* USER CODE BEGIN TIM2_Init 0 */
  97. /* USER CODE END TIM2_Init 0 */
  98. TIM_ClockConfigTypeDef sClockSourceConfig = {0};
  99. TIM_MasterConfigTypeDef sMasterConfig = {0};
  100. TIM_OC_InitTypeDef sConfigOC = {0};
  101. /* USER CODE BEGIN TIM2_Init 1 */
  102. /* USER CODE END TIM2_Init 1 */
  103. htim2.Instance = TIM2;
  104. htim2.Init.Prescaler = 40-1;
  105. htim2.Init.CounterMode = TIM_COUNTERMODE_UP;
  106. htim2.Init.Period = 1000-1;
  107. htim2.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1;
  108. htim2.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_DISABLE;
  109. if (HAL_TIM_Base_Init(&htim2) != HAL_OK)
  110. {
  111. Error_Handler();
  112. }
  113. sClockSourceConfig.ClockSource = TIM_CLOCKSOURCE_INTERNAL;
  114. if (HAL_TIM_ConfigClockSource(&htim2, &sClockSourceConfig) != HAL_OK)
  115. {
  116. Error_Handler();
  117. }
  118. if (HAL_TIM_PWM_Init(&htim2) != HAL_OK)
  119. {
  120. Error_Handler();
  121. }
  122. sMasterConfig.MasterOutputTrigger = TIM_TRGO_RESET;
  123. sMasterConfig.MasterSlaveMode = TIM_MASTERSLAVEMODE_DISABLE;
  124. if (HAL_TIMEx_MasterConfigSynchronization(&htim2, &sMasterConfig) != HAL_OK)
  125. {
  126. Error_Handler();
  127. }
  128. sConfigOC.OCMode = TIM_OCMODE_PWM1;
  129. sConfigOC.Pulse = 500;
  130. sConfigOC.OCPolarity = TIM_OCPOLARITY_HIGH;
  131. sConfigOC.OCFastMode = TIM_OCFAST_DISABLE;
  132. if (HAL_TIM_PWM_ConfigChannel(&htim2, &sConfigOC, TIM_CHANNEL_3) != HAL_OK)
  133. {
  134. Error_Handler();
  135. }
  136. if (HAL_TIM_PWM_ConfigChannel(&htim2, &sConfigOC, TIM_CHANNEL_4) != HAL_OK)
  137. {
  138. Error_Handler();
  139. }
  140. /* USER CODE BEGIN TIM2_Init 2 */
  141. /* USER CODE END TIM2_Init 2 */
  142. HAL_TIM_MspPostInit(&htim2);
  143. }
  144. /* TIM7 init function */
  145. void MX_TIM7_Init(void)
  146. {
  147. /* USER CODE BEGIN TIM7_Init 0 */
  148. /* USER CODE END TIM7_Init 0 */
  149. TIM_MasterConfigTypeDef sMasterConfig = {0};
  150. /* USER CODE BEGIN TIM7_Init 1 */
  151. /* USER CODE END TIM7_Init 1 */
  152. htim7.Instance = TIM7;
  153. htim7.Init.Prescaler = 80-1;
  154. htim7.Init.CounterMode = TIM_COUNTERMODE_UP;
  155. htim7.Init.Period = 65535;
  156. htim7.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_DISABLE;
  157. if (HAL_TIM_Base_Init(&htim7) != HAL_OK)
  158. {
  159. Error_Handler();
  160. }
  161. sMasterConfig.MasterOutputTrigger = TIM_TRGO_RESET;
  162. sMasterConfig.MasterSlaveMode = TIM_MASTERSLAVEMODE_DISABLE;
  163. if (HAL_TIMEx_MasterConfigSynchronization(&htim7, &sMasterConfig) != HAL_OK)
  164. {
  165. Error_Handler();
  166. }
  167. /* USER CODE BEGIN TIM7_Init 2 */
  168. /* USER CODE END TIM7_Init 2 */
  169. }
  170. /* TIM15 init function */
  171. void MX_TIM15_Init(void)
  172. {
  173. /* USER CODE BEGIN TIM15_Init 0 */
  174. /* USER CODE END TIM15_Init 0 */
  175. TIM_ClockConfigTypeDef sClockSourceConfig = {0};
  176. TIM_MasterConfigTypeDef sMasterConfig = {0};
  177. /* USER CODE BEGIN TIM15_Init 1 */
  178. /* USER CODE END TIM15_Init 1 */
  179. htim15.Instance = TIM15;
  180. htim15.Init.Prescaler = 80-1;
  181. htim15.Init.CounterMode = TIM_COUNTERMODE_UP;
  182. htim15.Init.Period = 65535;
  183. htim15.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1;
  184. htim15.Init.RepetitionCounter = 0;
  185. htim15.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_DISABLE;
  186. if (HAL_TIM_Base_Init(&htim15) != HAL_OK)
  187. {
  188. Error_Handler();
  189. }
  190. sClockSourceConfig.ClockSource = TIM_CLOCKSOURCE_INTERNAL;
  191. if (HAL_TIM_ConfigClockSource(&htim15, &sClockSourceConfig) != HAL_OK)
  192. {
  193. Error_Handler();
  194. }
  195. sMasterConfig.MasterOutputTrigger = TIM_TRGO_RESET;
  196. sMasterConfig.MasterSlaveMode = TIM_MASTERSLAVEMODE_DISABLE;
  197. if (HAL_TIMEx_MasterConfigSynchronization(&htim15, &sMasterConfig) != HAL_OK)
  198. {
  199. Error_Handler();
  200. }
  201. /* USER CODE BEGIN TIM15_Init 2 */
  202. /* USER CODE END TIM15_Init 2 */
  203. }
  204. void HAL_TIM_Base_MspInit(TIM_HandleTypeDef* tim_baseHandle)
  205. {
  206. GPIO_InitTypeDef GPIO_InitStruct = {0};
  207. if(tim_baseHandle->Instance==TIM1)
  208. {
  209. /* USER CODE BEGIN TIM1_MspInit 0 */
  210. /* USER CODE END TIM1_MspInit 0 */
  211. /* TIM1 clock enable */
  212. __HAL_RCC_TIM1_CLK_ENABLE();
  213. __HAL_RCC_GPIOA_CLK_ENABLE();
  214. /**TIM1 GPIO Configuration
  215. PA8 ------> TIM1_CH1
  216. */
  217. GPIO_InitStruct.Pin = GPIO_PIN_8;
  218. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  219. GPIO_InitStruct.Pull = GPIO_NOPULL;
  220. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
  221. GPIO_InitStruct.Alternate = GPIO_AF1_TIM1;
  222. HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
  223. /* TIM1 DMA Init */
  224. /* TIM1_CH1 Init */
  225. hdma_tim1_ch1.Instance = DMA1_Channel2;
  226. hdma_tim1_ch1.Init.Request = DMA_REQUEST_7;
  227. hdma_tim1_ch1.Init.Direction = DMA_PERIPH_TO_MEMORY;
  228. hdma_tim1_ch1.Init.PeriphInc = DMA_PINC_DISABLE;
  229. hdma_tim1_ch1.Init.MemInc = DMA_MINC_ENABLE;
  230. hdma_tim1_ch1.Init.PeriphDataAlignment = DMA_PDATAALIGN_HALFWORD;
  231. hdma_tim1_ch1.Init.MemDataAlignment = DMA_MDATAALIGN_HALFWORD;
  232. hdma_tim1_ch1.Init.Mode = DMA_CIRCULAR;
  233. hdma_tim1_ch1.Init.Priority = DMA_PRIORITY_LOW;
  234. if (HAL_DMA_Init(&hdma_tim1_ch1) != HAL_OK)
  235. {
  236. Error_Handler();
  237. }
  238. __HAL_LINKDMA(tim_baseHandle,hdma[TIM_DMA_ID_CC1],hdma_tim1_ch1);
  239. /* TIM1_CH2 Init */
  240. hdma_tim1_ch2.Instance = DMA1_Channel3;
  241. hdma_tim1_ch2.Init.Request = DMA_REQUEST_7;
  242. hdma_tim1_ch2.Init.Direction = DMA_PERIPH_TO_MEMORY;
  243. hdma_tim1_ch2.Init.PeriphInc = DMA_PINC_DISABLE;
  244. hdma_tim1_ch2.Init.MemInc = DMA_MINC_ENABLE;
  245. hdma_tim1_ch2.Init.PeriphDataAlignment = DMA_PDATAALIGN_HALFWORD;
  246. hdma_tim1_ch2.Init.MemDataAlignment = DMA_MDATAALIGN_HALFWORD;
  247. hdma_tim1_ch2.Init.Mode = DMA_CIRCULAR;
  248. hdma_tim1_ch2.Init.Priority = DMA_PRIORITY_LOW;
  249. if (HAL_DMA_Init(&hdma_tim1_ch2) != HAL_OK)
  250. {
  251. Error_Handler();
  252. }
  253. __HAL_LINKDMA(tim_baseHandle,hdma[TIM_DMA_ID_CC2],hdma_tim1_ch2);
  254. /* TIM1 interrupt Init */
  255. HAL_NVIC_SetPriority(TIM1_TRG_COM_IRQn, 5, 0);
  256. HAL_NVIC_EnableIRQ(TIM1_TRG_COM_IRQn);
  257. HAL_NVIC_SetPriority(TIM1_CC_IRQn, 5, 0);
  258. HAL_NVIC_EnableIRQ(TIM1_CC_IRQn);
  259. /* USER CODE BEGIN TIM1_MspInit 1 */
  260. /* USER CODE END TIM1_MspInit 1 */
  261. }
  262. else if(tim_baseHandle->Instance==TIM2)
  263. {
  264. /* USER CODE BEGIN TIM2_MspInit 0 */
  265. /* USER CODE END TIM2_MspInit 0 */
  266. /* TIM2 clock enable */
  267. __HAL_RCC_TIM2_CLK_ENABLE();
  268. /* USER CODE BEGIN TIM2_MspInit 1 */
  269. /* USER CODE END TIM2_MspInit 1 */
  270. }
  271. else if(tim_baseHandle->Instance==TIM7)
  272. {
  273. /* USER CODE BEGIN TIM7_MspInit 0 */
  274. /* USER CODE END TIM7_MspInit 0 */
  275. /* TIM7 clock enable */
  276. __HAL_RCC_TIM7_CLK_ENABLE();
  277. /* USER CODE BEGIN TIM7_MspInit 1 */
  278. /* USER CODE END TIM7_MspInit 1 */
  279. }
  280. else if(tim_baseHandle->Instance==TIM15)
  281. {
  282. /* USER CODE BEGIN TIM15_MspInit 0 */
  283. /* USER CODE END TIM15_MspInit 0 */
  284. /* TIM15 clock enable */
  285. __HAL_RCC_TIM15_CLK_ENABLE();
  286. /* USER CODE BEGIN TIM15_MspInit 1 */
  287. /* USER CODE END TIM15_MspInit 1 */
  288. }
  289. }
  290. void HAL_TIM_MspPostInit(TIM_HandleTypeDef* timHandle)
  291. {
  292. GPIO_InitTypeDef GPIO_InitStruct = {0};
  293. if(timHandle->Instance==TIM2)
  294. {
  295. /* USER CODE BEGIN TIM2_MspPostInit 0 */
  296. /* USER CODE END TIM2_MspPostInit 0 */
  297. __HAL_RCC_GPIOB_CLK_ENABLE();
  298. /**TIM2 GPIO Configuration
  299. PB10 ------> TIM2_CH3
  300. PB11 ------> TIM2_CH4
  301. */
  302. GPIO_InitStruct.Pin = GPIO_PIN_10|GPIO_PIN_11;
  303. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  304. GPIO_InitStruct.Pull = GPIO_NOPULL;
  305. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
  306. GPIO_InitStruct.Alternate = GPIO_AF1_TIM2;
  307. HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
  308. /* USER CODE BEGIN TIM2_MspPostInit 1 */
  309. /* USER CODE END TIM2_MspPostInit 1 */
  310. }
  311. }
  312. void HAL_TIM_Base_MspDeInit(TIM_HandleTypeDef* tim_baseHandle)
  313. {
  314. if(tim_baseHandle->Instance==TIM1)
  315. {
  316. /* USER CODE BEGIN TIM1_MspDeInit 0 */
  317. /* USER CODE END TIM1_MspDeInit 0 */
  318. /* Peripheral clock disable */
  319. __HAL_RCC_TIM1_CLK_DISABLE();
  320. /**TIM1 GPIO Configuration
  321. PA8 ------> TIM1_CH1
  322. */
  323. HAL_GPIO_DeInit(GPIOA, GPIO_PIN_8);
  324. /* TIM1 DMA DeInit */
  325. HAL_DMA_DeInit(tim_baseHandle->hdma[TIM_DMA_ID_CC1]);
  326. HAL_DMA_DeInit(tim_baseHandle->hdma[TIM_DMA_ID_CC2]);
  327. /* TIM1 interrupt Deinit */
  328. HAL_NVIC_DisableIRQ(TIM1_TRG_COM_IRQn);
  329. HAL_NVIC_DisableIRQ(TIM1_CC_IRQn);
  330. /* USER CODE BEGIN TIM1_MspDeInit 1 */
  331. /* USER CODE END TIM1_MspDeInit 1 */
  332. }
  333. else if(tim_baseHandle->Instance==TIM2)
  334. {
  335. /* USER CODE BEGIN TIM2_MspDeInit 0 */
  336. /* USER CODE END TIM2_MspDeInit 0 */
  337. /* Peripheral clock disable */
  338. __HAL_RCC_TIM2_CLK_DISABLE();
  339. /* USER CODE BEGIN TIM2_MspDeInit 1 */
  340. /* USER CODE END TIM2_MspDeInit 1 */
  341. }
  342. else if(tim_baseHandle->Instance==TIM7)
  343. {
  344. /* USER CODE BEGIN TIM7_MspDeInit 0 */
  345. /* USER CODE END TIM7_MspDeInit 0 */
  346. /* Peripheral clock disable */
  347. __HAL_RCC_TIM7_CLK_DISABLE();
  348. /* USER CODE BEGIN TIM7_MspDeInit 1 */
  349. /* USER CODE END TIM7_MspDeInit 1 */
  350. }
  351. else if(tim_baseHandle->Instance==TIM15)
  352. {
  353. /* USER CODE BEGIN TIM15_MspDeInit 0 */
  354. /* USER CODE END TIM15_MspDeInit 0 */
  355. /* Peripheral clock disable */
  356. __HAL_RCC_TIM15_CLK_DISABLE();
  357. /* USER CODE BEGIN TIM15_MspDeInit 1 */
  358. /* USER CODE END TIM15_MspDeInit 1 */
  359. }
  360. }
  361. /* USER CODE BEGIN 1 */
  362. /* USER CODE END 1 */