[FL-1196] Targets: add F6 (#427)
* Targets: add F6 * F6: Update linker script for use with internal storage * F6: synchronize with F5, add all changes arriving in V9 board, update cube project. Github workflow: add multi-target build, add F6 to build targets. * CI: fix full assembly * CI: better artifact naming scheme * CI: fix artifacts wildcard * F6: Swap C10 - A15, vibro and sdcard detect pins
This commit is contained in:
		
							
								
								
									
										178
									
								
								firmware/targets/f6/Src/main.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										178
									
								
								firmware/targets/f6/Src/main.c
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,178 @@
 | 
			
		||||
#include "main.h"
 | 
			
		||||
 | 
			
		||||
#include "cmsis_os2.h"
 | 
			
		||||
#include "adc.h"
 | 
			
		||||
#include "aes.h"
 | 
			
		||||
#include "comp.h"
 | 
			
		||||
#include "crc.h"
 | 
			
		||||
#include "pka.h"
 | 
			
		||||
#include "rf.h"
 | 
			
		||||
#include "rng.h"
 | 
			
		||||
#include "rtc.h"
 | 
			
		||||
#include "spi.h"
 | 
			
		||||
#include "tim.h"
 | 
			
		||||
#include "usart.h"
 | 
			
		||||
#include "usb_device.h"
 | 
			
		||||
#include "gpio.h"
 | 
			
		||||
#include "fatfs/fatfs.h"
 | 
			
		||||
 | 
			
		||||
#include <furi.h>
 | 
			
		||||
#include <api-hal.h>
 | 
			
		||||
#include <flipper.h>
 | 
			
		||||
 | 
			
		||||
void SystemClock_Config(void);
 | 
			
		||||
void MX_FREERTOS_Init(void);
 | 
			
		||||
 | 
			
		||||
int main(void) {
 | 
			
		||||
    // Initialize FURI layer
 | 
			
		||||
    furi_init();
 | 
			
		||||
 | 
			
		||||
    // Initialize ST HAL hardware
 | 
			
		||||
    HAL_Init();
 | 
			
		||||
    SystemClock_Config();
 | 
			
		||||
    MX_USART1_UART_Init();
 | 
			
		||||
    FURI_LOG_I("HAL", "USART OK");
 | 
			
		||||
    MX_RTC_Init();
 | 
			
		||||
    FURI_LOG_I("HAL", "RTC OK");
 | 
			
		||||
    MX_GPIO_Init();
 | 
			
		||||
    FURI_LOG_I("HAL", "GPIO OK");
 | 
			
		||||
    MX_ADC1_Init();
 | 
			
		||||
    FURI_LOG_I("HAL", "ADC1 OK");
 | 
			
		||||
    MX_SPI1_Init();
 | 
			
		||||
    FURI_LOG_I("HAL", "SPI1 OK");
 | 
			
		||||
    MX_SPI2_Init();
 | 
			
		||||
    FURI_LOG_I("HAL", "SPI2 OK");
 | 
			
		||||
    MX_USB_Device_Init();
 | 
			
		||||
    FURI_LOG_I("HAL", "USB OK");
 | 
			
		||||
    MX_TIM1_Init();
 | 
			
		||||
    FURI_LOG_I("HAL", "TIM1 OK");
 | 
			
		||||
    MX_TIM2_Init();
 | 
			
		||||
    FURI_LOG_I("HAL", "TIM2 OK");
 | 
			
		||||
    MX_TIM16_Init();
 | 
			
		||||
    FURI_LOG_I("HAL", "TIM16 OK");
 | 
			
		||||
    MX_COMP1_Init();
 | 
			
		||||
    FURI_LOG_I("HAL", "COMP1 OK");
 | 
			
		||||
    MX_RF_Init();
 | 
			
		||||
    FURI_LOG_I("HAL", "RF OK");
 | 
			
		||||
    MX_PKA_Init();
 | 
			
		||||
    FURI_LOG_I("HAL", "PKA OK");
 | 
			
		||||
    MX_RNG_Init();
 | 
			
		||||
    FURI_LOG_I("HAL", "RNG OK");
 | 
			
		||||
    MX_AES1_Init();
 | 
			
		||||
    FURI_LOG_I("HAL", "AES1 OK");
 | 
			
		||||
    MX_AES2_Init();
 | 
			
		||||
    FURI_LOG_I("HAL", "AES2 OK");
 | 
			
		||||
    MX_CRC_Init();
 | 
			
		||||
    FURI_LOG_I("HAL", "CRC OK");
 | 
			
		||||
 | 
			
		||||
    // Flipper API HAL
 | 
			
		||||
    api_hal_init();
 | 
			
		||||
 | 
			
		||||
    // 3rd party
 | 
			
		||||
    MX_FATFS_Init();
 | 
			
		||||
    FURI_LOG_I("HAL", "FATFS OK");
 | 
			
		||||
    // CMSIS initialization
 | 
			
		||||
    osKernelInitialize();
 | 
			
		||||
    FURI_LOG_I("HAL", "KERNEL OK");
 | 
			
		||||
    // Init flipper
 | 
			
		||||
    flipper_init();
 | 
			
		||||
    // Start kernel
 | 
			
		||||
    osKernelStart();
 | 
			
		||||
 | 
			
		||||
    while (1) {}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void SystemClock_Config(void)
 | 
			
		||||
{
 | 
			
		||||
    RCC_OscInitTypeDef RCC_OscInitStruct = {0};
 | 
			
		||||
    RCC_ClkInitTypeDef RCC_ClkInitStruct = {0};
 | 
			
		||||
    RCC_PeriphCLKInitTypeDef PeriphClkInitStruct = {0};
 | 
			
		||||
 | 
			
		||||
    HAL_PWR_EnableBkUpAccess();
 | 
			
		||||
 | 
			
		||||
    __HAL_RCC_LSEDRIVE_CONFIG(RCC_LSEDRIVE_MEDIUMLOW);
 | 
			
		||||
    __HAL_PWR_VOLTAGESCALING_CONFIG(PWR_REGULATOR_VOLTAGE_SCALE1);
 | 
			
		||||
    LL_RCC_HSE_SetCapacitorTuning(0x18);
 | 
			
		||||
 | 
			
		||||
    RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSI | RCC_OSCILLATORTYPE_HSE
 | 
			
		||||
                                       | RCC_OSCILLATORTYPE_LSI1 | RCC_OSCILLATORTYPE_LSE;
 | 
			
		||||
    RCC_OscInitStruct.HSIState = RCC_HSI_ON;
 | 
			
		||||
    RCC_OscInitStruct.HSEState = RCC_HSE_ON;
 | 
			
		||||
    RCC_OscInitStruct.LSIState = RCC_LSI_ON;
 | 
			
		||||
    RCC_OscInitStruct.LSEState = RCC_LSE_ON;
 | 
			
		||||
    RCC_OscInitStruct.HSICalibrationValue = RCC_HSICALIBRATION_DEFAULT;
 | 
			
		||||
    RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON;
 | 
			
		||||
    RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_HSE;
 | 
			
		||||
    RCC_OscInitStruct.PLL.PLLM = RCC_PLLM_DIV2;
 | 
			
		||||
    RCC_OscInitStruct.PLL.PLLN = 8;
 | 
			
		||||
    RCC_OscInitStruct.PLL.PLLP = RCC_PLLP_DIV2;
 | 
			
		||||
    RCC_OscInitStruct.PLL.PLLR = RCC_PLLR_DIV2;
 | 
			
		||||
    RCC_OscInitStruct.PLL.PLLQ = RCC_PLLQ_DIV2;
 | 
			
		||||
    if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK) {
 | 
			
		||||
        Error_Handler();
 | 
			
		||||
    }
 | 
			
		||||
    
 | 
			
		||||
    RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK4|RCC_CLOCKTYPE_HCLK2
 | 
			
		||||
                                                            |RCC_CLOCKTYPE_HCLK|RCC_CLOCKTYPE_SYSCLK
 | 
			
		||||
                                                            |RCC_CLOCKTYPE_PCLK1|RCC_CLOCKTYPE_PCLK2;
 | 
			
		||||
    RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK;
 | 
			
		||||
    RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1;
 | 
			
		||||
    RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV1;
 | 
			
		||||
    RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV1;
 | 
			
		||||
    RCC_ClkInitStruct.AHBCLK2Divider = RCC_SYSCLK_DIV2;
 | 
			
		||||
    RCC_ClkInitStruct.AHBCLK4Divider = RCC_SYSCLK_DIV1;
 | 
			
		||||
 | 
			
		||||
    if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_3) != HAL_OK) {
 | 
			
		||||
        Error_Handler();
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    PeriphClkInitStruct.PeriphClockSelection = RCC_PERIPHCLK_SMPS|RCC_PERIPHCLK_RFWAKEUP
 | 
			
		||||
                                                            |RCC_PERIPHCLK_RTC|RCC_PERIPHCLK_USART1
 | 
			
		||||
                                                            |RCC_PERIPHCLK_I2C1|RCC_PERIPHCLK_CLK48SEL
 | 
			
		||||
                                                            |RCC_PERIPHCLK_USB|RCC_PERIPHCLK_RNG
 | 
			
		||||
                                                            |RCC_PERIPHCLK_ADC;
 | 
			
		||||
    PeriphClkInitStruct.PLLSAI1.PLLN = 6;
 | 
			
		||||
    PeriphClkInitStruct.PLLSAI1.PLLP = RCC_PLLP_DIV2;
 | 
			
		||||
    PeriphClkInitStruct.PLLSAI1.PLLQ = RCC_PLLQ_DIV2;
 | 
			
		||||
    PeriphClkInitStruct.PLLSAI1.PLLR = RCC_PLLR_DIV2;
 | 
			
		||||
    PeriphClkInitStruct.PLLSAI1.PLLSAI1ClockOut = RCC_PLLSAI1_USBCLK|RCC_PLLSAI1_ADCCLK;
 | 
			
		||||
    PeriphClkInitStruct.Usart1ClockSelection = RCC_USART1CLKSOURCE_PCLK2;
 | 
			
		||||
    PeriphClkInitStruct.I2c1ClockSelection = RCC_I2C1CLKSOURCE_PCLK1;
 | 
			
		||||
    PeriphClkInitStruct.UsbClockSelection = RCC_USBCLKSOURCE_PLLSAI1;
 | 
			
		||||
    PeriphClkInitStruct.RngClockSelection = RCC_RNGCLKSOURCE_CLK48;
 | 
			
		||||
    PeriphClkInitStruct.AdcClockSelection = RCC_ADCCLKSOURCE_PLLSAI1;
 | 
			
		||||
    PeriphClkInitStruct.RTCClockSelection = RCC_RTCCLKSOURCE_LSE;
 | 
			
		||||
    PeriphClkInitStruct.RFWakeUpClockSelection = RCC_RFWKPCLKSOURCE_LSE;
 | 
			
		||||
    PeriphClkInitStruct.SmpsClockSelection = RCC_SMPSCLKSOURCE_HSE;
 | 
			
		||||
    PeriphClkInitStruct.SmpsDivSelection = RCC_SMPSCLKDIV_RANGE1;
 | 
			
		||||
    if (HAL_RCCEx_PeriphCLKConfig(&PeriphClkInitStruct) != HAL_OK) {
 | 
			
		||||
        Error_Handler();
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    // CSS for HSE
 | 
			
		||||
    HAL_RCC_EnableCSS();
 | 
			
		||||
    // CSS for LSE
 | 
			
		||||
    HAL_RCCEx_EnableLSECSS();
 | 
			
		||||
    HAL_RCCEx_EnableLSECSS_IT();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void Error_Handler(void) {
 | 
			
		||||
    asm("bkpt 1");
 | 
			
		||||
    while(1) {}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#ifdef  USE_FULL_ASSERT
 | 
			
		||||
/**
 | 
			
		||||
    * @brief  Reports the name of the source file and the source line number
 | 
			
		||||
    *         where the assert_param error has occurred.
 | 
			
		||||
    * @param  file: pointer to the source file name
 | 
			
		||||
    * @param  line: assert_param error line source number
 | 
			
		||||
    * @retval None
 | 
			
		||||
    */
 | 
			
		||||
void assert_failed(uint8_t *file, uint32_t line) {
 | 
			
		||||
    /* USER CODE BEGIN 6 */
 | 
			
		||||
    /* User can add his own implementation to report the file name and line number,
 | 
			
		||||
         tex: printf("Wrong parameters value: file %s on line %d\r\n", file, line) */
 | 
			
		||||
    /* USER CODE END 6 */
 | 
			
		||||
}
 | 
			
		||||
#endif /* USE_FULL_ASSERT */
 | 
			
		||||
		Reference in New Issue
	
	Block a user