main.c 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155
  1. #include "main.h"
  2. #include "cmsis_os2.h"
  3. #include "adc.h"
  4. #include "aes.h"
  5. #include "comp.h"
  6. #include "crc.h"
  7. #include "i2c.h"
  8. #include "pka.h"
  9. #include "rf.h"
  10. #include "rng.h"
  11. #include "rtc.h"
  12. #include "spi.h"
  13. #include "tim.h"
  14. #include "usart.h"
  15. #include "usb_device.h"
  16. #include "gpio.h"
  17. #include "fatfs/fatfs.h"
  18. #include <furi.h>
  19. #include <api-hal.h>
  20. #include <flipper.h>
  21. void SystemClock_Config(void);
  22. void MX_FREERTOS_Init(void);
  23. int main(void)
  24. {
  25. HAL_Init();
  26. SystemClock_Config();
  27. MX_GPIO_Init();
  28. MX_ADC1_Init();
  29. MX_I2C1_Init();
  30. MX_RTC_Init();
  31. MX_SPI1_Init();
  32. MX_SPI2_Init();
  33. MX_USART1_UART_Init();
  34. MX_USB_Device_Init();
  35. MX_TIM1_Init();
  36. MX_TIM2_Init();
  37. MX_TIM16_Init();
  38. MX_COMP1_Init();
  39. MX_RF_Init();
  40. MX_PKA_Init();
  41. MX_RNG_Init();
  42. MX_AES1_Init();
  43. MX_AES2_Init();
  44. MX_CRC_Init();
  45. api_hal_init();
  46. MX_FATFS_Init();
  47. delay_us_init_DWT();
  48. furi_init();
  49. // CMSIS initialization
  50. osKernelInitialize();
  51. // Init flipper
  52. flipper_init();
  53. // Start kernel
  54. osKernelStart();
  55. while (1) {}
  56. }
  57. void SystemClock_Config(void)
  58. {
  59. RCC_OscInitTypeDef RCC_OscInitStruct = {0};
  60. RCC_ClkInitTypeDef RCC_ClkInitStruct = {0};
  61. RCC_PeriphCLKInitTypeDef PeriphClkInitStruct = {0};
  62. HAL_PWR_EnableBkUpAccess();
  63. __HAL_RCC_LSEDRIVE_CONFIG(RCC_LSEDRIVE_MEDIUMLOW);
  64. __HAL_PWR_VOLTAGESCALING_CONFIG(PWR_REGULATOR_VOLTAGE_SCALE1);
  65. RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSI|RCC_OSCILLATORTYPE_HSE
  66. |RCC_OSCILLATORTYPE_LSE;
  67. RCC_OscInitStruct.HSEState = RCC_HSE_ON;
  68. RCC_OscInitStruct.LSEState = RCC_LSE_ON;
  69. RCC_OscInitStruct.HSIState = RCC_HSI_ON;
  70. RCC_OscInitStruct.HSICalibrationValue = RCC_HSICALIBRATION_DEFAULT;
  71. RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON;
  72. RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_HSE;
  73. RCC_OscInitStruct.PLL.PLLM = RCC_PLLM_DIV2;
  74. RCC_OscInitStruct.PLL.PLLN = 8;
  75. RCC_OscInitStruct.PLL.PLLP = RCC_PLLP_DIV2;
  76. RCC_OscInitStruct.PLL.PLLR = RCC_PLLR_DIV2;
  77. RCC_OscInitStruct.PLL.PLLQ = RCC_PLLQ_DIV2;
  78. if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK) {
  79. Error_Handler();
  80. }
  81. RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK4|RCC_CLOCKTYPE_HCLK2
  82. |RCC_CLOCKTYPE_HCLK|RCC_CLOCKTYPE_SYSCLK
  83. |RCC_CLOCKTYPE_PCLK1|RCC_CLOCKTYPE_PCLK2;
  84. RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK;
  85. RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1;
  86. RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV1;
  87. RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV1;
  88. RCC_ClkInitStruct.AHBCLK2Divider = RCC_SYSCLK_DIV2;
  89. RCC_ClkInitStruct.AHBCLK4Divider = RCC_SYSCLK_DIV1;
  90. if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_3) != HAL_OK) {
  91. Error_Handler();
  92. }
  93. PeriphClkInitStruct.PeriphClockSelection = RCC_PERIPHCLK_SMPS|RCC_PERIPHCLK_RFWAKEUP
  94. |RCC_PERIPHCLK_RTC|RCC_PERIPHCLK_USART1
  95. |RCC_PERIPHCLK_I2C1|RCC_PERIPHCLK_CLK48SEL
  96. |RCC_PERIPHCLK_USB|RCC_PERIPHCLK_RNG
  97. |RCC_PERIPHCLK_ADC;
  98. PeriphClkInitStruct.PLLSAI1.PLLN = 6;
  99. PeriphClkInitStruct.PLLSAI1.PLLP = RCC_PLLP_DIV2;
  100. PeriphClkInitStruct.PLLSAI1.PLLQ = RCC_PLLQ_DIV2;
  101. PeriphClkInitStruct.PLLSAI1.PLLR = RCC_PLLR_DIV2;
  102. PeriphClkInitStruct.PLLSAI1.PLLSAI1ClockOut = RCC_PLLSAI1_USBCLK|RCC_PLLSAI1_ADCCLK;
  103. PeriphClkInitStruct.Usart1ClockSelection = RCC_USART1CLKSOURCE_PCLK2;
  104. PeriphClkInitStruct.I2c1ClockSelection = RCC_I2C1CLKSOURCE_PCLK1;
  105. PeriphClkInitStruct.UsbClockSelection = RCC_USBCLKSOURCE_PLLSAI1;
  106. PeriphClkInitStruct.RngClockSelection = RCC_RNGCLKSOURCE_CLK48;
  107. PeriphClkInitStruct.AdcClockSelection = RCC_ADCCLKSOURCE_PLLSAI1;
  108. PeriphClkInitStruct.RTCClockSelection = RCC_RTCCLKSOURCE_LSE;
  109. PeriphClkInitStruct.RFWakeUpClockSelection = RCC_RFWKPCLKSOURCE_LSE;
  110. PeriphClkInitStruct.SmpsClockSelection = RCC_SMPSCLKSOURCE_HSE;
  111. PeriphClkInitStruct.SmpsDivSelection = RCC_SMPSCLKDIV_RANGE1;
  112. if (HAL_RCCEx_PeriphCLKConfig(&PeriphClkInitStruct) != HAL_OK) {
  113. Error_Handler();
  114. }
  115. // Enable CSS for both clocks
  116. HAL_RCC_EnableCSS();
  117. HAL_RCCEx_EnableLSECSS();
  118. }
  119. void Error_Handler(void) {
  120. asm("bkpt 1");
  121. while(1) {}
  122. }
  123. #ifdef USE_FULL_ASSERT
  124. /**
  125. * @brief Reports the name of the source file and the source line number
  126. * where the assert_param error has occurred.
  127. * @param file: pointer to the source file name
  128. * @param line: assert_param error line source number
  129. * @retval None
  130. */
  131. void assert_failed(uint8_t *file, uint32_t line) {
  132. /* USER CODE BEGIN 6 */
  133. /* User can add his own implementation to report the file name and line number,
  134. tex: printf("Wrong parameters value: file %s on line %d\r\n", file, line) */
  135. /* USER CODE END 6 */
  136. }
  137. #endif /* USE_FULL_ASSERT */