tim.c 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347
  1. /**
  2. ******************************************************************************
  3. * @file tim.c
  4. * @brief This file provides code for the configuration
  5. * of the TIM instances.
  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 Ultimate Liberty license
  13. * SLA0044, the "License"; You may not use this file except in compliance with
  14. * the License. You may obtain a copy of the License at:
  15. * www.st.com/SLA0044
  16. *
  17. ******************************************************************************
  18. */
  19. /* Includes ------------------------------------------------------------------*/
  20. #include "tim.h"
  21. /* USER CODE BEGIN 0 */
  22. /* USER CODE END 0 */
  23. TIM_HandleTypeDef htim1;
  24. TIM_HandleTypeDef htim2;
  25. TIM_HandleTypeDef htim16;
  26. /* TIM1 init function */
  27. void MX_TIM1_Init(void) {
  28. /* USER CODE BEGIN TIM1_Init 0 */
  29. /* USER CODE END TIM1_Init 0 */
  30. TIM_ClockConfigTypeDef sClockSourceConfig = {0};
  31. TIM_MasterConfigTypeDef sMasterConfig = {0};
  32. TIM_OC_InitTypeDef sConfigOC = {0};
  33. TIM_BreakDeadTimeConfigTypeDef sBreakDeadTimeConfig = {0};
  34. /* USER CODE BEGIN TIM1_Init 1 */
  35. /* USER CODE END TIM1_Init 1 */
  36. htim1.Instance = TIM1;
  37. htim1.Init.Prescaler = 0;
  38. htim1.Init.CounterMode = TIM_COUNTERMODE_UP;
  39. htim1.Init.Period = 65535;
  40. htim1.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1;
  41. htim1.Init.RepetitionCounter = 0;
  42. htim1.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_DISABLE;
  43. if(HAL_TIM_Base_Init(&htim1) != HAL_OK) {
  44. Error_Handler();
  45. }
  46. sClockSourceConfig.ClockSource = TIM_CLOCKSOURCE_INTERNAL;
  47. if(HAL_TIM_ConfigClockSource(&htim1, &sClockSourceConfig) != HAL_OK) {
  48. Error_Handler();
  49. }
  50. if(HAL_TIM_OC_Init(&htim1) != HAL_OK) {
  51. Error_Handler();
  52. }
  53. if(HAL_TIM_PWM_Init(&htim1) != HAL_OK) {
  54. Error_Handler();
  55. }
  56. sMasterConfig.MasterOutputTrigger = TIM_TRGO_RESET;
  57. sMasterConfig.MasterOutputTrigger2 = TIM_TRGO2_RESET;
  58. sMasterConfig.MasterSlaveMode = TIM_MASTERSLAVEMODE_DISABLE;
  59. if(HAL_TIMEx_MasterConfigSynchronization(&htim1, &sMasterConfig) != HAL_OK) {
  60. Error_Handler();
  61. }
  62. sConfigOC.OCMode = TIM_OCMODE_TIMING;
  63. sConfigOC.Pulse = 0;
  64. sConfigOC.OCPolarity = TIM_OCPOLARITY_HIGH;
  65. sConfigOC.OCNPolarity = TIM_OCNPOLARITY_HIGH;
  66. sConfigOC.OCFastMode = TIM_OCFAST_DISABLE;
  67. sConfigOC.OCIdleState = TIM_OCIDLESTATE_RESET;
  68. sConfigOC.OCNIdleState = TIM_OCNIDLESTATE_RESET;
  69. if(HAL_TIM_OC_ConfigChannel(&htim1, &sConfigOC, TIM_CHANNEL_1) != HAL_OK) {
  70. Error_Handler();
  71. }
  72. sConfigOC.OCMode = TIM_OCMODE_PWM1;
  73. if(HAL_TIM_PWM_ConfigChannel(&htim1, &sConfigOC, TIM_CHANNEL_3) != HAL_OK) {
  74. Error_Handler();
  75. }
  76. sBreakDeadTimeConfig.OffStateRunMode = TIM_OSSR_DISABLE;
  77. sBreakDeadTimeConfig.OffStateIDLEMode = TIM_OSSI_DISABLE;
  78. sBreakDeadTimeConfig.LockLevel = TIM_LOCKLEVEL_OFF;
  79. sBreakDeadTimeConfig.DeadTime = 0;
  80. sBreakDeadTimeConfig.BreakState = TIM_BREAK_DISABLE;
  81. sBreakDeadTimeConfig.BreakPolarity = TIM_BREAKPOLARITY_HIGH;
  82. sBreakDeadTimeConfig.BreakFilter = 0;
  83. sBreakDeadTimeConfig.BreakAFMode = TIM_BREAK_AFMODE_INPUT;
  84. sBreakDeadTimeConfig.Break2State = TIM_BREAK2_DISABLE;
  85. sBreakDeadTimeConfig.Break2Polarity = TIM_BREAK2POLARITY_HIGH;
  86. sBreakDeadTimeConfig.Break2Filter = 0;
  87. sBreakDeadTimeConfig.Break2AFMode = TIM_BREAK_AFMODE_INPUT;
  88. sBreakDeadTimeConfig.AutomaticOutput = TIM_AUTOMATICOUTPUT_DISABLE;
  89. if(HAL_TIMEx_ConfigBreakDeadTime(&htim1, &sBreakDeadTimeConfig) != HAL_OK) {
  90. Error_Handler();
  91. }
  92. /* USER CODE BEGIN TIM1_Init 2 */
  93. /* USER CODE END TIM1_Init 2 */
  94. HAL_TIM_MspPostInit(&htim1);
  95. }
  96. /* TIM2 init function */
  97. void MX_TIM2_Init(void) {
  98. /* USER CODE BEGIN TIM2_Init 0 */
  99. /* USER CODE END TIM2_Init 0 */
  100. TIM_ClockConfigTypeDef sClockSourceConfig = {0};
  101. TIM_MasterConfigTypeDef sMasterConfig = {0};
  102. TIM_IC_InitTypeDef sConfigIC = {0};
  103. /* USER CODE BEGIN TIM2_Init 1 */
  104. /* USER CODE END TIM2_Init 1 */
  105. htim2.Instance = TIM2;
  106. htim2.Init.Prescaler = 64 - 1;
  107. htim2.Init.CounterMode = TIM_COUNTERMODE_UP;
  108. htim2.Init.Period = 4294967295;
  109. htim2.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1;
  110. htim2.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_ENABLE;
  111. if(HAL_TIM_Base_Init(&htim2) != HAL_OK) {
  112. Error_Handler();
  113. }
  114. sClockSourceConfig.ClockSource = TIM_CLOCKSOURCE_INTERNAL;
  115. if(HAL_TIM_ConfigClockSource(&htim2, &sClockSourceConfig) != HAL_OK) {
  116. Error_Handler();
  117. }
  118. if(HAL_TIM_IC_Init(&htim2) != HAL_OK) {
  119. Error_Handler();
  120. }
  121. sMasterConfig.MasterOutputTrigger = TIM_TRGO_RESET;
  122. sMasterConfig.MasterSlaveMode = TIM_MASTERSLAVEMODE_DISABLE;
  123. if(HAL_TIMEx_MasterConfigSynchronization(&htim2, &sMasterConfig) != HAL_OK) {
  124. Error_Handler();
  125. }
  126. sConfigIC.ICPolarity = TIM_INPUTCHANNELPOLARITY_FALLING;
  127. sConfigIC.ICSelection = TIM_ICSELECTION_DIRECTTI;
  128. sConfigIC.ICPrescaler = TIM_ICPSC_DIV1;
  129. sConfigIC.ICFilter = 0;
  130. if(HAL_TIM_IC_ConfigChannel(&htim2, &sConfigIC, TIM_CHANNEL_1) != HAL_OK) {
  131. Error_Handler();
  132. }
  133. sConfigIC.ICPolarity = TIM_INPUTCHANNELPOLARITY_RISING;
  134. sConfigIC.ICSelection = TIM_ICSELECTION_INDIRECTTI;
  135. if(HAL_TIM_IC_ConfigChannel(&htim2, &sConfigIC, TIM_CHANNEL_2) != HAL_OK) {
  136. Error_Handler();
  137. }
  138. /* USER CODE BEGIN TIM2_Init 2 */
  139. /* USER CODE END TIM2_Init 2 */
  140. }
  141. /* TIM16 init function */
  142. void MX_TIM16_Init(void) {
  143. /* USER CODE BEGIN TIM16_Init 0 */
  144. /* USER CODE END TIM16_Init 0 */
  145. TIM_OC_InitTypeDef sConfigOC = {0};
  146. TIM_BreakDeadTimeConfigTypeDef sBreakDeadTimeConfig = {0};
  147. /* USER CODE BEGIN TIM16_Init 1 */
  148. /* USER CODE END TIM16_Init 1 */
  149. htim16.Instance = TIM16;
  150. htim16.Init.Prescaler = 500 - 1;
  151. htim16.Init.CounterMode = TIM_COUNTERMODE_UP;
  152. htim16.Init.Period = 291;
  153. htim16.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1;
  154. htim16.Init.RepetitionCounter = 0;
  155. htim16.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_DISABLE;
  156. if(HAL_TIM_Base_Init(&htim16) != HAL_OK) {
  157. Error_Handler();
  158. }
  159. if(HAL_TIM_PWM_Init(&htim16) != HAL_OK) {
  160. Error_Handler();
  161. }
  162. sConfigOC.OCMode = TIM_OCMODE_PWM1;
  163. sConfigOC.Pulse = 145;
  164. sConfigOC.OCPolarity = TIM_OCPOLARITY_HIGH;
  165. sConfigOC.OCNPolarity = TIM_OCNPOLARITY_HIGH;
  166. sConfigOC.OCFastMode = TIM_OCFAST_DISABLE;
  167. sConfigOC.OCIdleState = TIM_OCIDLESTATE_RESET;
  168. sConfigOC.OCNIdleState = TIM_OCNIDLESTATE_RESET;
  169. if(HAL_TIM_PWM_ConfigChannel(&htim16, &sConfigOC, TIM_CHANNEL_1) != HAL_OK) {
  170. Error_Handler();
  171. }
  172. sBreakDeadTimeConfig.OffStateRunMode = TIM_OSSR_DISABLE;
  173. sBreakDeadTimeConfig.OffStateIDLEMode = TIM_OSSI_DISABLE;
  174. sBreakDeadTimeConfig.LockLevel = TIM_LOCKLEVEL_OFF;
  175. sBreakDeadTimeConfig.DeadTime = 0;
  176. sBreakDeadTimeConfig.BreakState = TIM_BREAK_DISABLE;
  177. sBreakDeadTimeConfig.BreakPolarity = TIM_BREAKPOLARITY_HIGH;
  178. sBreakDeadTimeConfig.BreakFilter = 0;
  179. sBreakDeadTimeConfig.AutomaticOutput = TIM_AUTOMATICOUTPUT_DISABLE;
  180. if(HAL_TIMEx_ConfigBreakDeadTime(&htim16, &sBreakDeadTimeConfig) != HAL_OK) {
  181. Error_Handler();
  182. }
  183. /* USER CODE BEGIN TIM16_Init 2 */
  184. /* USER CODE END TIM16_Init 2 */
  185. HAL_TIM_MspPostInit(&htim16);
  186. }
  187. void HAL_TIM_Base_MspInit(TIM_HandleTypeDef* tim_baseHandle) {
  188. GPIO_InitTypeDef GPIO_InitStruct = {0};
  189. if(tim_baseHandle->Instance == TIM1) {
  190. /* USER CODE BEGIN TIM1_MspInit 0 */
  191. /* USER CODE END TIM1_MspInit 0 */
  192. /* TIM1 clock enable */
  193. __HAL_RCC_TIM1_CLK_ENABLE();
  194. /* TIM1 interrupt Init */
  195. HAL_NVIC_SetPriority(TIM1_TRG_COM_TIM17_IRQn, 5, 0);
  196. HAL_NVIC_EnableIRQ(TIM1_TRG_COM_TIM17_IRQn);
  197. /* USER CODE BEGIN TIM1_MspInit 1 */
  198. /* USER CODE END TIM1_MspInit 1 */
  199. } else if(tim_baseHandle->Instance == TIM2) {
  200. /* USER CODE BEGIN TIM2_MspInit 0 */
  201. /* USER CODE END TIM2_MspInit 0 */
  202. /* TIM2 clock enable */
  203. __HAL_RCC_TIM2_CLK_ENABLE();
  204. __HAL_RCC_GPIOA_CLK_ENABLE();
  205. /**TIM2 GPIO Configuration
  206. PA0 ------> TIM2_CH1
  207. */
  208. GPIO_InitStruct.Pin = IR_RX_Pin;
  209. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  210. GPIO_InitStruct.Pull = GPIO_NOPULL;
  211. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
  212. GPIO_InitStruct.Alternate = GPIO_AF1_TIM2;
  213. HAL_GPIO_Init(IR_RX_GPIO_Port, &GPIO_InitStruct);
  214. /* TIM2 interrupt Init */
  215. HAL_NVIC_SetPriority(TIM2_IRQn, 5, 0);
  216. HAL_NVIC_EnableIRQ(TIM2_IRQn);
  217. /* USER CODE BEGIN TIM2_MspInit 1 */
  218. /* USER CODE END TIM2_MspInit 1 */
  219. } else if(tim_baseHandle->Instance == TIM16) {
  220. /* USER CODE BEGIN TIM16_MspInit 0 */
  221. /* USER CODE END TIM16_MspInit 0 */
  222. /* TIM16 clock enable */
  223. __HAL_RCC_TIM16_CLK_ENABLE();
  224. /* USER CODE BEGIN TIM16_MspInit 1 */
  225. /* USER CODE END TIM16_MspInit 1 */
  226. }
  227. }
  228. void HAL_TIM_MspPostInit(TIM_HandleTypeDef* timHandle) {
  229. GPIO_InitTypeDef GPIO_InitStruct = {0};
  230. if(timHandle->Instance == TIM1) {
  231. /* USER CODE BEGIN TIM1_MspPostInit 0 */
  232. /* USER CODE END TIM1_MspPostInit 0 */
  233. __HAL_RCC_GPIOB_CLK_ENABLE();
  234. /**TIM1 GPIO Configuration
  235. PB9 ------> TIM1_CH3N
  236. PB13 ------> TIM1_CH1N
  237. */
  238. GPIO_InitStruct.Pin = IR_TX_Pin | RFID_OUT_Pin;
  239. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  240. GPIO_InitStruct.Pull = GPIO_NOPULL;
  241. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
  242. GPIO_InitStruct.Alternate = GPIO_AF1_TIM1;
  243. HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
  244. /* USER CODE BEGIN TIM1_MspPostInit 1 */
  245. /* USER CODE END TIM1_MspPostInit 1 */
  246. } else if(timHandle->Instance == TIM16) {
  247. /* USER CODE BEGIN TIM16_MspPostInit 0 */
  248. /* USER CODE END TIM16_MspPostInit 0 */
  249. __HAL_RCC_GPIOB_CLK_ENABLE();
  250. /**TIM16 GPIO Configuration
  251. PB8 ------> TIM16_CH1
  252. */
  253. GPIO_InitStruct.Pin = SPEAKER_Pin;
  254. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  255. GPIO_InitStruct.Pull = GPIO_NOPULL;
  256. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
  257. GPIO_InitStruct.Alternate = GPIO_AF14_TIM16;
  258. HAL_GPIO_Init(SPEAKER_GPIO_Port, &GPIO_InitStruct);
  259. /* USER CODE BEGIN TIM16_MspPostInit 1 */
  260. /* USER CODE END TIM16_MspPostInit 1 */
  261. }
  262. }
  263. void HAL_TIM_Base_MspDeInit(TIM_HandleTypeDef* tim_baseHandle) {
  264. if(tim_baseHandle->Instance == TIM1) {
  265. /* USER CODE BEGIN TIM1_MspDeInit 0 */
  266. /* USER CODE END TIM1_MspDeInit 0 */
  267. /* Peripheral clock disable */
  268. __HAL_RCC_TIM1_CLK_DISABLE();
  269. /* TIM1 interrupt Deinit */
  270. HAL_NVIC_DisableIRQ(TIM1_TRG_COM_TIM17_IRQn);
  271. /* USER CODE BEGIN TIM1_MspDeInit 1 */
  272. /* USER CODE END TIM1_MspDeInit 1 */
  273. } else if(tim_baseHandle->Instance == TIM2) {
  274. /* USER CODE BEGIN TIM2_MspDeInit 0 */
  275. /* USER CODE END TIM2_MspDeInit 0 */
  276. /* Peripheral clock disable */
  277. __HAL_RCC_TIM2_CLK_DISABLE();
  278. /**TIM2 GPIO Configuration
  279. PA0 ------> TIM2_CH1
  280. */
  281. HAL_GPIO_DeInit(IR_RX_GPIO_Port, IR_RX_Pin);
  282. /* TIM2 interrupt Deinit */
  283. HAL_NVIC_DisableIRQ(TIM2_IRQn);
  284. /* USER CODE BEGIN TIM2_MspDeInit 1 */
  285. /* USER CODE END TIM2_MspDeInit 1 */
  286. } else if(tim_baseHandle->Instance == TIM16) {
  287. /* USER CODE BEGIN TIM16_MspDeInit 0 */
  288. /* USER CODE END TIM16_MspDeInit 0 */
  289. /* Peripheral clock disable */
  290. __HAL_RCC_TIM16_CLK_DISABLE();
  291. /* USER CODE BEGIN TIM16_MspDeInit 1 */
  292. /* USER CODE END TIM16_MspDeInit 1 */
  293. }
  294. }
  295. /* USER CODE BEGIN 1 */
  296. /* USER CODE END 1 */
  297. /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/