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

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

?? 91x_scu.c

?? 最新版FreeRTOS, 包擴多種開發平臺的移植
?? C
?? 第 1 頁 / 共 2 頁
字號:
/******************** (C) COPYRIGHT 2006 STMicroelectronics ********************
* File Name          : 91x_scu.c
* Author             : MCD Application Team
* Date First Issued  : 05/18/2006 : Version 1.0
* Description        : This file provides the SCU library software functions
********************************************************************************
* History:
* 05/24/2006 : Version 1.1
* 05/18/2006 : Version 1.0
********************************************************************************
* THE PRESENT SOFTWARE 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 SOFTWARE AND/OR THE USE MADE BY CUSTOMERS OF THE CODING INFORMATION
* CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
*******************************************************************************/

/* Includes ------------------------------------------------------------------*/
#include "91x_scu.h"

/* Include of other module interface headers ---------------------------------*/
/* Local includes ------------------------------------------------------------*/
/* Private typedef -----------------------------------------------------------*/
/* Private define ------------------------------------------------------------*/
#define SCU_PLLEN 0x80000
/* Private macro -------------------------------------------------------------*/
/* Private variables ---------------------------------------------------------*/
/* Private function prototypes -----------------------------------------------*/
/* Interface functions -------------------------------------------------------*/
/* Private functions ---------------------------------------------------------*/

/*******************************************************************************
* Function Name  : SCU_MCLKSourceConfig
* Description    : Configures the MCLK source clock
* Input          : MCLK_Source = SCU_MCLK_OSC, SCU_MCLK_PLL or SCU_MCLK_RTC
* Output         : None
* Return         : ErrorStatus: SUCCESS or ERROR
* Note           : this function returns ERROR if trying to select the PLL as
*                  clock source while the PLL is disabled or not locked.
*******************************************************************************/
ErrorStatus SCU_MCLKSourceConfig(u32 MCLK_Source)
{
  u32 CLKCNTR_Value;

  CLKCNTR_Value = SCU->CLKCNTR;         /*get CLKCNTR register value*/
  CLKCNTR_Value &=~0x3;                 /*clear field MCLKSEL*/
  if (MCLK_Source == SCU_MCLK_PLL)      /*PLL selected as clock source*/
  {
    /*check if PLL enabled & locked*/
    if (!((SCU->PLLCONF&SCU_PLLEN)&&(SCU->SYSSTATUS&SCU_FLAG_LOCK)))
    return ERROR;
  }
  else CLKCNTR_Value |=MCLK_Source;     /*OSC or RTC selected as clock source*/
  SCU->CLKCNTR = CLKCNTR_Value;         /*Update CLKCNTR register value*/
  return SUCCESS;
}

/*******************************************************************************
* Function Name  : SCU_PLLFactorsConfig
* Description    : Sets the PLL factors
* Input          : PLLN, PLLM and PLLP
* Output         : None
* Return         : ErrorStatus: ERROR or SUCCESS
* Notes          : -The PLL factors must respect the PLL specification requirements
*                  -The function returns ERROR if trying to change PLL
*                   factors while PLL is selected as Main Clock source (MCLK)
*                  -This function disables the PLL, to enable the PLL use
*                   function" SCU_PLLCmd(ENABLE)" after setting the PLL factors
******************************************************************************/
ErrorStatus SCU_PLLFactorsConfig(u8 PLLN, u8 PLLM, u8 PLLP)
{
  if (SCU_PLLCmd(DISABLE)==SUCCESS)      /*Disable PLL*/
  {
    SCU->PLLCONF =0;                     /*clear PLLCONF register*/
    SCU->PLLCONF |=(PLLN<<8);            /*update PLLN field*/
    SCU->PLLCONF |=PLLM;                 /*update PLLM field*/
    SCU->PLLCONF |=PLLP<<16;             /*update PLLP field*/
    return SUCCESS;
  }
  return ERROR;
}

/*******************************************************************************
* Function Name  : SCU_PLLCmd
* Description    : Enable or Disable the PLL
* Input          : NewState = ENABLE or DISABLE
* Output         : None
* Return         : ErrorStatus: SUCCESS or ERROR
* Note           : -The function returns ERROR if:
*                   *trying to disable the PLL while it is selected as the MCLK
*                   *trying to enable the PLL while it is already enabled and
*                    locked
*******************************************************************************/
ErrorStatus SCU_PLLCmd(FunctionalState NewState)
{
  vu32 i;
  if (NewState==ENABLE)
  {
    if (!((SCU->PLLCONF&SCU_PLLEN)&&(SCU->SYSSTATUS&SCU_FLAG_LOCK)))
    {
      SCU->SYSSTATUS|=SCU_FLAG_LOCK;               /*clear LOCK bit*/
      SCU->PLLCONF |=SCU_PLLEN;                    /*PLL Enable*/
      while(!SCU->SYSSTATUS&SCU_FLAG_LOCK);        /*Wait PLL to lock*/
      return SUCCESS;
    }
    else return ERROR;
  }
  else /*NewState = DISABLE*/
  {
    if(SCU->CLKCNTR&0x3)                /*check if PLL not sys CLK*/
    {
      for(i=10;i>0;i--);                /*delay before PLL disabling*/
      SCU->PLLCONF &=~SCU_PLLEN;        /*PLL Disable*/
      return SUCCESS;
    }
    else return ERROR;
  }
}

/*******************************************************************************
* Function Name  : SCU_RCLKDivisorConfig
* Description    : Sets the RCLK divisor value
* Input          : RCLK_Divisor
* Output         : None
* Return         : None
*******************************************************************************/
void SCU_RCLKDivisorConfig(u32 RCLK_Divisor)
{
  SCU->CLKCNTR &=SCU_RCLK_Div1;              /*clear RCLKDIV[2:0] field*/
  if (RCLK_Divisor!=SCU_RCLK_Div1)
  SCU->CLKCNTR |= RCLK_Divisor;              /*update field with RCLK divisor*/
}

/*******************************************************************************
* Function Name  : SCU_HCLKDivisorConfig
* Description    : Sets the HCLK divisor value
* Input          : HCLK_Divisor
* Output         : None
* Return         : None
*******************************************************************************/
void SCU_HCLKDivisorConfig(u32 HCLK_Divisor)
{
  SCU->CLKCNTR &=SCU_HCLK_Div1;              /*clear AHBDIV[1:0] field*/
  if (HCLK_Divisor!=SCU_HCLK_Div1)
  SCU->CLKCNTR |= HCLK_Divisor;              /*update field with HCLK divisor*/
}

/*******************************************************************************
* Function Name  : SCU_PCLKDivisorConfig
* Description    : Sets the PCLK divisor value
* Input          : PCLK_Divisor
* Output         : None
* Return         : None
*******************************************************************************/
void SCU_PCLKDivisorConfig(u32 PCLK_Divisor)
{
  SCU->CLKCNTR &=SCU_PCLK_Div1;              /*clear APBDIV[1:0] field*/
  if (PCLK_Divisor!=SCU_PCLK_Div1)
  SCU->CLKCNTR |= PCLK_Divisor;              /*update field with PCLK Divisor*/
}

/*******************************************************************************
* Function Name  : SCU_APBPeriphClockConfig
* Description    : Enable the clock for an APB peripheral
* Input          : -APBPerip : APB peripherals(__RTC, __ADC ,...)
*                  -NewState : ENABLE or DISABLE
* Output         : None
* Return         : None
*******************************************************************************/
void SCU_APBPeriphClockConfig(u32 APBPeriph, FunctionalState NewState)
{
  if (NewState==ENABLE)                     /*Enable clock for APB peripheral*/
  SCU->PCGR1 |=APBPeriph;
  else
  SCU->PCGR1 &=~APBPeriph;                  /*Disable clock for APB peripheral*/
}

/*******************************************************************************
* Function Name  : SCU_AHBPeriphClockConfig
* Description    : Enable the clock for an AHB peripheral
* Input          : -AHBPerip: AHB peripherals(__USB, __DMA,...)
*                  -NewState : ENABLE or DISABLE
* Output         : None
* Return         : None
*******************************************************************************/
void SCU_AHBPeriphClockConfig(u32 AHBPeriph, FunctionalState NewState)
{
  if (NewState==ENABLE)                     /*Enable clock for AHB peripheral*/
  SCU->PCGRO |=AHBPeriph;
  else
  SCU->PCGRO &=~AHBPeriph;                  /*Disable clock for AHB peripheral*/
}

/*******************************************************************************
* Function Name  : SCU_APBPeriphReset
* Description    : Assert or deassert Reset on APB peripheral
* Input          : -APBPeriph: APB peripherals(__RTC, __ADC,...)
                   -NewState : ENABLE or DISABLE
* Output         : None
* Return         : None
*******************************************************************************/
void SCU_APBPeriphReset(u32 APBPeriph, FunctionalState NewState)
{
  if (NewState==DISABLE)                    /*APB peripheral not held in Reset*/
  SCU->PRR1 |=APBPeriph;
  else
  SCU->PRR1 &=~APBPeriph;                   /*APB peripheral held in Reset*/
}

/*******************************************************************************
* Function Name  : SCU_AHBPeriphReset
* Description    : Assert or deassert Reset on AHB peripheral
* Input          : -AHBPeriph: AHB peripherals(__USB, __DMA,...)
                   -NewState : ENABLE or DISABLE
* Output         : None
* Return         : None
*******************************************************************************/
void SCU_AHBPeriphReset(u32 AHBPeriph, FunctionalState NewState)
{
  if (NewState==DISABLE)
  SCU->PRR0 |=AHBPeriph;                    /*AHB peripheral not held in Reset*/
  else
  SCU->PRR0 &=~AHBPeriph;                   /*AHB peripheral held in Reset*/
}

/*******************************************************************************
* Function Name  : SCU_APBPeriphIdleConfig
* Description    : Enable or Disable Periph Clock during Idle mode
* Input          : -APBPeriph: APB peripherals(__RTC, __ADC,...)
                   -NewState : ENABLE or DISABLE
* Output         : None
* Return         : None
*******************************************************************************/
void SCU_APBPeriphIdleConfig(u32 APBPeriph, FunctionalState NewState)
{
  if (NewState==ENABLE)
  SCU->MGR1 |=APBPeriph;      /*APB peripheral clock enabled during Idle mode*/
  else
  SCU->MGR1 &=~APBPeriph;     /*APB peripheral clock disabled during Idle mode*/
}

/*******************************************************************************
* Function Name  : SCU_AHBPeriphIdleConfig
* Description    : Enable or Disable Periph Clock during Idle mode
* Input          : -AHBPeriph: AHB peripherals(__USB, __DMA,...)
                   -NewState : ENABLE or DISABLE
* Output         : None
* Return         : None
*******************************************************************************/
void SCU_AHBPeriphIdleConfig(u32 AHBPeriph, FunctionalState NewState)
{
  if (NewState==ENABLE)
  SCU->MGR0 |=AHBPeriph;      /*AHB peripheral clock enabled during Idle mode*/
  else
  SCU->MGR0 &=~AHBPeriph;     /*AHB peripheral clock disabled during Idle mode*/
}

/*******************************************************************************
* Function Name  : SCU_APBPeriphDebugConfig
* Description    : Enable or Disable Periph Clock during ARM debug state
* Input          : -APBPeriph: APB peripherals(__RTC, __ADC,...)
                   -NewState : ENABLE or DISABLE
* Output         : None
* Return         : None
*******************************************************************************/
void SCU_APBPeriphDebugConfig(u32 APBPeriph, FunctionalState NewState)
{
  if (NewState==ENABLE)
  SCU->PECGR1 |=APBPeriph;    /*APB peripheral clock enabled during ARM debug state*/
  else
  SCU->PECGR1 &=~APBPeriph;   /*APB peripheral clock disabled during ARM debug state*/
}

/*******************************************************************************
* Function Name  : SCU_AHBPeriphDebugConfig
* Description    : Enable or Disable Periph Clock during ARM debug state
* Input          : -AHBPeriph: AHB peripherals(__USB, __DMA,...)
                   -NewState : ENABLE or DISABLE
* Output         : None
* Return         : None
*******************************************************************************/
void SCU_AHBPeriphDebugConfig(u32 AHBPeriph, FunctionalState NewState)
{
  if (NewState==ENABLE)
  SCU->PECGR0 |=AHBPeriph;    /*AHB peripheral clock enabled during ARM debug state*/
  else
  SCU->PECGR0 &=~AHBPeriph;   /*AHB peripheral clock disabled during ARM debug state*/
}
/*******************************************************************************
* Function Name  : SCU_BRCLKDivisorConfig
* Description    : Sets the BRCLK divisor value
* Input          : BRCLK_Divisor
* Output         : None
* Return         : None
*******************************************************************************/
void SCU_BRCLKDivisorConfig(u32 BRCLK_Divisor)
{
  SCU->CLKCNTR &=SCU_BRCLK_Div1;              /*Clear BRSEL bit*/
  if (BRCLK_Divisor!=SCU_BRCLK_Div1)
  SCU->CLKCNTR |= SCU_BRCLK_Div2;             /*set bit BRSEL*/
}

/*******************************************************************************
* Function Name  : SCU_TIMCLKSourceConfig
* Description    : Sets the TIMx clock source
* Input          : - TIMx : SCU_TIM01 or SCU_TIM23
*                  - TIMCLK_Source = SCU_TIMCLK_EXT or SCU_TIMCLK_INT
* Output         : None
* Return         : None
*******************************************************************************/
void SCU_TIMCLKSourceConfig(u8 TIMx, u32 TIMCLK_Source)
{
  if (TIMx== SCU_TIM01)                     /*TIM01 clock source configuration*/
  {
    SCU->CLKCNTR &=0xFFFFDFFF;
    if (TIMCLK_Source == SCU_TIMCLK_EXT)
    SCU->CLKCNTR |=0x2000;
  }
  else
  {
    SCU->CLKCNTR &=0xFFFFBFFF;            /*TIM23 clock source configuration*/
    if (TIMCLK_Source == SCU_TIMCLK_EXT)
    SCU->CLKCNTR |=0x4000;
  }
}

/*******************************************************************************
* Function Name  : SCU_TIMPresConfig
* Description    : Sets the TIMx Prescaler Value
* Input          : - TIMx : SCU_TIM01 or SCU_TIM23

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品一区不卡| 亚洲乱码国产乱码精品精可以看| 国产高清视频一区| 久久99精品久久久久婷婷| 午夜精品免费在线| 三级精品在线观看| 日韩二区三区四区| 蜜臀av一区二区在线免费观看| 日韩福利视频网| 国产精品一区二区在线看| 国产成人日日夜夜| 99免费精品视频| 日本高清免费不卡视频| 欧美日韩视频在线观看一区二区三区| 欧美日韩久久不卡| 精品国精品自拍自在线| 国产丝袜欧美中文另类| 亚洲日本青草视频在线怡红院 | 91猫先生在线| 欧美亚洲国产一区二区三区| 在线不卡a资源高清| 久久综合成人精品亚洲另类欧美 | 成人精品鲁一区一区二区| www.欧美.com| 欧美午夜寂寞影院| 精品区一区二区| 《视频一区视频二区| 天堂在线亚洲视频| 国产老妇另类xxxxx| 欧美亚洲国产一区二区三区va| 日韩精品专区在线影院观看| 国产精品人人做人人爽人人添| 亚洲第一福利一区| 国产成人精品亚洲777人妖| 91黄色免费网站| 久久亚区不卡日本| 亚洲成av人在线观看| 国产激情视频一区二区在线观看| 色天使色偷偷av一区二区| 日韩美女天天操| 亚洲午夜在线观看视频在线| 国产精品亚洲一区二区三区妖精| 精品视频123区在线观看| 久久精品视频免费| 五月天中文字幕一区二区| 成人午夜免费视频| 精品国产制服丝袜高跟| 亚洲一区二区三区自拍| 成人一级片网址| 26uuu国产日韩综合| 丝袜美腿高跟呻吟高潮一区| 91丨九色丨蝌蚪富婆spa| 久久久99精品久久| 蜜臀av国产精品久久久久 | 久久久不卡网国产精品一区| 亚洲第一狼人社区| 色综合久久综合网欧美综合网| 久久你懂得1024| 经典三级一区二区| 日韩三级在线观看| 日本色综合中文字幕| 欧美视频在线观看一区| 国产精品国产三级国产a| 国产一区二区三区免费看| 日韩欧美一区在线观看| 日韩专区一卡二卡| 欧美精品一卡二卡| 午夜视频一区在线观看| 欧美性色黄大片| 亚洲永久免费视频| 在线欧美小视频| 亚洲五码中文字幕| 欧美视频中文字幕| 视频一区二区三区入口| 欧美一区二区网站| 免费成人在线视频观看| 日韩欧美成人激情| 久久精品99国产精品| 精品国产三级电影在线观看| 精品影视av免费| 久久久激情视频| 92国产精品观看| 亚洲香肠在线观看| 欧美少妇性性性| 蜜臀av性久久久久蜜臀av麻豆| 亚洲精品一区二区三区香蕉| 国产一区二区三区免费看| 亚洲国产精品二十页| 91网址在线看| 天堂va蜜桃一区二区三区| 日韩一级高清毛片| 国产成人av电影在线| 成人免费小视频| 欧美日韩一本到| 精品一区二区免费| 国产精品丝袜黑色高跟| 91麻豆123| 麻豆91精品视频| 中文字幕中文在线不卡住| 在线观看中文字幕不卡| 蜜臀va亚洲va欧美va天堂| 国产精品美女久久久久高潮| 色欧美日韩亚洲| 老汉av免费一区二区三区| 国产精品伦一区二区三级视频| 色婷婷av一区二区| 国产一区二区女| 一区二区不卡在线视频 午夜欧美不卡在| 精品视频在线免费看| 成人网男人的天堂| 日本一不卡视频| 国产精品婷婷午夜在线观看| 欧美精品一二三| 99精品视频一区二区| 久久国产麻豆精品| 亚洲伊人色欲综合网| 国产日本欧美一区二区| 欧美视频在线一区二区三区| 国产成人免费视| 美女一区二区在线观看| 亚洲人精品午夜| 国产欧美一区二区精品忘忧草| 欧美美女网站色| 色婷婷久久久亚洲一区二区三区 | 亚洲韩国精品一区| 国产偷国产偷亚洲高清人白洁| 欧美军同video69gay| 99精品一区二区| 国产九九视频一区二区三区| 日韩二区三区四区| 亚洲电影欧美电影有声小说| 国产精品伦理在线| 久久精品夜夜夜夜久久| 91麻豆精品国产91久久久久| 97久久精品人人做人人爽50路| 国产盗摄精品一区二区三区在线| 美洲天堂一区二卡三卡四卡视频| 性欧美疯狂xxxxbbbb| 一区二区激情小说| 亚洲美女区一区| 日韩伦理免费电影| 国产精品久久午夜| 国产女同性恋一区二区| 久久久久久久性| 久久综合色综合88| 久久九九久久九九| 国产午夜亚洲精品理论片色戒 | 国产一区91精品张津瑜| 麻豆中文一区二区| 美女www一区二区| 蜜桃精品在线观看| 激情综合网av| 国产福利精品一区二区| 国产一区二区三区四区五区入口| 韩国一区二区三区| 国产一本一道久久香蕉| 国产福利电影一区二区三区| 成人动漫一区二区三区| 91麻豆福利精品推荐| 色哦色哦哦色天天综合| 欧美性xxxxx极品少妇| 欧美疯狂性受xxxxx喷水图片| 91精品国产综合久久精品麻豆| 欧美一级理论片| 欧美电视剧在线看免费| 国产校园另类小说区| 亚洲欧美日韩国产综合在线| 亚洲国产视频一区| 男女男精品网站| 国产成人免费在线| 色天天综合久久久久综合片| 欧美肥妇毛茸茸| 26uuu久久综合| 伊人一区二区三区| 蜜臀av性久久久久蜜臀aⅴ流畅 | av在线不卡网| 欧美性色欧美a在线播放| 日韩一区二区在线免费观看| 国产性天天综合网| 亚洲精品一二三区| 麻豆91免费看| 91亚洲精品一区二区乱码| 91 com成人网| 中文天堂在线一区| 视频一区欧美精品| 国产成人久久精品77777最新版本| 一本大道久久a久久精品综合| 欧美一区二区在线观看| 亚洲欧洲日韩女同| 日本三级韩国三级欧美三级| 99国产精品99久久久久久| 欧美一区二区啪啪| 亚洲欧美怡红院| 国模套图日韩精品一区二区| 欧美在线短视频| 国产欧美精品在线观看| 日本午夜精品视频在线观看| 91在线观看下载| 久久综合狠狠综合| 日本怡春院一区二区|