2015-11-21 09:27:08 +00:00
|
|
|
#include "../../../gfx.h"
|
2016-06-16 10:34:03 +00:00
|
|
|
#undef Red
|
|
|
|
#undef Green
|
|
|
|
#undef Blue
|
2015-07-11 06:13:05 +00:00
|
|
|
#include "stm32f7xx.h"
|
|
|
|
|
|
|
|
#if !defined (HSE_VALUE)
|
|
|
|
#define HSE_VALUE ((uint32_t)25000000) /*!< Default value of the External oscillator in Hz */
|
|
|
|
#endif /* HSE_VALUE */
|
|
|
|
|
|
|
|
#if !defined (HSI_VALUE)
|
|
|
|
#define HSI_VALUE ((uint32_t)16000000) /*!< Value of the Internal oscillator in Hz*/
|
|
|
|
#endif /* HSI_VALUE */
|
|
|
|
|
|
|
|
/*!< Uncomment the following line if you need to relocate your vector Table in
|
|
|
|
Internal SRAM. */
|
|
|
|
/* #define VECT_TAB_SRAM */
|
|
|
|
#define VECT_TAB_OFFSET 0x00 /*!< Vector Table base offset field.
|
|
|
|
This value must be a multiple of 0x200. */
|
|
|
|
|
2015-11-05 07:09:11 +00:00
|
|
|
#if !GFX_USE_OS_CHIBIOS
|
|
|
|
uint32_t SystemCoreClock = HSI_VALUE;
|
|
|
|
#endif
|
2015-07-11 06:13:05 +00:00
|
|
|
|
2015-11-05 07:09:11 +00:00
|
|
|
__IO const uint8_t AHBPrescTable[16] = {0, 0, 0, 0, 0, 0, 0, 0, 1, 2, 3, 4, 6, 7, 8, 9};
|
2015-07-11 06:13:05 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Setup the microcontroller system
|
|
|
|
* Initialize the Embedded Flash Interface, the PLL and update the
|
|
|
|
* SystemFrequency variable.
|
|
|
|
* @param None
|
|
|
|
* @retval None
|
|
|
|
*/
|
|
|
|
void SystemInit(void)
|
|
|
|
{
|
|
|
|
/* FPU settings ------------------------------------------------------------*/
|
|
|
|
#if (__FPU_PRESENT == 1) && (__FPU_USED == 1)
|
|
|
|
SCB->CPACR |= ((3UL << 10*2)|(3UL << 11*2)); /* set CP10 and CP11 Full Access */
|
|
|
|
#endif
|
|
|
|
/* Reset the RCC clock configuration to the default reset state ------------*/
|
|
|
|
/* Set HSION bit */
|
|
|
|
RCC->CR |= (uint32_t)0x00000001;
|
|
|
|
|
|
|
|
/* Reset CFGR register */
|
|
|
|
RCC->CFGR = 0x00000000;
|
|
|
|
|
|
|
|
/* Reset HSEON, CSSON and PLLON bits */
|
|
|
|
RCC->CR &= (uint32_t)0xFEF6FFFF;
|
|
|
|
|
|
|
|
/* Reset PLLCFGR register */
|
2015-07-21 13:04:49 +00:00
|
|
|
//RCC->PLLCFGR = 0x24003010; // From discovery example
|
|
|
|
// M = 12 = 0b1100, N = 192 = 0b11000000, P = 2 = 0b10, Q = 2 = 0b10
|
|
|
|
RCC->PLLCFGR = 0x00C0980C;
|
2015-07-11 06:13:05 +00:00
|
|
|
|
|
|
|
/* Reset HSEBYP bit */
|
|
|
|
RCC->CR &= (uint32_t)0xFFFBFFFF;
|
|
|
|
|
|
|
|
/* Disable all interrupts */
|
|
|
|
RCC->CIR = 0x00000000;
|
|
|
|
|
|
|
|
/* Configure the Vector Table location add offset address ------------------*/
|
|
|
|
#ifdef VECT_TAB_SRAM
|
|
|
|
SCB->VTOR = SRAM1_BASE | VECT_TAB_OFFSET; /* Vector Table Relocation in Internal SRAM */
|
|
|
|
#else
|
|
|
|
SCB->VTOR = FLASH_BASE | VECT_TAB_OFFSET; /* Vector Table Relocation in Internal FLASH */
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Update SystemCoreClock variable according to Clock Register Values.
|
|
|
|
* The SystemCoreClock variable contains the core clock (HCLK), it can
|
|
|
|
* be used by the user application to setup the SysTick timer or configure
|
|
|
|
* other parameters.
|
|
|
|
*
|
|
|
|
* @note Each time the core clock (HCLK) changes, this function must be called
|
|
|
|
* to update SystemCoreClock variable value. Otherwise, any configuration
|
|
|
|
* based on this variable will be incorrect.
|
|
|
|
*
|
|
|
|
* @note - The system frequency computed by this function is not the real
|
|
|
|
* frequency in the chip. It is calculated based on the predefined
|
|
|
|
* constant and the selected clock source:
|
|
|
|
*
|
|
|
|
* - If SYSCLK source is HSI, SystemCoreClock will contain the HSI_VALUE(*)
|
|
|
|
*
|
|
|
|
* - If SYSCLK source is HSE, SystemCoreClock will contain the HSE_VALUE(**)
|
|
|
|
*
|
|
|
|
* - If SYSCLK source is PLL, SystemCoreClock will contain the HSE_VALUE(**)
|
|
|
|
* or HSI_VALUE(*) multiplied/divided by the PLL factors.
|
|
|
|
*
|
|
|
|
* (*) HSI_VALUE is a constant defined in stm32f7xx.h file (default value
|
|
|
|
* 16 MHz) but the real value may vary depending on the variations
|
|
|
|
* in voltage and temperature.
|
|
|
|
*
|
|
|
|
* (**) HSE_VALUE is a constant defined in stm32f7xx.h file (default value
|
|
|
|
* 25 MHz), user has to ensure that HSE_VALUE is same as the real
|
|
|
|
* frequency of the crystal used. Otherwise, this function may
|
|
|
|
* have wrong result.
|
|
|
|
*
|
|
|
|
* - The result of this function could be not correct when using fractional
|
|
|
|
* value for HSE crystal.
|
|
|
|
*
|
|
|
|
* @param None
|
|
|
|
* @retval None
|
|
|
|
*/
|
|
|
|
void SystemCoreClockUpdate(void)
|
|
|
|
{
|
|
|
|
uint32_t tmp = 0, pllvco = 0, pllp = 2, pllsource = 0, pllm = 2;
|
|
|
|
|
|
|
|
/* Get SYSCLK source -------------------------------------------------------*/
|
|
|
|
tmp = RCC->CFGR & RCC_CFGR_SWS;
|
|
|
|
|
|
|
|
switch (tmp)
|
|
|
|
{
|
|
|
|
case 0x00: /* HSI used as system clock source */
|
|
|
|
SystemCoreClock = HSI_VALUE;
|
|
|
|
break;
|
|
|
|
case 0x04: /* HSE used as system clock source */
|
|
|
|
SystemCoreClock = HSE_VALUE;
|
|
|
|
break;
|
|
|
|
case 0x08: /* PLL used as system clock source */
|
|
|
|
|
|
|
|
/* PLL_VCO = (HSE_VALUE or HSI_VALUE / PLL_M) * PLL_N
|
|
|
|
SYSCLK = PLL_VCO / PLL_P
|
|
|
|
*/
|
|
|
|
pllsource = (RCC->PLLCFGR & RCC_PLLCFGR_PLLSRC) >> 22;
|
|
|
|
pllm = RCC->PLLCFGR & RCC_PLLCFGR_PLLM;
|
|
|
|
|
|
|
|
if (pllsource != 0)
|
|
|
|
{
|
|
|
|
/* HSE used as PLL clock source */
|
|
|
|
pllvco = (HSE_VALUE / pllm) * ((RCC->PLLCFGR & RCC_PLLCFGR_PLLN) >> 6);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
/* HSI used as PLL clock source */
|
|
|
|
pllvco = (HSI_VALUE / pllm) * ((RCC->PLLCFGR & RCC_PLLCFGR_PLLN) >> 6);
|
|
|
|
}
|
|
|
|
|
|
|
|
pllp = (((RCC->PLLCFGR & RCC_PLLCFGR_PLLP) >>16) + 1 ) *2;
|
|
|
|
SystemCoreClock = pllvco/pllp;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
SystemCoreClock = HSI_VALUE;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
/* Compute HCLK frequency --------------------------------------------------*/
|
|
|
|
/* Get HCLK prescaler */
|
|
|
|
tmp = AHBPrescTable[((RCC->CFGR & RCC_CFGR_HPRE) >> 4)];
|
|
|
|
/* HCLK frequency */
|
|
|
|
SystemCoreClock >>= tmp;
|
|
|
|
}
|
|
|
|
|