main.c 6.6 KB

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