tim.c 26 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931
  1. /**
  2. ******************************************************************************
  3. * File Name : TIM.c
  4. * Description : This file provides code for the configuration
  5. * of the TIM instances.
  6. ******************************************************************************
  7. * @attention
  8. *
  9. * <h2><center>&copy; Copyright (c) 2020 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. #include "main.h"
  22. /* USER CODE BEGIN 0 */
  23. uint16_t ICP_Leak_Duty;
  24. uint16_t ICP_Leak_Period;
  25. uint16_t ICP_rising[2];
  26. uint16_t ICP_falling;
  27. uint8_t ICP_rising_idx;
  28. uint16_t SPWM_idx;
  29. /* USER CODE END 0 */
  30. TIM_HandleTypeDef htim1;
  31. TIM_HandleTypeDef htim4;
  32. TIM_HandleTypeDef htim5;
  33. TIM_HandleTypeDef htim6;
  34. TIM_HandleTypeDef htim9;
  35. TIM_HandleTypeDef htim10;
  36. TIM_HandleTypeDef htim11;
  37. TIM_HandleTypeDef htim12;
  38. TIM_HandleTypeDef htim13;
  39. TIM_HandleTypeDef htim14;
  40. /* TIM1 init function */
  41. void MX_TIM1_Init(void)
  42. {
  43. TIM_ClockConfigTypeDef sClockSourceConfig = {0};
  44. TIM_MasterConfigTypeDef sMasterConfig = {0};
  45. TIM_OC_InitTypeDef sConfigOC = {0};
  46. TIM_BreakDeadTimeConfigTypeDef sBreakDeadTimeConfig = {0};
  47. htim1.Instance = TIM1;
  48. htim1.Init.Prescaler = 168-1;
  49. htim1.Init.CounterMode = TIM_COUNTERMODE_UP;
  50. htim1.Init.Period = 1000-1;
  51. htim1.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1;
  52. htim1.Init.RepetitionCounter = 0;
  53. htim1.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_DISABLE;
  54. if (HAL_TIM_Base_Init(&htim1) != HAL_OK)
  55. {
  56. Error_Handler();
  57. }
  58. sClockSourceConfig.ClockSource = TIM_CLOCKSOURCE_INTERNAL;
  59. if (HAL_TIM_ConfigClockSource(&htim1, &sClockSourceConfig) != HAL_OK)
  60. {
  61. Error_Handler();
  62. }
  63. if (HAL_TIM_PWM_Init(&htim1) != HAL_OK)
  64. {
  65. Error_Handler();
  66. }
  67. sMasterConfig.MasterOutputTrigger = TIM_TRGO_RESET;
  68. sMasterConfig.MasterSlaveMode = TIM_MASTERSLAVEMODE_DISABLE;
  69. if (HAL_TIMEx_MasterConfigSynchronization(&htim1, &sMasterConfig) != HAL_OK)
  70. {
  71. Error_Handler();
  72. }
  73. sConfigOC.OCMode = TIM_OCMODE_PWM1;
  74. sConfigOC.Pulse = 0;
  75. sConfigOC.OCPolarity = TIM_OCPOLARITY_HIGH;
  76. sConfigOC.OCFastMode = TIM_OCFAST_DISABLE;
  77. sConfigOC.OCIdleState = TIM_OCIDLESTATE_RESET;
  78. sConfigOC.OCNIdleState = TIM_OCNIDLESTATE_RESET;
  79. if (HAL_TIM_PWM_ConfigChannel(&htim1, &sConfigOC, TIM_CHANNEL_4) != HAL_OK)
  80. {
  81. Error_Handler();
  82. }
  83. sBreakDeadTimeConfig.OffStateRunMode = TIM_OSSR_DISABLE;
  84. sBreakDeadTimeConfig.OffStateIDLEMode = TIM_OSSI_DISABLE;
  85. sBreakDeadTimeConfig.LockLevel = TIM_LOCKLEVEL_OFF;
  86. sBreakDeadTimeConfig.DeadTime = 0;
  87. sBreakDeadTimeConfig.BreakState = TIM_BREAK_DISABLE;
  88. sBreakDeadTimeConfig.BreakPolarity = TIM_BREAKPOLARITY_HIGH;
  89. sBreakDeadTimeConfig.AutomaticOutput = TIM_AUTOMATICOUTPUT_DISABLE;
  90. if (HAL_TIMEx_ConfigBreakDeadTime(&htim1, &sBreakDeadTimeConfig) != HAL_OK)
  91. {
  92. Error_Handler();
  93. }
  94. HAL_TIM_MspPostInit(&htim1);
  95. }
  96. /* TIM4 init function */
  97. void MX_TIM4_Init(void)
  98. {
  99. TIM_ClockConfigTypeDef sClockSourceConfig = {0};
  100. TIM_SlaveConfigTypeDef sSlaveConfig = {0};
  101. TIM_MasterConfigTypeDef sMasterConfig = {0};
  102. TIM_IC_InitTypeDef sConfigIC = {0};
  103. htim4.Instance = TIM4;
  104. htim4.Init.Prescaler = 84-1;
  105. htim4.Init.CounterMode = TIM_COUNTERMODE_UP;
  106. htim4.Init.Period = 1000-1;
  107. htim4.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1;
  108. htim4.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_DISABLE;
  109. if (HAL_TIM_Base_Init(&htim4) != HAL_OK)
  110. {
  111. Error_Handler();
  112. }
  113. sClockSourceConfig.ClockSource = TIM_CLOCKSOURCE_INTERNAL;
  114. if (HAL_TIM_ConfigClockSource(&htim4, &sClockSourceConfig) != HAL_OK)
  115. {
  116. Error_Handler();
  117. }
  118. if (HAL_TIM_IC_Init(&htim4) != HAL_OK)
  119. {
  120. Error_Handler();
  121. }
  122. sSlaveConfig.SlaveMode = TIM_SLAVEMODE_RESET;
  123. sSlaveConfig.InputTrigger = TIM_TS_TI1FP1;
  124. sSlaveConfig.TriggerPolarity = TIM_INPUTCHANNELPOLARITY_RISING;
  125. sSlaveConfig.TriggerFilter = 0;
  126. if (HAL_TIM_SlaveConfigSynchro(&htim4, &sSlaveConfig) != HAL_OK)
  127. {
  128. Error_Handler();
  129. }
  130. sMasterConfig.MasterOutputTrigger = TIM_TRGO_RESET;
  131. sMasterConfig.MasterSlaveMode = TIM_MASTERSLAVEMODE_ENABLE;
  132. if (HAL_TIMEx_MasterConfigSynchronization(&htim4, &sMasterConfig) != HAL_OK)
  133. {
  134. Error_Handler();
  135. }
  136. sConfigIC.ICPolarity = TIM_INPUTCHANNELPOLARITY_RISING;
  137. sConfigIC.ICSelection = TIM_ICSELECTION_DIRECTTI;
  138. sConfigIC.ICPrescaler = TIM_ICPSC_DIV1;
  139. sConfigIC.ICFilter = 0;
  140. if (HAL_TIM_IC_ConfigChannel(&htim4, &sConfigIC, TIM_CHANNEL_1) != HAL_OK)
  141. {
  142. Error_Handler();
  143. }
  144. sConfigIC.ICSelection = TIM_ICSELECTION_INDIRECTTI;
  145. if (HAL_TIM_IC_ConfigChannel(&htim4, &sConfigIC, TIM_CHANNEL_2) != HAL_OK)
  146. {
  147. Error_Handler();
  148. }
  149. }
  150. /* TIM5 init function */
  151. void MX_TIM5_Init(void)
  152. {
  153. TIM_ClockConfigTypeDef sClockSourceConfig = {0};
  154. TIM_MasterConfigTypeDef sMasterConfig = {0};
  155. htim5.Instance = TIM5;
  156. htim5.Init.Prescaler = 84-1;
  157. htim5.Init.CounterMode = TIM_COUNTERMODE_UP;
  158. htim5.Init.Period = 10-1;
  159. htim5.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1;
  160. htim5.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_DISABLE;
  161. if (HAL_TIM_Base_Init(&htim5) != HAL_OK)
  162. {
  163. Error_Handler();
  164. }
  165. sClockSourceConfig.ClockSource = TIM_CLOCKSOURCE_INTERNAL;
  166. if (HAL_TIM_ConfigClockSource(&htim5, &sClockSourceConfig) != HAL_OK)
  167. {
  168. Error_Handler();
  169. }
  170. sMasterConfig.MasterOutputTrigger = TIM_TRGO_RESET;
  171. sMasterConfig.MasterSlaveMode = TIM_MASTERSLAVEMODE_DISABLE;
  172. if (HAL_TIMEx_MasterConfigSynchronization(&htim5, &sMasterConfig) != HAL_OK)
  173. {
  174. Error_Handler();
  175. }
  176. }
  177. /* TIM6 init function */
  178. void MX_TIM6_Init(void)
  179. {
  180. TIM_MasterConfigTypeDef sMasterConfig = {0};
  181. htim6.Instance = TIM6;
  182. htim6.Init.Prescaler = 84-1;
  183. htim6.Init.CounterMode = TIM_COUNTERMODE_UP;
  184. htim6.Init.Period = 1000-1;
  185. htim6.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_DISABLE;
  186. if (HAL_TIM_Base_Init(&htim6) != HAL_OK)
  187. {
  188. Error_Handler();
  189. }
  190. sMasterConfig.MasterOutputTrigger = TIM_TRGO_RESET;
  191. sMasterConfig.MasterSlaveMode = TIM_MASTERSLAVEMODE_DISABLE;
  192. if (HAL_TIMEx_MasterConfigSynchronization(&htim6, &sMasterConfig) != HAL_OK)
  193. {
  194. Error_Handler();
  195. }
  196. }
  197. /* TIM9 init function */
  198. void MX_TIM9_Init(void)
  199. {
  200. TIM_ClockConfigTypeDef sClockSourceConfig = {0};
  201. TIM_OC_InitTypeDef sConfigOC = {0};
  202. htim9.Instance = TIM9;
  203. htim9.Init.Prescaler = 84-1;
  204. htim9.Init.CounterMode = TIM_COUNTERMODE_UP;
  205. htim9.Init.Period = 1000-1;
  206. htim9.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1;
  207. htim9.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_DISABLE;
  208. if (HAL_TIM_Base_Init(&htim9) != HAL_OK)
  209. {
  210. Error_Handler();
  211. }
  212. sClockSourceConfig.ClockSource = TIM_CLOCKSOURCE_INTERNAL;
  213. if (HAL_TIM_ConfigClockSource(&htim9, &sClockSourceConfig) != HAL_OK)
  214. {
  215. Error_Handler();
  216. }
  217. if (HAL_TIM_PWM_Init(&htim9) != HAL_OK)
  218. {
  219. Error_Handler();
  220. }
  221. sConfigOC.OCMode = TIM_OCMODE_PWM1;
  222. sConfigOC.Pulse = 0;
  223. sConfigOC.OCPolarity = TIM_OCPOLARITY_HIGH;
  224. sConfigOC.OCFastMode = TIM_OCFAST_DISABLE;
  225. if (HAL_TIM_PWM_ConfigChannel(&htim9, &sConfigOC, TIM_CHANNEL_1) != HAL_OK)
  226. {
  227. Error_Handler();
  228. }
  229. if (HAL_TIM_PWM_ConfigChannel(&htim9, &sConfigOC, TIM_CHANNEL_2) != HAL_OK)
  230. {
  231. Error_Handler();
  232. }
  233. HAL_TIM_MspPostInit(&htim9);
  234. }
  235. /* TIM10 init function */
  236. void MX_TIM10_Init(void)
  237. {
  238. TIM_OC_InitTypeDef sConfigOC = {0};
  239. htim10.Instance = TIM10;
  240. htim10.Init.Prescaler = 84-1;
  241. htim10.Init.CounterMode = TIM_COUNTERMODE_UP;
  242. htim10.Init.Period = 1000-1;
  243. htim10.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1;
  244. htim10.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_DISABLE;
  245. if (HAL_TIM_Base_Init(&htim10) != HAL_OK)
  246. {
  247. Error_Handler();
  248. }
  249. if (HAL_TIM_PWM_Init(&htim10) != HAL_OK)
  250. {
  251. Error_Handler();
  252. }
  253. sConfigOC.OCMode = TIM_OCMODE_PWM1;
  254. sConfigOC.Pulse = 0;
  255. sConfigOC.OCPolarity = TIM_OCPOLARITY_HIGH;
  256. sConfigOC.OCFastMode = TIM_OCFAST_DISABLE;
  257. if (HAL_TIM_PWM_ConfigChannel(&htim10, &sConfigOC, TIM_CHANNEL_1) != HAL_OK)
  258. {
  259. Error_Handler();
  260. }
  261. HAL_TIM_MspPostInit(&htim10);
  262. }
  263. /* TIM11 init function */
  264. void MX_TIM11_Init(void)
  265. {
  266. TIM_OC_InitTypeDef sConfigOC = {0};
  267. htim11.Instance = TIM11;
  268. htim11.Init.Prescaler = 84-1;
  269. htim11.Init.CounterMode = TIM_COUNTERMODE_UP;
  270. htim11.Init.Period = 1000-1;
  271. htim11.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1;
  272. htim11.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_DISABLE;
  273. if (HAL_TIM_Base_Init(&htim11) != HAL_OK)
  274. {
  275. Error_Handler();
  276. }
  277. if (HAL_TIM_PWM_Init(&htim11) != HAL_OK)
  278. {
  279. Error_Handler();
  280. }
  281. sConfigOC.OCMode = TIM_OCMODE_PWM1;
  282. sConfigOC.Pulse = 0;
  283. sConfigOC.OCPolarity = TIM_OCPOLARITY_HIGH;
  284. sConfigOC.OCFastMode = TIM_OCFAST_DISABLE;
  285. if (HAL_TIM_PWM_ConfigChannel(&htim11, &sConfigOC, TIM_CHANNEL_1) != HAL_OK)
  286. {
  287. Error_Handler();
  288. }
  289. HAL_TIM_MspPostInit(&htim11);
  290. }
  291. /* TIM12 init function */
  292. void MX_TIM12_Init(void)
  293. {
  294. TIM_ClockConfigTypeDef sClockSourceConfig = {0};
  295. TIM_OC_InitTypeDef sConfigOC = {0};
  296. htim12.Instance = TIM12;
  297. htim12.Init.Prescaler = 21-1;
  298. htim12.Init.CounterMode = TIM_COUNTERMODE_UP;
  299. htim12.Init.Period = 400-1;
  300. htim12.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1;
  301. htim12.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_DISABLE;
  302. if (HAL_TIM_Base_Init(&htim12) != HAL_OK)
  303. {
  304. Error_Handler();
  305. }
  306. sClockSourceConfig.ClockSource = TIM_CLOCKSOURCE_INTERNAL;
  307. if (HAL_TIM_ConfigClockSource(&htim12, &sClockSourceConfig) != HAL_OK)
  308. {
  309. Error_Handler();
  310. }
  311. if (HAL_TIM_PWM_Init(&htim12) != HAL_OK)
  312. {
  313. Error_Handler();
  314. }
  315. sConfigOC.OCMode = TIM_OCMODE_PWM1;
  316. sConfigOC.Pulse = 0;
  317. sConfigOC.OCPolarity = TIM_OCPOLARITY_HIGH;
  318. sConfigOC.OCFastMode = TIM_OCFAST_DISABLE;
  319. if (HAL_TIM_PWM_ConfigChannel(&htim12, &sConfigOC, TIM_CHANNEL_1) != HAL_OK)
  320. {
  321. Error_Handler();
  322. }
  323. HAL_TIM_MspPostInit(&htim12);
  324. }
  325. /* TIM13 init function */
  326. void MX_TIM13_Init(void)
  327. {
  328. htim13.Instance = TIM13;
  329. htim13.Init.Prescaler = 21-1;
  330. htim13.Init.CounterMode = TIM_COUNTERMODE_UP;
  331. htim13.Init.Period = 400-1;
  332. htim13.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1;
  333. htim13.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_DISABLE;
  334. if (HAL_TIM_Base_Init(&htim13) != HAL_OK)
  335. {
  336. Error_Handler();
  337. }
  338. }
  339. /* TIM14 init function */
  340. void MX_TIM14_Init(void)
  341. {
  342. htim14.Instance = TIM14;
  343. htim14.Init.Prescaler = 84-1;
  344. htim14.Init.CounterMode = TIM_COUNTERMODE_UP;
  345. htim14.Init.Period = 1000-1;
  346. htim14.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1;
  347. htim14.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_DISABLE;
  348. if (HAL_TIM_Base_Init(&htim14) != HAL_OK)
  349. {
  350. Error_Handler();
  351. }
  352. }
  353. void HAL_TIM_Base_MspInit(TIM_HandleTypeDef* tim_baseHandle)
  354. {
  355. GPIO_InitTypeDef GPIO_InitStruct = {0};
  356. if(tim_baseHandle->Instance==TIM1)
  357. {
  358. /* USER CODE BEGIN TIM1_MspInit 0 */
  359. /* USER CODE END TIM1_MspInit 0 */
  360. /* TIM1 clock enable */
  361. __HAL_RCC_TIM1_CLK_ENABLE();
  362. /* TIM1 interrupt Init */
  363. HAL_NVIC_SetPriority(TIM1_BRK_TIM9_IRQn, 5, 0);
  364. HAL_NVIC_EnableIRQ(TIM1_BRK_TIM9_IRQn);
  365. /* USER CODE BEGIN TIM1_MspInit 1 */
  366. /* USER CODE END TIM1_MspInit 1 */
  367. }
  368. else if(tim_baseHandle->Instance==TIM4)
  369. {
  370. /* USER CODE BEGIN TIM4_MspInit 0 */
  371. /* USER CODE END TIM4_MspInit 0 */
  372. /* TIM4 clock enable */
  373. __HAL_RCC_TIM4_CLK_ENABLE();
  374. __HAL_RCC_GPIOD_CLK_ENABLE();
  375. /**TIM4 GPIO Configuration
  376. PD12 ------> TIM4_CH1
  377. */
  378. GPIO_InitStruct.Pin = ICP_TIM4_CH1_LEAK_PWM_Pin;
  379. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  380. GPIO_InitStruct.Pull = GPIO_NOPULL;
  381. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
  382. GPIO_InitStruct.Alternate = GPIO_AF2_TIM4;
  383. HAL_GPIO_Init(ICP_TIM4_CH1_LEAK_PWM_GPIO_Port, &GPIO_InitStruct);
  384. /* TIM4 interrupt Init */
  385. HAL_NVIC_SetPriority(TIM4_IRQn, 5, 0);
  386. HAL_NVIC_EnableIRQ(TIM4_IRQn);
  387. /* USER CODE BEGIN TIM4_MspInit 1 */
  388. /* USER CODE END TIM4_MspInit 1 */
  389. }
  390. else if(tim_baseHandle->Instance==TIM5)
  391. {
  392. /* USER CODE BEGIN TIM5_MspInit 0 */
  393. /* USER CODE END TIM5_MspInit 0 */
  394. /* TIM5 clock enable */
  395. __HAL_RCC_TIM5_CLK_ENABLE();
  396. /* TIM5 interrupt Init */
  397. HAL_NVIC_SetPriority(TIM5_IRQn, 5, 0);
  398. HAL_NVIC_EnableIRQ(TIM5_IRQn);
  399. /* USER CODE BEGIN TIM5_MspInit 1 */
  400. /* USER CODE END TIM5_MspInit 1 */
  401. }
  402. else if(tim_baseHandle->Instance==TIM6)
  403. {
  404. /* USER CODE BEGIN TIM6_MspInit 0 */
  405. /* USER CODE END TIM6_MspInit 0 */
  406. /* TIM6 clock enable */
  407. __HAL_RCC_TIM6_CLK_ENABLE();
  408. /* TIM6 interrupt Init */
  409. HAL_NVIC_SetPriority(TIM6_DAC_IRQn, 5, 0);
  410. HAL_NVIC_EnableIRQ(TIM6_DAC_IRQn);
  411. /* USER CODE BEGIN TIM6_MspInit 1 */
  412. /* USER CODE END TIM6_MspInit 1 */
  413. }
  414. else if(tim_baseHandle->Instance==TIM9)
  415. {
  416. /* USER CODE BEGIN TIM9_MspInit 0 */
  417. /* USER CODE END TIM9_MspInit 0 */
  418. /* TIM9 clock enable */
  419. __HAL_RCC_TIM9_CLK_ENABLE();
  420. /* TIM9 interrupt Init */
  421. HAL_NVIC_SetPriority(TIM1_BRK_TIM9_IRQn, 5, 0);
  422. HAL_NVIC_EnableIRQ(TIM1_BRK_TIM9_IRQn);
  423. /* USER CODE BEGIN TIM9_MspInit 1 */
  424. /* USER CODE END TIM9_MspInit 1 */
  425. }
  426. else if(tim_baseHandle->Instance==TIM10)
  427. {
  428. /* USER CODE BEGIN TIM10_MspInit 0 */
  429. /* USER CODE END TIM10_MspInit 0 */
  430. /* TIM10 clock enable */
  431. __HAL_RCC_TIM10_CLK_ENABLE();
  432. /* USER CODE BEGIN TIM10_MspInit 1 */
  433. /* USER CODE END TIM10_MspInit 1 */
  434. }
  435. else if(tim_baseHandle->Instance==TIM11)
  436. {
  437. /* USER CODE BEGIN TIM11_MspInit 0 */
  438. /* USER CODE END TIM11_MspInit 0 */
  439. /* TIM11 clock enable */
  440. __HAL_RCC_TIM11_CLK_ENABLE();
  441. /* USER CODE BEGIN TIM11_MspInit 1 */
  442. /* USER CODE END TIM11_MspInit 1 */
  443. }
  444. else if(tim_baseHandle->Instance==TIM12)
  445. {
  446. /* USER CODE BEGIN TIM12_MspInit 0 */
  447. /* USER CODE END TIM12_MspInit 0 */
  448. /* TIM12 clock enable */
  449. __HAL_RCC_TIM12_CLK_ENABLE();
  450. /* USER CODE BEGIN TIM12_MspInit 1 */
  451. /* USER CODE END TIM12_MspInit 1 */
  452. }
  453. else if(tim_baseHandle->Instance==TIM13)
  454. {
  455. /* USER CODE BEGIN TIM13_MspInit 0 */
  456. /* USER CODE END TIM13_MspInit 0 */
  457. /* TIM13 clock enable */
  458. __HAL_RCC_TIM13_CLK_ENABLE();
  459. /* TIM13 interrupt Init */
  460. HAL_NVIC_SetPriority(TIM8_UP_TIM13_IRQn, 5, 0);
  461. HAL_NVIC_EnableIRQ(TIM8_UP_TIM13_IRQn);
  462. /* USER CODE BEGIN TIM13_MspInit 1 */
  463. /* USER CODE END TIM13_MspInit 1 */
  464. }
  465. else if(tim_baseHandle->Instance==TIM14)
  466. {
  467. /* USER CODE BEGIN TIM14_MspInit 0 */
  468. /* USER CODE END TIM14_MspInit 0 */
  469. /* TIM14 clock enable */
  470. __HAL_RCC_TIM14_CLK_ENABLE();
  471. /* TIM14 interrupt Init */
  472. HAL_NVIC_SetPriority(TIM8_TRG_COM_TIM14_IRQn, 5, 0);
  473. HAL_NVIC_EnableIRQ(TIM8_TRG_COM_TIM14_IRQn);
  474. /* USER CODE BEGIN TIM14_MspInit 1 */
  475. /* USER CODE END TIM14_MspInit 1 */
  476. }
  477. }
  478. void HAL_TIM_MspPostInit(TIM_HandleTypeDef* timHandle)
  479. {
  480. GPIO_InitTypeDef GPIO_InitStruct = {0};
  481. if(timHandle->Instance==TIM1)
  482. {
  483. /* USER CODE BEGIN TIM1_MspPostInit 0 */
  484. /* USER CODE END TIM1_MspPostInit 0 */
  485. __HAL_RCC_GPIOE_CLK_ENABLE();
  486. /**TIM1 GPIO Configuration
  487. PE14 ------> TIM1_CH4
  488. */
  489. GPIO_InitStruct.Pin = TIM1_CH4_PWM_CP_Pin;
  490. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  491. GPIO_InitStruct.Pull = GPIO_NOPULL;
  492. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
  493. GPIO_InitStruct.Alternate = GPIO_AF1_TIM1;
  494. HAL_GPIO_Init(TIM1_CH4_PWM_CP_GPIO_Port, &GPIO_InitStruct);
  495. /* USER CODE BEGIN TIM1_MspPostInit 1 */
  496. /* USER CODE END TIM1_MspPostInit 1 */
  497. }
  498. else if(timHandle->Instance==TIM9)
  499. {
  500. /* USER CODE BEGIN TIM9_MspPostInit 0 */
  501. /* USER CODE END TIM9_MspPostInit 0 */
  502. __HAL_RCC_GPIOE_CLK_ENABLE();
  503. /**TIM9 GPIO Configuration
  504. PE5 ------> TIM9_CH1
  505. PE6 ------> TIM9_CH2
  506. */
  507. GPIO_InitStruct.Pin = TIM9_CH1_PWM_LED_R_Pin|TIM9_CH2_PWM_LED_G_Pin;
  508. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  509. GPIO_InitStruct.Pull = GPIO_NOPULL;
  510. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
  511. GPIO_InitStruct.Alternate = GPIO_AF3_TIM9;
  512. HAL_GPIO_Init(GPIOE, &GPIO_InitStruct);
  513. /* USER CODE BEGIN TIM9_MspPostInit 1 */
  514. /* USER CODE END TIM9_MspPostInit 1 */
  515. }
  516. else if(timHandle->Instance==TIM10)
  517. {
  518. /* USER CODE BEGIN TIM10_MspPostInit 0 */
  519. /* USER CODE END TIM10_MspPostInit 0 */
  520. __HAL_RCC_GPIOB_CLK_ENABLE();
  521. /**TIM10 GPIO Configuration
  522. PB8 ------> TIM10_CH1
  523. */
  524. GPIO_InitStruct.Pin = TIM10_CH1_PWM_LED_B_Pin;
  525. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  526. GPIO_InitStruct.Pull = GPIO_NOPULL;
  527. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
  528. GPIO_InitStruct.Alternate = GPIO_AF3_TIM10;
  529. HAL_GPIO_Init(TIM10_CH1_PWM_LED_B_GPIO_Port, &GPIO_InitStruct);
  530. /* USER CODE BEGIN TIM10_MspPostInit 1 */
  531. /* USER CODE END TIM10_MspPostInit 1 */
  532. }
  533. else if(timHandle->Instance==TIM11)
  534. {
  535. /* USER CODE BEGIN TIM11_MspPostInit 0 */
  536. /* USER CODE END TIM11_MspPostInit 0 */
  537. __HAL_RCC_GPIOB_CLK_ENABLE();
  538. /**TIM11 GPIO Configuration
  539. PB9 ------> TIM11_CH1
  540. */
  541. GPIO_InitStruct.Pin = TIM11_CH1_PWM_LED_W_Pin;
  542. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  543. GPIO_InitStruct.Pull = GPIO_NOPULL;
  544. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
  545. GPIO_InitStruct.Alternate = GPIO_AF3_TIM11;
  546. HAL_GPIO_Init(TIM11_CH1_PWM_LED_W_GPIO_Port, &GPIO_InitStruct);
  547. /* USER CODE BEGIN TIM11_MspPostInit 1 */
  548. /* USER CODE END TIM11_MspPostInit 1 */
  549. }
  550. else if(timHandle->Instance==TIM12)
  551. {
  552. /* USER CODE BEGIN TIM12_MspPostInit 0 */
  553. /* USER CODE END TIM12_MspPostInit 0 */
  554. __HAL_RCC_GPIOB_CLK_ENABLE();
  555. /**TIM12 GPIO Configuration
  556. PB14 ------> TIM12_CH1
  557. */
  558. GPIO_InitStruct.Pin = TIM12_CH1_PWM_GFCI_Test_Pin;
  559. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  560. GPIO_InitStruct.Pull = GPIO_NOPULL;
  561. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
  562. GPIO_InitStruct.Alternate = GPIO_AF9_TIM12;
  563. HAL_GPIO_Init(TIM12_CH1_PWM_GFCI_Test_GPIO_Port, &GPIO_InitStruct);
  564. /* USER CODE BEGIN TIM12_MspPostInit 1 */
  565. /* USER CODE END TIM12_MspPostInit 1 */
  566. }
  567. }
  568. void HAL_TIM_Base_MspDeInit(TIM_HandleTypeDef* tim_baseHandle)
  569. {
  570. if(tim_baseHandle->Instance==TIM1)
  571. {
  572. /* USER CODE BEGIN TIM1_MspDeInit 0 */
  573. /* USER CODE END TIM1_MspDeInit 0 */
  574. /* Peripheral clock disable */
  575. __HAL_RCC_TIM1_CLK_DISABLE();
  576. /* TIM1 interrupt Deinit */
  577. /* USER CODE BEGIN TIM1:TIM1_BRK_TIM9_IRQn disable */
  578. /**
  579. * Uncomment the line below to disable the "TIM1_BRK_TIM9_IRQn" interrupt
  580. * Be aware, disabling shared interrupt may affect other IPs
  581. */
  582. /* HAL_NVIC_DisableIRQ(TIM1_BRK_TIM9_IRQn); */
  583. /* USER CODE END TIM1:TIM1_BRK_TIM9_IRQn disable */
  584. /* USER CODE BEGIN TIM1_MspDeInit 1 */
  585. /* USER CODE END TIM1_MspDeInit 1 */
  586. }
  587. else if(tim_baseHandle->Instance==TIM4)
  588. {
  589. /* USER CODE BEGIN TIM4_MspDeInit 0 */
  590. /* USER CODE END TIM4_MspDeInit 0 */
  591. /* Peripheral clock disable */
  592. __HAL_RCC_TIM4_CLK_DISABLE();
  593. /**TIM4 GPIO Configuration
  594. PD12 ------> TIM4_CH1
  595. */
  596. HAL_GPIO_DeInit(ICP_TIM4_CH1_LEAK_PWM_GPIO_Port, ICP_TIM4_CH1_LEAK_PWM_Pin);
  597. /* TIM4 interrupt Deinit */
  598. HAL_NVIC_DisableIRQ(TIM4_IRQn);
  599. /* USER CODE BEGIN TIM4_MspDeInit 1 */
  600. /* USER CODE END TIM4_MspDeInit 1 */
  601. }
  602. else if(tim_baseHandle->Instance==TIM5)
  603. {
  604. /* USER CODE BEGIN TIM5_MspDeInit 0 */
  605. /* USER CODE END TIM5_MspDeInit 0 */
  606. /* Peripheral clock disable */
  607. __HAL_RCC_TIM5_CLK_DISABLE();
  608. /* TIM5 interrupt Deinit */
  609. HAL_NVIC_DisableIRQ(TIM5_IRQn);
  610. /* USER CODE BEGIN TIM5_MspDeInit 1 */
  611. /* USER CODE END TIM5_MspDeInit 1 */
  612. }
  613. else if(tim_baseHandle->Instance==TIM6)
  614. {
  615. /* USER CODE BEGIN TIM6_MspDeInit 0 */
  616. /* USER CODE END TIM6_MspDeInit 0 */
  617. /* Peripheral clock disable */
  618. __HAL_RCC_TIM6_CLK_DISABLE();
  619. /* TIM6 interrupt Deinit */
  620. HAL_NVIC_DisableIRQ(TIM6_DAC_IRQn);
  621. /* USER CODE BEGIN TIM6_MspDeInit 1 */
  622. /* USER CODE END TIM6_MspDeInit 1 */
  623. }
  624. else if(tim_baseHandle->Instance==TIM9)
  625. {
  626. /* USER CODE BEGIN TIM9_MspDeInit 0 */
  627. /* USER CODE END TIM9_MspDeInit 0 */
  628. /* Peripheral clock disable */
  629. __HAL_RCC_TIM9_CLK_DISABLE();
  630. /* TIM9 interrupt Deinit */
  631. /* USER CODE BEGIN TIM9:TIM1_BRK_TIM9_IRQn disable */
  632. /**
  633. * Uncomment the line below to disable the "TIM1_BRK_TIM9_IRQn" interrupt
  634. * Be aware, disabling shared interrupt may affect other IPs
  635. */
  636. /* HAL_NVIC_DisableIRQ(TIM1_BRK_TIM9_IRQn); */
  637. /* USER CODE END TIM9:TIM1_BRK_TIM9_IRQn disable */
  638. /* USER CODE BEGIN TIM9_MspDeInit 1 */
  639. /* USER CODE END TIM9_MspDeInit 1 */
  640. }
  641. else if(tim_baseHandle->Instance==TIM10)
  642. {
  643. /* USER CODE BEGIN TIM10_MspDeInit 0 */
  644. /* USER CODE END TIM10_MspDeInit 0 */
  645. /* Peripheral clock disable */
  646. __HAL_RCC_TIM10_CLK_DISABLE();
  647. /* USER CODE BEGIN TIM10_MspDeInit 1 */
  648. /* USER CODE END TIM10_MspDeInit 1 */
  649. }
  650. else if(tim_baseHandle->Instance==TIM11)
  651. {
  652. /* USER CODE BEGIN TIM11_MspDeInit 0 */
  653. /* USER CODE END TIM11_MspDeInit 0 */
  654. /* Peripheral clock disable */
  655. __HAL_RCC_TIM11_CLK_DISABLE();
  656. /* USER CODE BEGIN TIM11_MspDeInit 1 */
  657. /* USER CODE END TIM11_MspDeInit 1 */
  658. }
  659. else if(tim_baseHandle->Instance==TIM12)
  660. {
  661. /* USER CODE BEGIN TIM12_MspDeInit 0 */
  662. /* USER CODE END TIM12_MspDeInit 0 */
  663. /* Peripheral clock disable */
  664. __HAL_RCC_TIM12_CLK_DISABLE();
  665. /* USER CODE BEGIN TIM12_MspDeInit 1 */
  666. /* USER CODE END TIM12_MspDeInit 1 */
  667. }
  668. else if(tim_baseHandle->Instance==TIM13)
  669. {
  670. /* USER CODE BEGIN TIM13_MspDeInit 0 */
  671. /* USER CODE END TIM13_MspDeInit 0 */
  672. /* Peripheral clock disable */
  673. __HAL_RCC_TIM13_CLK_DISABLE();
  674. /* TIM13 interrupt Deinit */
  675. HAL_NVIC_DisableIRQ(TIM8_UP_TIM13_IRQn);
  676. /* USER CODE BEGIN TIM13_MspDeInit 1 */
  677. /* USER CODE END TIM13_MspDeInit 1 */
  678. }
  679. else if(tim_baseHandle->Instance==TIM14)
  680. {
  681. /* USER CODE BEGIN TIM14_MspDeInit 0 */
  682. /* USER CODE END TIM14_MspDeInit 0 */
  683. /* Peripheral clock disable */
  684. __HAL_RCC_TIM14_CLK_DISABLE();
  685. /* TIM14 interrupt Deinit */
  686. HAL_NVIC_DisableIRQ(TIM8_TRG_COM_TIM14_IRQn);
  687. /* USER CODE BEGIN TIM14_MspDeInit 1 */
  688. /* USER CODE END TIM14_MspDeInit 1 */
  689. }
  690. }
  691. /* USER CODE BEGIN 1 */
  692. #ifdef FUNC_CHECK_REQ_AND_CP_WHEN_SET_CP_PWM
  693. #include "cp_detection.h"
  694. #endif
  695. void user_pwm_setvalue(uint8_t ch, uint16_t value)
  696. {
  697. TIM_OC_InitTypeDef sConfigOC;
  698. sConfigOC.OCMode = TIM_OCMODE_PWM1;
  699. sConfigOC.Pulse = value;
  700. sConfigOC.OCPolarity = TIM_OCPOLARITY_HIGH;
  701. sConfigOC.OCFastMode = TIM_OCFAST_DISABLE;
  702. #ifdef MODIFY_MCU_PWM_SET_VALUE_CP
  703. static uint16_t PreCpPulseVal = 0xFFFF;
  704. #endif
  705. switch(ch)
  706. {
  707. case PWM_CH_CP:
  708. #ifdef FIX_FUNC_CHECK_REQ_AND_CP_WHEN_SET_CP_PWM
  709. if (Charger.memory.EVSE_Config.data.item.MCU_Control_Mode == MCU_CONTROL_MODE_NO_CSU)
  710. {
  711. if (Charger.CP_State == SYSTEM_STATE_A)
  712. {
  713. sConfigOC.Pulse = value = PWM_DUTY_FULL;
  714. }
  715. }
  716. else if (Charger.memory.EVSE_Config.data.item.MCU_Control_Mode == MCU_CONTROL_MODE_CSU)
  717. {
  718. if (!Charger.am3352.isRequestOn || Charger.CP_State == SYSTEM_STATE_A)
  719. {
  720. sConfigOC.Pulse = value = PWM_DUTY_FULL;
  721. }
  722. }
  723. #else
  724. //#ifdef FUNC_CHECK_REQ_AND_CP_WHEN_SET_CP_PWM
  725. // if (!Charger.am3352.isRequestOn || Charger.CP_State == SYSTEM_STATE_A)
  726. // {
  727. // sConfigOC.Pulse = value = PWM_DUTY_FULL;
  728. // }
  729. //#endif
  730. #endif //FIX_FUNC_CHECK_REQ_AND_CP_WHEN_SET_CP_PWM
  731. #ifdef MODIFY_MCU_PWM_SET_VALUE_CP
  732. if (value != PreCpPulseVal)
  733. {
  734. PreCpPulseVal = value;
  735. XP("\r\n#USER_CP_PWM_SETVALUE(%d)\r\n\r\n", value);
  736. #ifdef FUNC_CURRENT_CP_PWM_DATA
  737. Charger.m_CP_CurPWM = value;
  738. #endif
  739. #ifdef MODIFY_SET_CP_PWM_DUTY_WHEN_GET_NEW_VAL
  740. HAL_TIM_PWM_ConfigChannel(&htim1, &sConfigOC, TIM_CHANNEL_4);
  741. HAL_TIM_PWM_Start(&htim1, TIM_CHANNEL_4);
  742. #endif
  743. }
  744. #endif //MODIFY_MCU_PWM_SET_VALUE_CP
  745. #ifndef MODIFY_SET_CP_PWM_DUTY_WHEN_GET_NEW_VAL
  746. HAL_TIM_PWM_ConfigChannel(&htim1, &sConfigOC, TIM_CHANNEL_4);
  747. HAL_TIM_PWM_Start(&htim1, TIM_CHANNEL_4);
  748. #endif
  749. break;
  750. case PWM_CH_LED_R:
  751. HAL_TIM_PWM_ConfigChannel(&htim9, &sConfigOC, TIM_CHANNEL_1);
  752. HAL_TIM_PWM_Start(&htim9, TIM_CHANNEL_1);
  753. break;
  754. case PWM_CH_LED_G:
  755. HAL_TIM_PWM_ConfigChannel(&htim9, &sConfigOC, TIM_CHANNEL_2);
  756. HAL_TIM_PWM_Start(&htim9, TIM_CHANNEL_2);
  757. break;
  758. case PWM_CH_LED_B:
  759. HAL_TIM_PWM_ConfigChannel(&htim10, &sConfigOC, TIM_CHANNEL_1);
  760. HAL_TIM_PWM_Start(&htim10, TIM_CHANNEL_1);
  761. break;
  762. case PWM_CH_LED_W:
  763. HAL_TIM_PWM_ConfigChannel(&htim11, &sConfigOC, TIM_CHANNEL_1);
  764. HAL_TIM_PWM_Start(&htim11, TIM_CHANNEL_1);
  765. break;
  766. case PWM_CH_GFCI_TEST:
  767. HAL_TIM_PWM_ConfigChannel(&htim12, &sConfigOC, TIM_CHANNEL_1);
  768. HAL_TIM_PWM_Start(&htim12, TIM_CHANNEL_1);
  769. break;
  770. }
  771. }
  772. //------------------------------------------------------------------------------
  773. void SPWM_Switch(uint8_t isOn)
  774. {
  775. XP("#SPWM_Switch: %s\r\n", isOn ? "ON" : "OFF");
  776. if(isOn)
  777. {
  778. HAL_TIM_Base_Start_IT(&htim13);
  779. }
  780. else
  781. {
  782. HAL_TIM_Base_Stop_IT(&htim13);
  783. user_pwm_setvalue(PWM_CH_GFCI_TEST, 0);
  784. }
  785. }
  786. //------------------------------------------------------------------------------
  787. void HAL_TIM_IC_CaptureCallback(TIM_HandleTypeDef *htim)
  788. {
  789. if(htim->Instance == TIM4)
  790. {
  791. if(htim->Channel == HAL_TIM_ACTIVE_CHANNEL_1)
  792. {
  793. ICP_rising[ICP_rising_idx] = HAL_TIM_ReadCapturedValue(&htim4, TIM_CHANNEL_1);
  794. if(ICP_rising_idx++>1)
  795. ICP_rising_idx = 0;
  796. if(ICP_rising[1] > ICP_rising[0])
  797. ICP_Leak_Period = ICP_rising[1] - ICP_rising[0];
  798. }
  799. else if(htim->Channel == HAL_TIM_ACTIVE_CHANNEL_2)
  800. {
  801. ICP_falling = HAL_TIM_ReadCapturedValue(&htim4, TIM_CHANNEL_2);
  802. if(ICP_falling > ICP_rising[0])
  803. ICP_Leak_Duty = ICP_falling - ICP_rising[0];
  804. }
  805. }
  806. }
  807. /* USER CODE END 1 */
  808. /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/