123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173 |
- /**
- ******************************************************************************
- * @file system_py32f0xx.c
- * @author MCU Application Team
- * @Version V1.0.0
- * @Date 2020-10-19
- * @brief CMSIS Cortex-M0+ Device Peripheral Access Layer System Source File.
- ******************************************************************************
- */
- #include "py32f0xx.h"
- #if !defined (HSE_VALUE)
- #define HSE_VALUE 24000000U /*!< Value of the External oscillator in Hz */
- #endif /* HSE_VALUE */
- #if !defined (HSI_VALUE)
- #define HSI_VALUE 8000000U /*!< Value of the Internal oscillator in Hz*/
- #endif /* HSI_VALUE */
- #if !defined (LSI_VALUE)
- #define LSI_VALUE 32768U /*!< Value of LSI in Hz*/
- #endif /* LSI_VALUE */
- #if !defined (LSE_VALUE)
- #define LSE_VALUE 32768U /*!< Value of LSE in Hz*/
- #endif /* LSE_VALUE */
- /************************* Miscellaneous Configuration ************************/
- /*!< Uncomment the following line if you need to relocate your vector Table in
- Internal SRAM. */
- /* #define FORBID_VECT_TAB_MIGRATION */
- /* #define VECT_TAB_SRAM */
- #define VECT_TAB_OFFSET 0x00 /*!< Vector Table base offset field.
- This value must be a multiple of 0x100. */
- /******************************************************************************/
- /*----------------------------------------------------------------------------
- Clock Variable definitions
- *----------------------------------------------------------------------------*/
- /* This variable is updated in three ways:
- 1) by calling CMSIS function SystemCoreClockUpdate()
- 2) by calling HAL API function HAL_RCC_GetHCLKFreq()
- 3) each time HAL_RCC_ClockConfig() is called to configure the system clock frequency
- Note: If you use this function to configure the system clock; then there
- is no need to call the 2 first functions listed above, since SystemCoreClock
- variable is updated automatically.
- */
- uint32_t SystemCoreClock = HSI_VALUE;
- const uint32_t AHBPrescTable[16] = {0, 0, 0, 0, 0, 0, 0, 0, 1, 2, 3, 4, 6, 7, 8, 9};
- const uint32_t APBPrescTable[8] = {0, 0, 0, 0, 1, 2, 3, 4};
- const uint32_t HSIFreqTable[8] = {4000000U, 8000000U, 16000000U, 22120000U, 24000000U, 4000000U, 4000000U, 4000000U};
- /*----------------------------------------------------------------------------
- Clock functions
- *----------------------------------------------------------------------------*/
- void SystemCoreClockUpdate(void) /* Get Core Clock Frequency */
- {
- uint32_t tmp;
- uint32_t hsidiv;
- uint32_t hsifs;
- /* Get SYSCLK source -------------------------------------------------------*/
- switch (RCC->CFGR & RCC_CFGR_SWS)
- {
- case RCC_CFGR_SWS_0: /* HSE used as system clock */
- SystemCoreClock = HSE_VALUE;
- break;
- case (RCC_CFGR_SWS_1 | RCC_CFGR_SWS_0): /* LSI used as system clock */
- SystemCoreClock = LSI_VALUE;
- break;
- #if defined(RCC_LSE_SUPPORT)
- case RCC_CFGR_SWS_2: /* LSE used as system clock */
- SystemCoreClock = LSE_VALUE;
- break;
- #endif
- #if defined(RCC_PLL_SUPPORT)
- case RCC_CFGR_SWS_1: /* PLL used as system clock */
- if ((RCC->PLLCFGR & RCC_PLLCFGR_PLLSRC) == RCC_PLLCFGR_PLLSRC_HSI) /* HSI used as PLL clock source */
- {
- hsifs = ((READ_BIT(RCC->ICSCR, RCC_ICSCR_HSI_FS)) >> RCC_ICSCR_HSI_FS_Pos);
- SystemCoreClock = 2 * (HSIFreqTable[hsifs]);
- }
- else /* HSE used as PLL clock source */
- {
- SystemCoreClock = 2 * HSE_VALUE;
- }
- break;
- #endif
- case 0x00000000U: /* HSI used as system clock */
- default: /* HSI used as system clock */
- hsifs = ((READ_BIT(RCC->ICSCR, RCC_ICSCR_HSI_FS)) >> RCC_ICSCR_HSI_FS_Pos);
- hsidiv = (1UL << ((READ_BIT(RCC->CR, RCC_CR_HSIDIV)) >> RCC_CR_HSIDIV_Pos));
- SystemCoreClock = (HSIFreqTable[hsifs] / hsidiv);
- break;
- }
- /* Compute HCLK clock frequency --------------------------------------------*/
- /* Get HCLK prescaler */
- tmp = AHBPrescTable[((RCC->CFGR & RCC_CFGR_HPRE) >> RCC_CFGR_HPRE_Pos)];
- /* HCLK clock frequency */
- SystemCoreClock >>= tmp;
- }
- /**
- * Initialize the system
- *
- * @param none
- * @return none
- *
- * @brief Setup the microcontroller system.
- * Initialize the System.
- */
- void SystemInit(void)
- {
- /* Set the HSI clock to 8MHz by default */
- RCC->ICSCR = (RCC->ICSCR & 0xFFFF0000) | (0x1 << 13) | *(uint32_t *)(0x1fff0f04);
- /* Configure the Vector Table location add offset address ------------------*/
- #ifdef VECT_TAB_SRAM
- SCB->VTOR = SRAM_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
- }
- #ifndef FORBID_VECT_TAB_MIGRATION
- #ifndef VECT_TAB_SRAM
- #if (defined (__CC_ARM)) || (defined (__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050))
- extern int32_t $Super$$main(void);
- uint32_t VECT_SRAM_TAB[48]__attribute__((section(".ARM.__at_0x20000000")));
- /* re-define main function */
- int $Sub$$main(void)
- {
- uint8_t i;
- uint32_t *pFmcVect = (uint32_t *)(FLASH_BASE | VECT_TAB_OFFSET);
- for (i = 0; i < 48; i++)
- {
- VECT_SRAM_TAB[i] = pFmcVect[i];
- }
- SCB->VTOR = SRAM_BASE;
- $Super$$main();
- return 0;
- }
- #elif defined(__ICCARM__)
- extern int32_t main(void);
- /* __low_level_init will auto called by IAR cstartup */
- extern void __iar_data_init3(void);
- uint32_t VECT_SRAM_TAB[48] @SRAM_BASE;
- int __low_level_init(void)
- {
- uint8_t i;
- uint32_t *pFmcVect = (uint32_t *)(FLASH_BASE | VECT_TAB_OFFSET);
- /* call IAR table copy function. */
- __iar_data_init3();
- for (i = 0; i < 48; i++)
- {
- VECT_SRAM_TAB[i] = pFmcVect[i];
- }
- SCB->VTOR = SRAM_BASE;
- main();
- return 0;
- }
- #endif
- #endif
- #endif
|