hal.c 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186
  1. #include "hal/hal.h"
  2. #include "hal/pwm.h"
  3. #include "stm32f3xx_ll_exti.h"
  4. void HAL_MspInit(void)
  5. {
  6. __HAL_RCC_SYSCFG_CLK_ENABLE();
  7. __HAL_RCC_PWR_CLK_ENABLE();
  8. HAL_NVIC_SetPriorityGrouping(NVIC_PRIORITYGROUP_3);
  9. }
  10. void SystemClock_Config(void)
  11. {
  12. RCC_OscInitTypeDef RCC_OscInitStruct = {0};
  13. RCC_ClkInitTypeDef RCC_ClkInitStruct = {0};
  14. RCC_PeriphCLKInitTypeDef PeriphClkInit = {0};
  15. /** Initializes the RCC Oscillators according to the specified parameters
  16. * in the RCC_OscInitTypeDef structure.
  17. */
  18. RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSE;
  19. RCC_OscInitStruct.HSEState = RCC_HSE_ON;
  20. RCC_OscInitStruct.HSEPredivValue = RCC_HSE_PREDIV_DIV1;
  21. RCC_OscInitStruct.HSIState = RCC_HSI_ON;
  22. RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON;
  23. RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_HSE;
  24. RCC_OscInitStruct.PLL.PLLMUL = RCC_PLL_MUL9;
  25. if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK)
  26. {
  27. Error_Handler();
  28. }
  29. /** Initializes the CPU, AHB and APB buses clocks
  30. */
  31. RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK|RCC_CLOCKTYPE_SYSCLK
  32. |RCC_CLOCKTYPE_PCLK1|RCC_CLOCKTYPE_PCLK2;
  33. RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK;
  34. RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1;
  35. RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV2;
  36. RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV1;
  37. if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_2) != HAL_OK)
  38. {
  39. Error_Handler();
  40. }
  41. PeriphClkInit.PeriphClockSelection = RCC_PERIPHCLK_TIM1;
  42. PeriphClkInit.Tim1ClockSelection = RCC_TIM1CLK_PLLCLK;
  43. if (HAL_RCCEx_PeriphCLKConfig(&PeriphClkInit) != HAL_OK)
  44. {
  45. Error_Handler();
  46. }
  47. SystemCoreClockUpdate();
  48. }
  49. void HAL_GPIO_init(void){
  50. GPIO_InitTypeDef GPIO_InitStruct = {0};
  51. __HAL_RCC_GPIOA_CLK_ENABLE();
  52. __HAL_RCC_GPIOB_CLK_ENABLE();
  53. __HAL_RCC_GPIOC_CLK_ENABLE();
  54. __HAL_RCC_GPIOD_CLK_ENABLE();
  55. __HAL_RCC_GPIOF_CLK_ENABLE();
  56. /*Configure GPIO pin Output Level */
  57. HAL_GPIO_WritePin(GPIOC, PWM_EN_U_Pin | PWM_EN_V_Pin | PWM_EN_W_Pin, GPIO_PIN_RESET);
  58. /*Configure GPIO pins : M1_PWM_EN_U_Pin M1_PWM_EN_V_Pin M1_PWM_EN_W_Pin */
  59. GPIO_InitStruct.Pin = PWM_EN_U_Pin | PWM_EN_V_Pin | PWM_EN_W_Pin;
  60. GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
  61. GPIO_InitStruct.Pull = GPIO_PULLDOWN;
  62. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
  63. HAL_GPIO_Init(GPIOC, &GPIO_InitStruct);
  64. GPIO_InitStruct.Pin = HALL_1_PIN;
  65. GPIO_InitStruct.Mode = GPIO_MODE_IT_RISING_FALLING;
  66. GPIO_InitStruct.Pull = GPIO_NOPULL;
  67. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
  68. HAL_GPIO_Init(HALL_1_GROUP, &GPIO_InitStruct);
  69. GPIO_InitStruct.Pin = HALL_2_PIN;
  70. GPIO_InitStruct.Mode = GPIO_MODE_IT_RISING_FALLING;
  71. GPIO_InitStruct.Pull = GPIO_NOPULL;
  72. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
  73. HAL_GPIO_Init(HALL_2_GROUP, &GPIO_InitStruct);
  74. GPIO_InitStruct.Pin = HALL_3_PIN;
  75. GPIO_InitStruct.Mode = GPIO_MODE_IT_RISING_FALLING;
  76. GPIO_InitStruct.Pull = GPIO_NOPULL;
  77. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
  78. HAL_GPIO_Init(HALL_3_GROUP, &GPIO_InitStruct);
  79. /*Configure GPIO pin : Start_Stop_Pin */
  80. GPIO_InitStruct.Pin = Start_Stop_Pin;
  81. GPIO_InitStruct.Mode = GPIO_MODE_IT_FALLING;
  82. GPIO_InitStruct.Pull = GPIO_NOPULL;
  83. HAL_GPIO_Init(Start_Stop_GPIO_Port, &GPIO_InitStruct);
  84. }
  85. void HAL_TIM_Base_MspInit(TIM_HandleTypeDef* htim_base)
  86. {
  87. GPIO_InitTypeDef GPIO_InitStruct = {0};
  88. if(htim_base->Instance==TIM1)
  89. {
  90. /* Peripheral clock enable */
  91. __HAL_RCC_TIM1_CLK_ENABLE();
  92. __HAL_RCC_GPIOA_CLK_ENABLE();
  93. /**TIM1 GPIO Configuration
  94. PA11 ------> TIM1_BKIN2
  95. */
  96. GPIO_InitStruct.Pin = M1_OCP_Pin;
  97. GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  98. GPIO_InitStruct.Pull = GPIO_PULLUP;
  99. GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
  100. GPIO_InitStruct.Alternate = GPIO_AF12_TIM1;
  101. HAL_GPIO_Init(M1_OCP_GPIO_Port, &GPIO_InitStruct);
  102. }
  103. else if (htim_base->Instance == TIM6)
  104. {
  105. __HAL_RCC_TIM6_CLK_ENABLE();
  106. }
  107. }
  108. void HAL_ADC_MspInit(ADC_HandleTypeDef* hadc)
  109. {
  110. GPIO_InitTypeDef GPIO_InitStruct = {0};
  111. if(hadc->Instance==ADC1)
  112. {
  113. /* USER CODE BEGIN ADC1_MspInit 0 */
  114. /* USER CODE END ADC1_MspInit 0 */
  115. /* Peripheral clock enable */
  116. __HAL_RCC_ADC1_CLK_ENABLE();
  117. __HAL_RCC_GPIOC_CLK_ENABLE();
  118. __HAL_RCC_GPIOA_CLK_ENABLE();
  119. /**ADC1 GPIO Configuration
  120. PC0 ------> ADC1_IN6
  121. PC1 ------> ADC1_IN7
  122. PC2 ------> ADC1_IN8
  123. PA0 ------> ADC1_IN1
  124. PA1 ------> ADC1_IN2
  125. */
  126. GPIO_InitStruct.Pin = CURR_AMPL_W_Pin|CURR_AMPL_V_Pin|TEMPERATURE_Pin;
  127. GPIO_InitStruct.Mode = GPIO_MODE_ANALOG;
  128. GPIO_InitStruct.Pull = GPIO_NOPULL;
  129. HAL_GPIO_Init(GPIOC, &GPIO_InitStruct);
  130. GPIO_InitStruct.Pin = CURR_AMPL_U_Pin|BUS_VOLTAGE_Pin;
  131. GPIO_InitStruct.Mode = GPIO_MODE_ANALOG;
  132. GPIO_InitStruct.Pull = GPIO_NOPULL;
  133. HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
  134. /* USER CODE BEGIN ADC1_MspInit 1 */
  135. /* USER CODE END ADC1_MspInit 1 */
  136. }
  137. }
  138. void HAL_NVIC_Init(void){
  139. /* TIM1_BRK_TIM15_IRQn interrupt configuration */
  140. HAL_NVIC_SetPriority(TIM1_BRK_TIM15_IRQn, 9, 0);
  141. /* TIM1_UP_TIM16_IRQn interrupt configuration */
  142. HAL_NVIC_SetPriority(TIM1_UP_TIM16_IRQn, 5, 0);
  143. /* ADC1_IRQn interrupt configuration */
  144. HAL_NVIC_SetPriority(ADC1_IRQn, 7, 0);
  145. /* TIM6 used to produces update event every 10ms to run foc slow task */
  146. HAL_NVIC_SetPriority(TIM6_DAC_IRQn, 9, 0);
  147. /* HALL EXTI configuration */
  148. HAL_NVIC_SetPriority(EXTI3_IRQn, 8, 0);
  149. HAL_NVIC_SetPriority(EXTI15_10_IRQn, 8, 0);
  150. /* USART2_IRQn interrupt configuration */
  151. HAL_NVIC_SetPriority(USART2_IRQn, 8, 0);
  152. }
  153. void HAL_EXIT_Enable(void) {
  154. HAL_NVIC_EnableIRQ(EXTI3_IRQn);
  155. HAL_NVIC_EnableIRQ(EXTI15_10_IRQn);
  156. }
  157. void Error_Handler(void)
  158. {
  159. __disable_irq();
  160. while (1){
  161. }
  162. }