/************************************************************************************//** * \file Demo/ARMCM7_STM32H7_Nucleo_H743ZI_IAR/Boot/main.c * \brief Bootloader application source file. * \ingroup Boot_ARMCM7_STM32H7_Nucleo_H743ZI_IAR * \internal *---------------------------------------------------------------------------------------- * C O P Y R I G H T *---------------------------------------------------------------------------------------- * Copyright (c) 2020 by Feaser http://www.feaser.com All rights reserved * *---------------------------------------------------------------------------------------- * L I C E N S E *---------------------------------------------------------------------------------------- * This file is part of OpenBLT. OpenBLT is free software: you can redistribute it and/or * modify it under the terms of the GNU General Public License as published by the Free * Software Foundation, either version 3 of the License, or (at your option) any later * version. * * OpenBLT is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR * PURPOSE. See the GNU General Public License for more details. * * You have received a copy of the GNU General Public License along with OpenBLT. It * should be located in ".\Doc\license.html". If not, contact Feaser to obtain a copy. * * \endinternal ****************************************************************************************/ /**************************************************************************************** * Include files ****************************************************************************************/ #include "boot.h" /* bootloader generic header */ #include "stm32h7xx.h" /* STM32 CPU and HAL header */ #include "stm32h7xx_ll_pwr.h" /* STM32 LL PWR header */ #include "stm32h7xx_ll_rcc.h" /* STM32 LL RCC header */ #include "stm32h7xx_ll_utils.h" /* STM32 LL UTILS header */ #include "stm32h7xx_ll_gpio.h" /* STM32 LL GPIO header */ /**************************************************************************************** * Function prototypes ****************************************************************************************/ static void Init(void); static void SystemClock_Config(void); /************************************************************************************//** ** \brief This is the entry point for the bootloader application and is called ** by the reset interrupt vector after the C-startup routines executed. ** \return none. ** ****************************************************************************************/ void main(void) { /* initialize the microcontroller */ Init(); /* initialize the bootloader */ BootInit(); /* start the infinite program loop */ while (1) { /* run the bootloader task */ BootTask(); } } /*** end of main ***/ /************************************************************************************//** ** \brief Initializes the microcontroller. ** \return none. ** ****************************************************************************************/ static void Init(void) { /* HAL library initialization */ HAL_Init(); /* configure system clock */ SystemClock_Config(); } /*** end of Init ***/ /************************************************************************************//** ** \brief System Clock Configuration. This code was created by CubeMX and configures ** the system clock to match the configuration in the bootloader's ** configuration (blt_conf.h), specifically the macros: ** BOOT_CPU_SYSTEM_SPEED_KHZ and BOOT_CPU_XTAL_SPEED_KHZ. ** Note that the Lower Layer drivers were selected in CubeMX for the RCC ** subsystem. ** \return none. ** ****************************************************************************************/ static void SystemClock_Config(void) { /* Set flash latency. */ LL_FLASH_SetLatency(LL_FLASH_LATENCY_4); if (LL_FLASH_GetLatency() != LL_FLASH_LATENCY_4) { /* Error setting flash latency. */ ASSERT_RT(BLT_FALSE); } /* Configure the main internal regulator output voltage. */ LL_PWR_ConfigSupply(LL_PWR_LDO_SUPPLY); LL_PWR_SetRegulVoltageScaling(LL_PWR_REGU_VOLTAGE_SCALE0); /* Enable the HSE clock. */ LL_RCC_HSE_EnableBypass(); LL_RCC_HSE_Enable(); /* Wait till HSE is ready. */ while (LL_RCC_HSE_IsReady() != 1) { ; } /* Configure and enable the PLL. */ LL_RCC_PLL_SetSource(LL_RCC_PLLSOURCE_HSE); LL_RCC_PLL1P_Enable(); LL_RCC_PLL1Q_Enable(); LL_RCC_PLL1_SetVCOInputRange(LL_RCC_PLLINPUTRANGE_2_4); LL_RCC_PLL1_SetVCOOutputRange(LL_RCC_PLLVCORANGE_WIDE); LL_RCC_PLL1_SetM(4); LL_RCC_PLL1_SetN(480); LL_RCC_PLL1_SetP(2); LL_RCC_PLL1_SetQ(20); LL_RCC_PLL1_SetR(2); LL_RCC_PLL1_Enable(); /* Wait till PLL is ready. */ while (LL_RCC_PLL1_IsReady() != 1) { ; } /* Intermediate AHB prescaler 2 when target frequency clock is higher than 80 MHz */ LL_RCC_SetAHBPrescaler(LL_RCC_AHB_DIV_2); LL_RCC_SetSysClkSource(LL_RCC_SYS_CLKSOURCE_PLL1); LL_RCC_SetSysPrescaler(LL_RCC_SYSCLK_DIV_1); LL_RCC_SetAHBPrescaler(LL_RCC_AHB_DIV_2); LL_RCC_SetAPB1Prescaler(LL_RCC_APB1_DIV_2); LL_RCC_SetAPB2Prescaler(LL_RCC_APB2_DIV_2); LL_RCC_SetAPB3Prescaler(LL_RCC_APB3_DIV_2); LL_RCC_SetAPB4Prescaler(LL_RCC_APB4_DIV_2); /* Configure peripheral clock sources. */ LL_RCC_SetUSARTClockSource(LL_RCC_USART234578_CLKSOURCE_PCLK1); LL_RCC_SetFDCANClockSource(LL_RCC_FDCAN_CLKSOURCE_HSE); LL_RCC_SetUSBClockSource(LL_RCC_USB_CLKSOURCE_PLL1Q); /* Update the system clock speed setting. */ LL_SetSystemCoreClock(BOOT_CPU_SYSTEM_SPEED_KHZ * 1000u); } /*** end of SystemClock_Config ***/ /************************************************************************************//** ** \brief Initializes the Global MSP. This function is called from HAL_Init() ** function to perform system level initialization (GPIOs, clock, DMA, ** interrupt). ** \return none. ** ****************************************************************************************/ void HAL_MspInit(void) { LL_GPIO_InitTypeDef GPIO_InitStruct; /* SYSCFG clock enable. */ LL_APB4_GRP1_EnableClock(LL_APB4_GRP1_PERIPH_SYSCFG); /* GPIO ports clock enable. */ LL_AHB4_GRP1_EnableClock(LL_AHB4_GRP1_PERIPH_GPIOA); LL_AHB4_GRP1_EnableClock(LL_AHB4_GRP1_PERIPH_GPIOB); LL_AHB4_GRP1_EnableClock(LL_AHB4_GRP1_PERIPH_GPIOC); LL_AHB4_GRP1_EnableClock(LL_AHB4_GRP1_PERIPH_GPIOD); #if (BOOT_COM_RS232_ENABLE > 0) /* UART clock enable. */ LL_APB1_GRP1_EnableClock(LL_APB1_GRP1_PERIPH_USART3); #endif #if (BOOT_COM_CAN_ENABLE > 0) /* CAN clock enable. */ LL_APB1_GRP2_EnableClock(LL_APB1_GRP2_PERIPH_FDCAN); #endif /* Configure GPIO pin for the LED. */ GPIO_InitStruct.Pin = LL_GPIO_PIN_7; GPIO_InitStruct.Mode = LL_GPIO_MODE_OUTPUT; GPIO_InitStruct.Speed = LL_GPIO_SPEED_FREQ_LOW; GPIO_InitStruct.OutputType = LL_GPIO_OUTPUT_PUSHPULL; GPIO_InitStruct.Pull = LL_GPIO_PULL_NO; LL_GPIO_Init(GPIOB, &GPIO_InitStruct); /* Configure GPIO pin for (optional) backdoor entry input. */ GPIO_InitStruct.Pin = LL_GPIO_PIN_13; GPIO_InitStruct.Mode = LL_GPIO_MODE_INPUT; GPIO_InitStruct.Pull = LL_GPIO_PULL_NO; LL_GPIO_Init(GPIOC, &GPIO_InitStruct); #if (BOOT_COM_RS232_ENABLE > 0) /* UART TX and RX GPIO pin configuration. */ GPIO_InitStruct.Pin = LL_GPIO_PIN_8 | LL_GPIO_PIN_9; GPIO_InitStruct.Mode = LL_GPIO_MODE_ALTERNATE; GPIO_InitStruct.Speed = LL_GPIO_SPEED_FREQ_LOW; GPIO_InitStruct.OutputType = LL_GPIO_OUTPUT_PUSHPULL; GPIO_InitStruct.Pull = LL_GPIO_PULL_NO; GPIO_InitStruct.Alternate = LL_GPIO_AF_7; LL_GPIO_Init(GPIOD, &GPIO_InitStruct); #endif #if (BOOT_COM_CAN_ENABLE > 0) /* CAN TX and RX GPIO pin configuration. */ GPIO_InitStruct.Pin = LL_GPIO_PIN_8 | LL_GPIO_PIN_9; GPIO_InitStruct.Mode = LL_GPIO_MODE_ALTERNATE; GPIO_InitStruct.Speed = LL_GPIO_SPEED_FREQ_HIGH; GPIO_InitStruct.OutputType = LL_GPIO_OUTPUT_PUSHPULL; GPIO_InitStruct.Pull = LL_GPIO_PULL_NO; GPIO_InitStruct.Alternate = LL_GPIO_AF_9; LL_GPIO_Init(GPIOB, &GPIO_InitStruct); #endif #if (BOOT_COM_USB_ENABLE > 0) /* USB pin configuration. */ GPIO_InitStruct.Pin = LL_GPIO_PIN_11 | LL_GPIO_PIN_12; GPIO_InitStruct.Mode = LL_GPIO_MODE_ALTERNATE; GPIO_InitStruct.Speed = LL_GPIO_SPEED_FREQ_VERY_HIGH; GPIO_InitStruct.OutputType = LL_GPIO_OUTPUT_PUSHPULL; GPIO_InitStruct.Pull = LL_GPIO_PULL_NO; GPIO_InitStruct.Alternate = LL_GPIO_AF_10; LL_GPIO_Init(GPIOA, &GPIO_InitStruct); #endif #if (BOOT_COM_USB_ENABLE > 0) /* USB clock enable. */ LL_AHB1_GRP1_EnableClock(LL_AHB1_GRP1_PERIPH_USB2OTGHS); #endif } /*** end of HAL_MspInit ***/ /************************************************************************************//** ** \brief DeInitializes the Global MSP. This function is called from HAL_DeInit() ** function to perform system level de-initialization (GPIOs, clock, DMA, ** interrupt). ** \return none. ** ****************************************************************************************/ void HAL_MspDeInit(void) { /* Reset the RCC clock configuration to the default reset state. */ LL_RCC_DeInit(); /* Reset GPIO pin for the LED to turn it off. */ LL_GPIO_ResetOutputPin(GPIOB, LL_GPIO_PIN_7); /* Deinit used GPIOs. */ LL_GPIO_DeInit(GPIOD); LL_GPIO_DeInit(GPIOC); LL_GPIO_DeInit(GPIOB); LL_GPIO_DeInit(GPIOA); #if (BOOT_COM_USB_ENABLE > 0) /* USB clock disable. */ LL_AHB1_GRP1_DisableClock(LL_AHB1_GRP1_PERIPH_USB2OTGHS); #endif #if (BOOT_COM_CAN_ENABLE > 0) /* CAN clock disable. */ LL_APB1_GRP2_DisableClock(LL_APB1_GRP2_PERIPH_FDCAN); #endif #if (BOOT_COM_RS232_ENABLE > 0) /* UART clock disable. */ LL_APB1_GRP1_DisableClock(LL_APB1_GRP1_PERIPH_USART3); #endif /* GPIO ports clock disable. */ LL_AHB4_GRP1_DisableClock(LL_AHB4_GRP1_PERIPH_GPIOD); LL_AHB4_GRP1_DisableClock(LL_AHB4_GRP1_PERIPH_GPIOC); LL_AHB4_GRP1_DisableClock(LL_AHB4_GRP1_PERIPH_GPIOB); LL_AHB4_GRP1_DisableClock(LL_AHB4_GRP1_PERIPH_GPIOA); /* SYSCFG clock disable. */ LL_APB4_GRP1_DisableClock(LL_APB4_GRP1_PERIPH_SYSCFG); } /*** end of HAL_MspDeInit ***/ /*********************************** end of main.c *************************************/