main.c 8.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250
  1. #if defined STM32F1
  2. # include <stm32f1xx_hal.h>
  3. #elif defined STM32F2
  4. # include <stm32f2xx_hal.h>
  5. #elif defined STM32F4
  6. # include <stm32f4xx_hal.h>
  7. #elif defined STM32G0
  8. # include <stm32g0xx_hal.h>
  9. #endif
  10. void initGPIO()
  11. {
  12. GPIO_InitTypeDef GPIO_Config;
  13. GPIO_Config.Mode = GPIO_MODE_AF_PP;
  14. GPIO_Config.Pull = GPIO_NOPULL;
  15. #if defined STM32F1
  16. __GPIOC_CLK_ENABLE();
  17. __AFIO_CLK_ENABLE();
  18. GPIO_Config.Pin = GPIO_PIN_8;
  19. GPIO_Config.Speed = GPIO_SPEED_HIGH;
  20. HAL_GPIO_Init(GPIOC, &GPIO_Config);
  21. #elif defined STM32F2
  22. __GPIOD_CLK_ENABLE();
  23. GPIO_Config.Alternate = GPIO_AF2_TIM4;
  24. GPIO_Config.Pin = GPIO_PIN_12;
  25. GPIO_Config.Speed = GPIO_SPEED_HIGH;
  26. HAL_GPIO_Init(GPIOD, &GPIO_Config);
  27. #elif defined STM32F4
  28. __GPIOA_CLK_ENABLE();
  29. GPIO_Config.Alternate = GPIO_AF2_TIM3;
  30. GPIO_Config.Pin = GPIO_PIN_6;
  31. GPIO_Config.Speed = GPIO_SPEED_HIGH;
  32. HAL_GPIO_Init(GPIOA, &GPIO_Config);
  33. #elif defined STM32G0
  34. __GPIOA_CLK_ENABLE();
  35. #if defined STM32G070xx
  36. GPIO_Config.Alternate = GPIO_AF2_TIM1;
  37. #else
  38. GPIO_Config.Alternate = GPIO_AF2_TIM2;
  39. #endif
  40. GPIO_Config.Pin = GPIO_PIN_5;
  41. GPIO_Config.Speed = GPIO_SPEED_FREQ_HIGH;
  42. HAL_GPIO_Init(GPIOA, &GPIO_Config);
  43. #endif
  44. }
  45. void initTimers()
  46. {
  47. TIM_HandleTypeDef TIM_Handle;
  48. // 10 kHz timer.
  49. #if defined STM32F1
  50. __TIM8_CLK_ENABLE();
  51. TIM_Handle.Instance = TIM8;
  52. TIM_Handle.Init.Prescaler = (uint16_t)(HAL_RCC_GetPCLK2Freq() / 10000) - 1;
  53. #elif defined STM32F2
  54. __TIM4_CLK_ENABLE();
  55. TIM_Handle.Instance = TIM4;
  56. TIM_Handle.Init.Prescaler = (uint16_t)(HAL_RCC_GetPCLK2Freq() / 100000) - 1;
  57. #elif defined STM32F4
  58. __TIM3_CLK_ENABLE();
  59. TIM_Handle.Instance = TIM3;
  60. // TIM3 Clocked from SYSCLK = 168 MHz
  61. TIM_Handle.Init.Prescaler = (uint16_t)(HAL_RCC_GetSysClockFreq() / 10000) - 1;
  62. #elif defined STM32G0
  63. #if defined STM32G070xx
  64. TIM_Handle.Instance = TIM1;
  65. __TIM1_CLK_ENABLE();
  66. #else
  67. TIM_Handle.Instance = TIM2;
  68. __TIM2_CLK_ENABLE();
  69. #endif
  70. TIM_Handle.Init.Prescaler = (uint16_t)(HAL_RCC_GetSysClockFreq() / 10000) - 1;
  71. #endif
  72. // 1 Hz blinking
  73. TIM_Handle.Init.Period = 10000;
  74. TIM_Handle.Init.ClockDivision = 0;
  75. TIM_Handle.Init.CounterMode = TIM_COUNTERMODE_UP;
  76. HAL_TIM_Base_Init(&TIM_Handle);
  77. HAL_TIM_PWM_Init(&TIM_Handle);
  78. TIM_OC_InitTypeDef TIM_OCConfig;
  79. TIM_OCConfig.OCMode = TIM_OCMODE_PWM1;
  80. // 5000 / 10000 = 50% duty cycle.
  81. TIM_OCConfig.Pulse = 4999;
  82. TIM_OCConfig.OCPolarity = TIM_OCPOLARITY_HIGH;
  83. TIM_OCConfig.OCFastMode = TIM_OCFAST_DISABLE;
  84. #if defined STM32F1
  85. HAL_TIM_PWM_ConfigChannel(&TIM_Handle, &TIM_OCConfig, TIM_CHANNEL_3);
  86. HAL_TIM_PWM_Start(&TIM_Handle, TIM_CHANNEL_3);
  87. #elif defined STM32F2
  88. HAL_TIM_PWM_ConfigChannel(&TIM_Handle, &TIM_OCConfig, TIM_CHANNEL_1);
  89. HAL_TIM_PWM_Start(&TIM_Handle, TIM_CHANNEL_1);
  90. #elif defined STM32F4
  91. HAL_TIM_PWM_ConfigChannel(&TIM_Handle, &TIM_OCConfig, TIM_CHANNEL_1);
  92. HAL_TIM_PWM_Start(&TIM_Handle, TIM_CHANNEL_1);
  93. #elif defined STM32G0
  94. HAL_TIM_PWM_ConfigChannel(&TIM_Handle, &TIM_OCConfig, TIM_CHANNEL_1);
  95. HAL_TIM_PWM_Start(&TIM_Handle, TIM_CHANNEL_1);
  96. #endif
  97. }
  98. static void initClock(void)
  99. {
  100. RCC_ClkInitTypeDef RCC_ClkInitStruct;
  101. RCC_OscInitTypeDef RCC_OscInitStruct;
  102. #if defined STM32F1
  103. __HAL_RCC_PWR_CLK_ENABLE();
  104. uint8_t fLatency;
  105. RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSE;
  106. RCC_OscInitStruct.HSEState = RCC_HSE_ON;
  107. RCC_OscInitStruct.LSEState = RCC_LSE_OFF;
  108. RCC_OscInitStruct.HSIState = RCC_HSI_OFF;
  109. RCC_OscInitStruct.HSICalibrationValue = 0;
  110. RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON;
  111. RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_HSE;
  112. # if (defined STM32F100xB) || (defined STM32F100xE)
  113. // 8 MHz * 3 = 24 MHz SYSCLK
  114. RCC_OscInitStruct.HSEPredivValue = RCC_HSE_PREDIV_DIV1;
  115. RCC_OscInitStruct.PLL.PLLMUL = RCC_PLL_MUL3;
  116. fLatency = FLASH_LATENCY_0;
  117. # elif (defined STM32F101x6) || (defined STM32F101xB) || (defined STM32F101xE) || (defined STM32F101xG)
  118. // 8 MHz / 2 * 9 = 36 MHz SYSCLK
  119. RCC_OscInitStruct.HSEPredivValue = RCC_HSE_PREDIV_DIV2;
  120. RCC_OscInitStruct.PLL.PLLMUL = RCC_PLL_MUL9;
  121. fLatency = FLASH_LATENCY_1;
  122. # elif (defined STM32F102x6) || (defined STM32F102xB)
  123. // 8 MHz * 6 = 48 MHz SYSCLK
  124. RCC_OscInitStruct.HSEPredivValue = RCC_HSE_PREDIV_DIV1;
  125. RCC_OscInitStruct.PLL.PLLMUL = RCC_PLL_MUL6;
  126. fLatency = FLASH_LATENCY_1;
  127. # elif (defined STM32F103x6) || (defined STM32F103xB) || (defined STM32F103xE) || (defined STM32F103xG)
  128. // 8 MHz * 9 = 72 MHz SYSCLK
  129. RCC_OscInitStruct.HSEPredivValue = RCC_HSE_PREDIV_DIV1;
  130. RCC_OscInitStruct.PLL.PLLMUL = RCC_PLL_MUL9;
  131. fLatency = FLASH_LATENCY_2;
  132. # elif (defined STM32F105xC) || (defined STM32F107xC)
  133. // 8 MHz * 9 = 72 MHz SYSCLK
  134. RCC_OscInitStruct.HSEPredivValue = RCC_HSE_PREDIV_DIV1;
  135. RCC_OscInitStruct.PLL.PLLMUL = RCC_PLL_MUL9;
  136. fLatency = FLASH_LATENCY_2;
  137. # endif
  138. HAL_RCC_OscConfig(&RCC_OscInitStruct);
  139. RCC_ClkInitStruct.ClockType = (RCC_CLOCKTYPE_SYSCLK | RCC_CLOCKTYPE_HCLK | RCC_CLOCKTYPE_PCLK1 | RCC_CLOCKTYPE_PCLK2);
  140. RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK;
  141. RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1;
  142. RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV1;
  143. RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV2;
  144. HAL_RCC_ClockConfig(&RCC_ClkInitStruct, fLatency);
  145. #elif defined STM32F2
  146. RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSE;
  147. RCC_OscInitStruct.HSEState = RCC_HSE_ON;
  148. RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON;
  149. RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_HSE;
  150. RCC_OscInitStruct.PLL.PLLM = 25;
  151. RCC_OscInitStruct.PLL.PLLN = 240;
  152. RCC_OscInitStruct.PLL.PLLP = RCC_PLLP_DIV2;
  153. RCC_OscInitStruct.PLL.PLLQ = 5;
  154. HAL_RCC_OscConfig(&RCC_OscInitStruct);
  155. /* Select PLL as system clock source and configure the HCLK, PCLK1 and PCLK2
  156. clocks dividers */
  157. RCC_ClkInitStruct.ClockType = (RCC_CLOCKTYPE_SYSCLK | RCC_CLOCKTYPE_HCLK | RCC_CLOCKTYPE_PCLK1 | RCC_CLOCKTYPE_PCLK2);
  158. RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK;
  159. RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1;
  160. RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV4;
  161. RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV2;
  162. HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_3);
  163. #elif defined STM32F4
  164. __HAL_RCC_PWR_CLK_ENABLE();
  165. __HAL_PWR_VOLTAGESCALING_CONFIG(PWR_REGULATOR_VOLTAGE_SCALE1);
  166. // 8 MHz * 336 / 8 / 2 = 168 MHz SYSCLK
  167. RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSE;
  168. RCC_OscInitStruct.HSEState = RCC_HSE_ON;
  169. RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON;
  170. RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_HSE;
  171. RCC_OscInitStruct.PLL.PLLM = 8;
  172. RCC_OscInitStruct.PLL.PLLN = 336;
  173. RCC_OscInitStruct.PLL.PLLP = RCC_PLLP_DIV2;
  174. RCC_OscInitStruct.PLL.PLLQ = 7;
  175. HAL_RCC_OscConfig(&RCC_OscInitStruct);
  176. RCC_ClkInitStruct.ClockType = (RCC_CLOCKTYPE_SYSCLK | RCC_CLOCKTYPE_HCLK | RCC_CLOCKTYPE_PCLK1 | RCC_CLOCKTYPE_PCLK2);
  177. RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK;
  178. RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1;
  179. RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV2;
  180. RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV4;
  181. HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_5);
  182. if (HAL_GetREVID() == 0x1001)
  183. {
  184. __HAL_FLASH_PREFETCH_BUFFER_ENABLE();
  185. }
  186. #elif defined STM32G0
  187. HAL_PWREx_ControlVoltageScaling(PWR_REGULATOR_VOLTAGE_SCALE1);
  188. RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSI;
  189. RCC_OscInitStruct.HSIState = RCC_HSI_ON;
  190. RCC_OscInitStruct.HSIDiv = RCC_HSI_DIV1;
  191. RCC_OscInitStruct.HSICalibrationValue = RCC_HSICALIBRATION_DEFAULT;
  192. RCC_OscInitStruct.PLL.PLLState = RCC_PLL_NONE;
  193. HAL_RCC_OscConfig(&RCC_OscInitStruct);
  194. RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK|RCC_CLOCKTYPE_SYSCLK
  195. |RCC_CLOCKTYPE_PCLK1;
  196. RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_HSI;
  197. RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1;
  198. RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV1;
  199. HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_0);
  200. #endif
  201. }
  202. void initAll(void)
  203. {
  204. HAL_Init();
  205. initClock();
  206. initGPIO();
  207. initTimers();
  208. }
  209. int main(void)
  210. {
  211. initAll();
  212. for (;;);
  213. return 0;
  214. }