亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? system_stm32f10x.c

?? STM32有很強大的支持
?? C
?? 第 1 頁 / 共 2 頁
字號:
/**
  ******************************************************************************
  * @file system_stm32f10x.c
  * @brief CMSIS Cortex-M3 Device Peripheral Access Layer System Source File.
  * @author STMicroelectronics - MCD Application Team
  * @version V3.0.0
  * @date 04/06/2009
  ******************************************************************************
  *
  * THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
  * WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE
  * TIME. AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY
  * DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING
  * FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE
  * CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
  *
  * <h2><center>&copy; COPYRIGHT 2009 STMicroelectronics</center></h2>
  ******************************************************************************
  */

/** @addtogroup Private_Includes
  * @{
  */

#include "stm32f10x.h"

/**
  * @}
  */

/** @addtogroup Private_TypesDefinitions
  * @{
  */

/**
  * @}
  */

/** @addtogroup Private_Defines
  * @{
  */

/*!< Uncomment the line corresponding to the desired System clock (SYSCLK)
   frequency (after reset the HSI is used as SYSCLK source) */
//#define SYSCLK_FREQ_HSE    HSE_Value
//#define SYSCLK_FREQ_20MHz  20000000
//#define SYSCLK_FREQ_36MHz  36000000
//#define SYSCLK_FREQ_48MHz  48000000
//#define SYSCLK_FREQ_56MHz  56000000
#define SYSCLK_FREQ_72MHz  72000000

/*!< Uncomment the  following line if you need to use external SRAM mounted
     on STM3210E-EVAL board (STM32 High density devices) as data memory  */ 
#ifdef STM32F10X_HD
/* #define DATA_IN_ExtSRAM */
#endif /* STM32F10X_HD */

/**
  * @}
  */

/** @addtogroup Private_Macros
  * @{
  */

/**
  * @}
  */

/** @addtogroup Private_Variables
  * @{
  */

/*******************************************************************************
*  Clock Definitions
*******************************************************************************/
#ifdef SYSCLK_FREQ_HSE
  const uint32_t SystemFrequency         = SYSCLK_FREQ_HSE;        /*!< System Clock Frequency (Core Clock) */
  const uint32_t SystemFrequency_SysClk  = SYSCLK_FREQ_HSE;        /*!< System clock                        */
  const uint32_t SystemFrequency_AHBClk  = SYSCLK_FREQ_HSE;        /*!< AHB System bus speed                */
  const uint32_t SystemFrequency_APB1Clk = SYSCLK_FREQ_HSE;        /*!< APB Peripheral bus 1 (low)  speed   */
  const uint32_t SystemFrequency_APB2Clk = SYSCLK_FREQ_HSE;        /*!< APB Peripheral bus 2 (high) speed   */
#elif defined SYSCLK_FREQ_20MHz
  const uint32_t SystemFrequency         = SYSCLK_FREQ_20MHz;      /*!< System Clock Frequency (Core Clock) */
  const uint32_t SystemFrequency_SysClk  = SYSCLK_FREQ_20MHz;      /*!< System clock                        */
  const uint32_t SystemFrequency_AHBClk  = SYSCLK_FREQ_20MHz;      /*!< AHB System bus speed                */
  const uint32_t SystemFrequency_APB1Clk = SYSCLK_FREQ_20MHz;      /*!< APB Peripheral bus 1 (low)  speed   */
  const uint32_t SystemFrequency_APB2Clk = SYSCLK_FREQ_20MHz;      /*!< APB Peripheral bus 2 (high) speed   */
#elif defined SYSCLK_FREQ_36MHz
  const uint32_t SystemFrequency         = SYSCLK_FREQ_36MHz;      /*!< System Clock Frequency (Core Clock) */
  const uint32_t SystemFrequency_SysClk  = SYSCLK_FREQ_36MHz;      /*!< System clock                        */
  const uint32_t SystemFrequency_AHBClk  = SYSCLK_FREQ_36MHz;      /*!< AHB System bus speed                */
  const uint32_t SystemFrequency_APB1Clk = SYSCLK_FREQ_36MHz;      /*!< APB Peripheral bus 1 (low)  speed   */
  const uint32_t SystemFrequency_APB2Clk = SYSCLK_FREQ_36MHz;      /*!< APB Peripheral bus 2 (high) speed   */
#elif defined SYSCLK_FREQ_48MHz
  const uint32_t SystemFrequency         = SYSCLK_FREQ_48MHz;      /*!< System Clock Frequency (Core Clock) */
  const uint32_t SystemFrequency_SysClk  = SYSCLK_FREQ_48MHz;      /*!< System clock                        */
  const uint32_t SystemFrequency_AHBClk  = SYSCLK_FREQ_48MHz;      /*!< AHB System bus speed                */
  const uint32_t SystemFrequency_APB1Clk = (SYSCLK_FREQ_48MHz/2);  /*!< APB Peripheral bus 1 (low)  speed   */
  const uint32_t SystemFrequency_APB2Clk = SYSCLK_FREQ_48MHz;      /*!< APB Peripheral bus 2 (high) speed   */
#elif defined SYSCLK_FREQ_56MHz
  const uint32_t SystemFrequency         = SYSCLK_FREQ_56MHz;      /*!< System Clock Frequency (Core Clock) */
  const uint32_t SystemFrequency_SysClk  = SYSCLK_FREQ_56MHz;      /*!< System clock                        */
  const uint32_t SystemFrequency_AHBClk  = SYSCLK_FREQ_56MHz;      /*!< AHB System bus speed                */
  const uint32_t SystemFrequency_APB1Clk = (SYSCLK_FREQ_56MHz/2);  /*!< APB Peripheral bus 1 (low)  speed   */
  const uint32_t SystemFrequency_APB2Clk = SYSCLK_FREQ_56MHz;      /*!< APB Peripheral bus 2 (high) speed   */  
#elif defined SYSCLK_FREQ_72MHz
  const uint32_t SystemFrequency         = SYSCLK_FREQ_72MHz;      /*!< System Clock Frequency (Core Clock) */
  const uint32_t SystemFrequency_SysClk  = SYSCLK_FREQ_72MHz;      /*!< System clock                        */
  const uint32_t SystemFrequency_AHBClk  = SYSCLK_FREQ_72MHz;      /*!< AHB System bus speed                */
  const uint32_t SystemFrequency_APB1Clk = (SYSCLK_FREQ_72MHz/2);  /*!< APB Peripheral bus 1 (low)  speed   */
  const uint32_t SystemFrequency_APB2Clk = SYSCLK_FREQ_72MHz;      /*!< APB Peripheral bus 2 (high) speed   */
#else /*!< HSI Selected as System Clock source */
  const uint32_t SystemFrequency         = HSI_Value;                /*!< System Clock Frequency (Core Clock) */
  const uint32_t SystemFrequency_SysClk  = HSI_Value;                /*!< System clock                        */
  const uint32_t SystemFrequency_AHBClk  = HSI_Value;                /*!< AHB System bus speed                */
  const uint32_t SystemFrequency_APB1Clk = HSI_Value;                /*!< APB Peripheral bus 1 (low)  speed   */
  const uint32_t SystemFrequency_APB2Clk = HSI_Value;                /*!< APB Peripheral bus 2 (high) speed   */
#endif

/**
  * @}
  */

/** @addtogroup Private_FunctionPrototypes
  * @{
  */

static void SetSysClock(void);

#ifdef SYSCLK_FREQ_HSE
  static void SetSysClockToHSE(void);
#elif defined SYSCLK_FREQ_20MHz
  static void SetSysClockTo20(void);
#elif defined SYSCLK_FREQ_36MHz
  static void SetSysClockTo36(void);
#elif defined SYSCLK_FREQ_48MHz
  static void SetSysClockTo48(void);
#elif defined SYSCLK_FREQ_56MHz
  static void SetSysClockTo56(void);  
#elif defined SYSCLK_FREQ_72MHz
  static void SetSysClockTo72(void);
#endif

/**
  * @}
  */

/** @addtogroup Private_Functions
  * @{
  */

/**
  * @brief Setup the microcontroller system
  *        Initialize the Embedded Flash Interface,  initialize the PLL and update th SystemFrequency variable
  * @param None.
  * @arg None.
  * @note : This function should be used only after reset.
  * @retval value: None.
  */
void SystemInit (void)
{
  /*!< RCC system reset(for debug purpose) */
  /*!< Set HSION bit */
  RCC->CR |= (uint32_t)0x00000001;
  /*!< Reset SW[1:0], HPRE[3:0], PPRE1[2:0], PPRE2[2:0], ADCPRE[1:0] and MCO[2:0] bits */
  RCC->CFGR &= (uint32_t)0xF8FF0000;  
  /*!< Reset HSEON, CSSON and PLLON bits */
  RCC->CR &= (uint32_t)0xFEF6FFFF;
  /*!< Reset HSEBYP bit */
  RCC->CR &= (uint32_t)0xFFFBFFFF;
  /*!< Reset PLLSRC, PLLXTPRE, PLLMUL[3:0] and USBPRE bits */
  RCC->CFGR &= (uint32_t)0xFF80FFFF;
  /*!< Disable all interrupts */
  RCC->CIR = 0x00000000;
    
  /*!< Configure the System clock frequency, HCLK, PCLK2 and PCLK1 prescalers */
  /*!< Configure the Flash Latency cycles and enable prefetch buffer */
  SetSysClock();

}

/**
  * @brief Configures the System clock frequency, HCLK, PCLK2 and PCLK1 
  *        prescalers.
  * @param None.
  * @arg None.
  * @note : None.
  * @retval value: None.
  */
static void SetSysClock(void)
{
#ifdef SYSCLK_FREQ_HSE
  SetSysClockToHSE();
#elif defined SYSCLK_FREQ_20MHz
  SetSysClockTo20();
#elif defined SYSCLK_FREQ_36MHz
  SetSysClockTo36();
#elif defined SYSCLK_FREQ_48MHz
  SetSysClockTo48();
#elif defined SYSCLK_FREQ_56MHz
  SetSysClockTo56();  
#elif defined SYSCLK_FREQ_72MHz
  SetSysClockTo72();
#endif
 
 /*!< If none of the define above is enabled, the HSI is used as System clock
    source (default after reset) */ 
}

/**
  * @brief Setup the external memory controller. Called in startup_stm32f10x.s 
  *        before jump to __main
  * @param None.
  * @arg None.
  * @note : None.
  * @retval value: None.
  */ 
#ifdef DATA_IN_ExtSRAM
/**
  * @brief Setup the external memory controller. 
  *        Called in startup_stm32f10x_xx.s/.c before jump to main.
  * 	   This function configures the external SRAM mounted on STM3210E-EVAL
  *      board (STM32 High density devices). This SRAM will be used as program
  *      data memory (including heap and stack).
  * @param None.
  * @arg None.
  * @note : None.
  * @retval value: None.
  */ 
void SystemInit_ExtMemCtl(void) 
{
/*!< FSMC Bank1 NOR/SRAM3 is used for the STM3210E-EVAL, if another Bank is 
  required, then adjust the Register Addresses */

  /*!< Enable FSMC clock */
  RCC->AHBENR = 0x00000114;
  
  /*!< Enable GPIOD, GPIOE, GPIOF and GPIOG clocks */  
  RCC->APB2ENR = 0x000001E0;
  
/* ---------------  SRAM Data lines, NOE and NWE configuration ---------------*/
/*----------------  SRAM Address lines configuration -------------------------*/
/*----------------  NOE and NWE configuration --------------------------------*/  
/*----------------  NE3 configuration ----------------------------------------*/
/*----------------  NBL0, NBL1 configuration ---------------------------------*/
  
  GPIOD->CRL = 0x44BB44BB;  
  GPIOD->CRH = 0xBBBBBBBB;

  GPIOE->CRL = 0xB44444BB;  
  GPIOE->CRH = 0xBBBBBBBB;

  GPIOF->CRL = 0x44BBBBBB;  
  GPIOF->CRH = 0xBBBB4444;

  GPIOG->CRL = 0x44BBBBBB;  
  GPIOG->CRH = 0x44444B44;
   
/*----------------  FSMC Configuration ---------------------------------------*/  
/*----------------  Enable FSMC Bank1_SRAM Bank ------------------------------*/
  
  FSMC_Bank1->BTCR[4] = 0x00001011;
  FSMC_Bank1->BTCR[5] = 0x00000200;
}
#endif /* DATA_IN_ExtSRAM */

#ifdef SYSCLK_FREQ_HSE
/**
  * @brief Selects HSE as System clock source and configure HCLK, PCLK2
  *        and PCLK1 prescalers.
  * @param None.
  * @arg None.
  * @note : This function should be used only after reset.
  * @retval value: None.
  */
static void SetSysClockToHSE(void)
{
  __IO uint32_t StartUpCounter = 0, HSEStatus = 0;
  
  /*!< SYSCLK, HCLK, PCLK2 and PCLK1 configuration ---------------------------*/    
  /*!< Enable HSE */    
  RCC->CR |= ((uint32_t)RCC_CR_HSEON);
 
  /*!< Wait till HSE is ready and if Time out is reached exit */
  do
  {
    HSEStatus = RCC->CR & RCC_CR_HSERDY;
    StartUpCounter++;  
  } while((HSEStatus == 0) && (StartUpCounter != HSEStartUp_TimeOut));

  if ((RCC->CR & RCC_CR_HSERDY) != RESET)
  {
    HSEStatus = (uint32_t)0x01;
  }
  else
  {
    HSEStatus = (uint32_t)0x00;
  }  

  if (HSEStatus == (uint32_t)0x01)
  {
    /*!< Enable Prefetch Buffer */
    FLASH->ACR |= FLASH_ACR_PRFTBE;

    /*!< Flash 0 wait state */
    FLASH->ACR &= (uint32_t)((uint32_t)~FLASH_ACR_LATENCY);
    FLASH->ACR |= (uint32_t)FLASH_ACR_LATENCY_0;    
 
    /*!< HCLK = SYSCLK */
    RCC->CFGR |= (uint32_t)RCC_CFGR_HPRE_DIV1;
      
    /*!< PCLK2 = HCLK */
    RCC->CFGR |= (uint32_t)RCC_CFGR_PPRE2_DIV1;
    
    /*!< PCLK1 = HCLK */
    RCC->CFGR |= (uint32_t)RCC_CFGR_PPRE1_DIV1;
    
    /*!< Select HSE as system clock source */
    RCC->CFGR &= (uint32_t)((uint32_t)~(RCC_CFGR_SW));
    RCC->CFGR |= (uint32_t)RCC_CFGR_SW_HSE;    

    /*!< Wait till HSE is used as system clock source */
    while ((RCC->CFGR & (uint32_t)RCC_CFGR_SWS) != (uint32_t)0x04)
    {
    }
  }
  else
  { /*!< If HSE fails to start-up, the application will have wrong clock 
         configuration. User can add here some code to deal with this error */    

    /*!< Go to infinite loop */
    while (1)
    {
    }
  }  
}
#elif defined SYSCLK_FREQ_20MHz
/**
  * @brief Sets System clock frequency to 20MHz and configure HCLK, PCLK2 
  *        and PCLK1 prescalers.
  * @param None.
  * @arg None.
  * @note : This function should be used only after reset.
  * @retval value: None.
  */
static void SetSysClockTo20(void)
{
  __IO uint32_t StartUpCounter = 0, HSEStatus = 0;
  
  /*!< SYSCLK, HCLK, PCLK2 and PCLK1 configuration ---------------------------*/    
  /*!< Enable HSE */    
  RCC->CR |= ((uint32_t)RCC_CR_HSEON);
 
  /*!< Wait till HSE is ready and if Time out is reached exit */
  do
  {
    HSEStatus = RCC->CR & RCC_CR_HSERDY;
    StartUpCounter++;  
  } while((HSEStatus == 0) && (StartUpCounter != HSEStartUp_TimeOut));

  if ((RCC->CR & RCC_CR_HSERDY) != RESET)
  {
    HSEStatus = (uint32_t)0x01;
  }
  else
  {
    HSEStatus = (uint32_t)0x00;
  }  

  if (HSEStatus == (uint32_t)0x01)
  {
    /*!< Enable Prefetch Buffer */
    FLASH->ACR |= FLASH_ACR_PRFTBE;

    /*!< Flash 0 wait state */
    FLASH->ACR &= (uint32_t)((uint32_t)~FLASH_ACR_LATENCY);
    FLASH->ACR |= (uint32_t)FLASH_ACR_LATENCY_0;    
 

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩一区二区免费在线观看| 久久欧美一区二区| 日韩一级片在线观看| 亚洲午夜久久久久久久久电影院| 国产欧美综合色| 日本一区二区三区电影| 欧美国产成人在线| 亚洲一区欧美一区| 日韩在线一区二区三区| 首页综合国产亚洲丝袜| 美女视频黄免费的久久 | 欧美一区二区三区四区五区| 精品蜜桃在线看| 亚洲视频图片小说| 奇米影视一区二区三区小说| av在线免费不卡| 日韩精品一区二区在线| 亚洲精品乱码久久久久久久久| 久久99精品国产麻豆婷婷| 91香蕉视频污在线| 精品国产一区二区三区四区四| 亚洲美女免费在线| 国产乱码精品一品二品| 欧美精品一二三区| 国产精品免费视频网站| 久久99久久99小草精品免视看| 色综合一个色综合| 国产亚洲综合性久久久影院| 视频一区中文字幕国产| 97精品久久久午夜一区二区三区| 欧美一区二区大片| 亚洲另类色综合网站| 国产一区二区在线影院| 91麻豆精品国产91久久久久久| 亚洲色图丝袜美腿| 国产999精品久久| 国产伦精品一区二区三区免费迷 | 蜜桃视频一区二区| 91麻豆成人久久精品二区三区| 日韩欧美高清dvd碟片| 一区二区三区四区不卡在线| 国产99久久久久| 精品欧美一区二区三区精品久久| 亚洲国产婷婷综合在线精品| 成人aa视频在线观看| 精品国产乱码久久久久久1区2区| 亚洲gay无套男同| 日本精品一级二级| 国产精品电影一区二区| 国产精品自拍av| 精品va天堂亚洲国产| 免费高清成人在线| 在线成人免费视频| 偷拍一区二区三区四区| 在线精品观看国产| 亚洲卡通欧美制服中文| 91啪九色porn原创视频在线观看| 欧美日韩国产中文| 五月天亚洲婷婷| 日韩二区三区四区| 欧美日韩在线电影| 一区av在线播放| 色婷婷综合久久久中文一区二区| 国产精品久久久久久久久图文区 | 丰满少妇久久久久久久| 精品视频1区2区| 亚洲激情第一区| 一本到一区二区三区| 中文字幕一区二区三| 波多野结衣亚洲| 中文字幕在线视频一区| 粉嫩一区二区三区在线看| 欧美激情中文不卡| 岛国av在线一区| 国产精品无圣光一区二区| 国产suv精品一区二区三区| 国产人妖乱国产精品人妖| 国产乱人伦偷精品视频免下载 | 国产精品1024| 国产区在线观看成人精品| 国产电影一区二区三区| 欧美国产欧美综合| av网站免费线看精品| 中文字幕日韩一区二区| 在线一区二区三区做爰视频网站| 亚洲成人综合网站| 欧美视频在线播放| 日韩成人免费看| 亚洲人成小说网站色在线| 色综合视频在线观看| 亚洲午夜免费福利视频| 7777精品伊人久久久大香线蕉 | 91久久国产综合久久| 亚洲精品一区二区三区福利| 在线一区二区三区四区五区 | 午夜精品免费在线| 国产不卡视频一区| 日韩电影在线一区二区| 欧美一区二区大片| 国产精品一品二品| 国产盗摄精品一区二区三区在线| 亚洲成人免费av| 中文字幕一区二区三区乱码在线 | 亚洲国产日韩一区二区| 久久久国产午夜精品 | 久久久久久夜精品精品免费| 欧美日韩国产电影| 欧美理论电影在线| 欧美日韩在线观看一区二区| 精品三级在线观看| 欧美日韩极品在线观看一区| 91官网在线观看| 成人午夜激情在线| 国产美女主播视频一区| 国产精品夜夜嗨| 国产精品一区在线观看你懂的| 在线观看网站黄不卡| 亚洲靠逼com| 91精品国产综合久久香蕉的特点 | 国产一区久久久| 亚洲免费观看在线观看| 日韩一区二区电影网| av一二三不卡影片| 奇米一区二区三区| 中文字幕色av一区二区三区| 日韩一二三四区| 色综合天天视频在线观看| 91麻豆国产在线观看| 欧美网站一区二区| 精品卡一卡二卡三卡四在线| 中文字幕亚洲一区二区va在线| 亚洲va国产天堂va久久en| 亚洲v精品v日韩v欧美v专区| 韩国av一区二区三区在线观看| 成人激情免费网站| 成人国产精品免费观看| 国产日韩欧美一区二区三区乱码 | 粉嫩aⅴ一区二区三区四区| av一二三不卡影片| 欧美日韩国产123区| 国产欧美日韩激情| 日本一区免费视频| 国产精品超碰97尤物18| 亚洲小说欧美激情另类| 国产综合色精品一区二区三区| 成人av一区二区三区| 久久婷婷色综合| 中文幕一区二区三区久久蜜桃| 国产午夜精品在线观看| 久久久久久久久久久久电影| 精品不卡在线视频| 久久新电视剧免费观看| 最新日韩av在线| 亚洲国产精品久久一线不卡| 久久99精品网久久| 欧美午夜电影网| 亚洲免费在线视频一区 二区| 精品在线亚洲视频| 欧美日本免费一区二区三区| 亚洲色图另类专区| 国产成人免费网站| 中文字幕一区二区三区不卡| 国产一区二区三区日韩| 久久噜噜亚洲综合| 激情五月播播久久久精品| 国产精品99久久久久久有的能看 | 不卡在线观看av| 国产精品一二三四区| 麻豆精品视频在线| 青椒成人免费视频| 免费看日韩a级影片| 图片区小说区国产精品视频| 亚洲一区二区三区在线播放| 亚洲女与黑人做爰| 一区精品在线播放| 亚洲日本护士毛茸茸| 中文字幕在线观看一区| 欧美高清一级片在线观看| 国产视频亚洲色图| 国产欧美日韩三级| 中文字幕成人网| 中文字幕va一区二区三区| 欧美国产欧美综合| 中文字幕电影一区| 1000精品久久久久久久久| 一区视频在线播放| 亚洲乱码国产乱码精品精小说 | 欧美另类高清zo欧美| 4438x亚洲最大成人网| 日韩丝袜美女视频| 欧美成人猛片aaaaaaa| 久久久国产精品不卡| 欧美激情一二三区| 亚洲婷婷综合久久一本伊一区 | 欧美精品视频www在线观看| 欧美日韩国产精品成人| 日韩一区二区三区精品视频| 精品日韩99亚洲| 中文字幕免费不卡| 亚洲精品国产一区二区三区四区在线 |