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

? 歡迎來(lái)到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? rccu.h

?? MCS-51的一個(gè)Free小型操作系統(tǒng),在KeilC中下編譯工作
?? H
字號(hào):
/******************** (C) COPYRIGHT 2003 STMicroelectronics ********************
* File Name          : rccu.h
* Author             : MCD Application Team
* Date First Issued  : 28/07/2003
* Description        : This file contains all the functions prototypes for the
*                      RCCU software library.
********************************************************************************
* History:
*  30/11/2004 : V2.0
*  14/07/2004 : V1.3
*  01/01/2004 : V1.2
*******************************************************************************
 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.
*******************************************************************************/

#ifndef __RCCU_H
#define __RCCU_H

#include "71x_map.h"

typedef enum {
               RCCU_DEFAULT=0x00,
               RCCU_RCLK_2 =0x01,
               RCCU_RCLK_4 =0x02,
               RCCU_RCLK_8 =0x03
             } RCCU_Clock_Div;

typedef enum {
               RCCU_PLL1_Output,
               RCCU_CLOCK2_16,
               RCCU_CLOCK2,
               RCCU_RTC_CLOCK
             } RCCU_RCLK_Clocks;


                     typedef enum {
               RCCU_PLL1_Mul_12=0x01,
               RCCU_PLL1_Mul_16=0x03,
               RCCU_PLL1_Mul_20=0x00,
               RCCU_PLL1_Mul_24=0x02
             } RCCU_PLL1_Mul;

typedef enum {
               RCCU_PLL2_Mul_12=0x01,
               RCCU_PLL2_Mul_16=0x03,
               RCCU_PLL2_Mul_20=0x00,
               RCCU_PLL2_Mul_28=0x02
             } RCCU_PLL2_Mul;

typedef enum {
               RCCU_Div_1=0x00,
               RCCU_Div_2=0x01,
               RCCU_Div_3=0x02,
               RCCU_Div_4=0x03,
               RCCU_Div_5=0x04,
               RCCU_Div_6=0x05,
               RCCU_Div_7=0x06
             } RCCU_PLL_Div;

typedef enum {
               RCCU_PLL2_Output = 0x01,
               RCCU_USBCK       = 0x00
             } RCCU_USB_Clocks;

typedef enum {
               RCCU_CLK2,
               RCCU_RCLK,
               RCCU_MCLK,
               RCCU_PCLK,
               RCCU_FCLK
             } RCCU_Clocks;

typedef enum {
               RCCU_PLL1_LOCK_IT = 0x0080,
               RCCU_CKAF_IT      = 0x0100,
               RCCU_CK2_16_IT    = 0x0200,
               RCCU_STOP_IT      = 0x0400
             } RCCU_Interrupts;

typedef enum {
               RCCU_PLL1_LOCK   = 0x0002,
               RCCU_CKAF_ST     = 0x0004,
               RCCU_PLL1_LOCK_I = 0x0800,
               RCCU_CKAF_I      = 0x1000,
               RCCU_CK2_16_I    = 0x2000,
               RCCU_STOP_I      = 0x4000
             } RCCU_Flags;

typedef enum {
               RCCU_ExternalReset = 0x00000000,
               RCCU_SoftwareReset = 0x00000020,
               RCCU_WDGReset      = 0x00000040,
               RCCU_RTCAlarmReset = 0x00000080,
               RCCU_LVDReset      = 0x00000200,
               RCCU_WKPReset      = 0x00000400
              }RCCU_ResetSources;


#define RCCU_Div2_Mask  0x00008000
#define RCCU_Div2_Index 0x0F
#define RCCU_FACT_Mask  0x0003

#define RCCU_FACT1_Mask  0x0003

#define RCCU_FACT2_Mask  0x0300
#define RCCU_FACT2_Index 0x08

#define RCCU_MX_Mask   0x00000030
#define RCCU_MX_Index  0x04

#define RCCU_DX_Mask   0x00000007

#define RCCU_FREEN_Mask    0x00000080

#define RCCU_CSU_CKSEL_Mask 0x00000001

#define RCCU_CK2_16_Mask    0x00000008

#define RCCU_CKAF_SEL_Mask  0x00000004

#define RCCU_LOCK_Mask     0x00000002

#define RCCU_USBEN_Mask   0x0100
#define RCCU_USBEN_Index  0x08
#define RCCU_ResetSources_Mask 0x000006E0

// RTC Oscillator Frequency value = 32 768 Hz
#define RCCU_RTC_Osc  32768


/*******************************************************************************
* Function Name  : RCCU_Div2Config
* Description    : Enables/Disables the clock division by two
* Input          : NewState : ENABLE or DISABLE
* Return         : None
*******************************************************************************/
inline void RCCU_Div2Config ( FunctionalState NewState )
{
  if (NewState == ENABLE) RCCU->CFR |= RCCU_Div2_Mask;
    else RCCU->CFR &= ~RCCU_Div2_Mask;
}

/*******************************************************************************
* Function Name  : RCCU_Div2Status
* Description    : Gets the Div2 Flag status
* Input          : None
* Input          : FlagStatus
* Return         : None
*******************************************************************************/
inline FlagStatus RCCU_Div2Status ( void )
{
  return (RCCU->CFR & RCCU_Div2_Mask) == 0 ? RESET : SET;
}

/*******************************************************************************
* Function Name  : RCCU_MCLKConfig
* Description    : Selects the division factor for RCLK to obtain the
*                  MCLK clock for the CPU
* Input          : New_Clock : RCCU_DEFAULT, RCCU_RCLK_2, RCCU_RCLK_4, RCCU_RCLK_8
* Return         : None
*******************************************************************************/
inline void RCCU_MCLKConfig ( RCCU_Clock_Div New_Clock )
{
  PCU->MDIVR = ( PCU->MDIVR & ~RCCU_FACT_Mask ) | New_Clock;
}

/*******************************************************************************
* Function Name  : RCCU_FCLKConfig
* Description    : Selects the division factor for RCLK to obtain the
*                  FCLK clock for the APB1 fast peripherals (PCLK1).
* Input          : New_Clock : RCCU_DEFAULT, RCCU_RCLK_2,
*                               RCCU_RCLK_4, RCCU_RCLK_8
* Return         : None
*******************************************************************************/
inline void RCCU_FCLKConfig ( RCCU_Clock_Div New_Clock )
{
  PCU->PDIVR = ( PCU->PDIVR & ~RCCU_FACT1_Mask ) | New_Clock;
}

/*******************************************************************************
* Function Name  : RCCU_PCLKConfig
* Description    : Selects the division factor for RCLK to obtain the
*                  PCLK clock for the APB2 peripherals (PCLK2).
* Input          : New_Clock : RCCU_DEFAULT, RCCU_RCLK_2,
*                              RCCU_RCLK_4, RCCU_RCLK_8
* Return         : None
*******************************************************************************/
inline void RCCU_PCLKConfig ( RCCU_Clock_Div New_Clock )
{
  PCU->PDIVR =(PCU->PDIVR & ~RCCU_FACT2_Mask)|(New_Clock << RCCU_FACT2_Index);
}

/*******************************************************************************
* Function Name  : RCCU_PLL1Config
* Description    : Configures the PLL1 div & mul factors.
* Input          : New_Mul : RCCU_Mul_12, RCCU_Mul_16, RCCU_Mul_20, RCCU_Mul_28
*                : New_Div : RCCU_Div_1, RCCU_Div_2, RCCU_Div_3,
*                            RCCU_Div_4, RCCU_Div_5, RCCU_Div_6, RCCU_Div_7
* Return         : None
*******************************************************************************/
void RCCU_PLL1Config ( RCCU_PLL1_Mul New_Mul, RCCU_PLL_Div New_Div );

/*******************************************************************************
* Function Name  : RCCU_PLL2Config
* Description    : Configures the PLL2 div & mul factors.
* Input          : New_Mul : RCCU_Mul_12, RCCU_Mul_16, RCCU_Mul_20, RCCU_Mul_28
*                : New_Div : RCCU_Div_1, RCCU_Div_2, RCCU_Div_3, RCCU_Div_4,
*                            RCCU_Div_5, RCCU_Div_6, RCCU_Div_7
* Return         : None
*******************************************************************************/
void RCCU_PLL2Config ( RCCU_PLL2_Mul New_Mul, RCCU_PLL_Div New_Div );

/*******************************************************************************
* Function Name  : RCCU_RCLKSourceConfig
* Description    : Selects the RCLK source clock
* Input          : New_Clock : RCCU_PLL1_OutPut, RCCU_CLOCK2_16, RCCU_CLOCK2
* Return         : None
*******************************************************************************/
void RCCU_RCLKSourceConfig ( RCCU_RCLK_Clocks New_Clock );

/*******************************************************************************
* Function Name  : RCCU_RCLKClockSource
* Description    : Returns the current RCLK source clock
* Input          : None
* Return         : RCCU_PLL1_Output, RCCU_CLOCK2_16, RCCU_CLOCK2
*******************************************************************************/
RCCU_RCLK_Clocks RCCU_RCLKClockSource ( void );

/*******************************************************************************
* Function Name  : RCCU_USBCLKConfig
* Description    : Selects the USB source clock
* Input          : New_Clock : RCCU_PLL2_Output, RCCU_USBCK
* Return         : None
*******************************************************************************/
inline void RCCU_USBCLKConfig ( RCCU_USB_Clocks New_Clock )
{
  PCU->PLL2CR = (PCU->PLL2CR & ~RCCU_USBEN_Mask)|(New_Clock << RCCU_USBEN_Index);
}

/*******************************************************************************
* Function Name  : RCCU_USBClockSource
* Description    : Gets the USB source clock
* Input          : None
* Return         : RCCU_USB_Clocks
*******************************************************************************/
RCCU_USB_Clocks RCCU_USBClockSource ( void );

/*******************************************************************************
* Function Name  : RCCU_FrequencyValue
* Description    : Calculates & Returns any internal RCCU clock freuqency
*                  passed in parametres
* Input          : RCCU_Clocks : RCCU_CLK2, RCCU_RCLK, RCCU_MCLK,
*                  RCCU_PCLK, RCCU_FCLK
* Return         : u32
*******************************************************************************/
u32 RCCU_FrequencyValue ( RCCU_Clocks Internal_Clk );

/*******************************************************************************
* Function Name  : RCCU_ITConfig
* Description    : Configures the RCCU interrupts
* Input          : RCCU interrupts : RCCU_CK2_16_IT, RCCU_CKAF_IT,
*                  RCCU_PLL1_LOCK_IT
* Return         : None
*******************************************************************************/
inline void RCCU_ITConfig ( RCCU_Interrupts RCCU_IT, FunctionalState NewState)
{
  if (NewState == ENABLE) RCCU->CCR |= RCCU_IT; else RCCU->CCR &= ~RCCU_IT;
}

/*******************************************************************************
* Function Name  : RCCU_FlagStatus
* Description    : Checks the RCCU clock flag register status
* Input          : RCCU Flags : RCCU_CK2_16, RCCU_CKAF, RCCU_PLL1_LOCK
* Return         : FlagStatus : SET or RESET
*******************************************************************************/
inline FlagStatus RCCU_FlagStatus ( RCCU_Flags RCCU_flag )
{
  return (RCCU->CFR & RCCU_flag) == 0 ? RESET : SET;
}

/*******************************************************************************
* Function Name  : RCCU_FlagClear
* Description    : Clears a specified flag in the RCCU registers
* Input          : RCCU Flags : RCCU_CK2_16, RCCU_CKAF, RCCU_PLL1_LOCK
* Return         : None
*******************************************************************************/
inline void RCCU_FlagClear ( RCCU_Interrupts RCCU_IT )
{
  RCCU->CFR |= RCCU_IT;
}

/*******************************************************************************
* Function Name  : RCCU_ResetSources
* Description    : Return the source of the system reset
* Input          : None
* Return         : The reset source
*******************************************************************************/
inline RCCU_ResetSources RCCU_ResetSource ()
{

  switch(RCCU->CFR & RCCU_ResetSources_Mask)
  {
    case 0x00000020: return RCCU_SoftwareReset;
    case 0x00000040: return RCCU_WDGReset;
    case 0x00000080: return RCCU_RTCAlarmReset;
    case 0x00000200: return RCCU_LVDReset;
    case 0x00000400: return RCCU_WKPReset;
    default : return RCCU_ExternalReset;
  }
}

#endif	// __RCCU_H

/******************* (C) COPYRIGHT 2003 STMicroelectronics *****END OF FILE****/

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
丁香网亚洲国际| 国产成人超碰人人澡人人澡| 久久综合九色欧美综合狠狠 | 国产伦精品一区二区三区免费迷| 久久精品人人做| 欧美日韩中文字幕一区二区| 国产69精品久久777的优势| 亚洲免费观看高清完整| 久久久久久黄色| 日韩视频国产视频| 在线精品国精品国产尤物884a| 国产在线看一区| 五月天一区二区| 亚洲免费在线看| 中文字幕av资源一区| 日韩午夜在线观看视频| 国产精品电影一区二区| 蜜桃一区二区三区在线| 久久夜色精品国产噜噜av| 91麻豆国产自产在线观看| 激情综合网激情| 在线观看区一区二| 午夜精品久久久久久久久久| 国产精品美女久久久久高潮| 欧美成人精精品一区二区频| 欧美性猛片xxxx免费看久爱 | 欧美日韩精品电影| 91日韩一区二区三区| 国产a精品视频| 寂寞少妇一区二区三区| 欧美a一区二区| 日韩电影一二三区| 亚洲电影第三页| 亚洲一线二线三线视频| 亚洲丝袜另类动漫二区| 国产精品久久久久婷婷二区次| 久久综合九色综合欧美亚洲| 精品国产一区二区亚洲人成毛片| 538在线一区二区精品国产| 欧美日韩在线电影| 欧美三级电影网| 欧美三级资源在线| 欧洲生活片亚洲生活在线观看| 色综合天天狠狠| 91在线视频官网| 一本久久精品一区二区| 欧美制服丝袜第一页| 色老头久久综合| 欧美日韩久久久久久| 欧美日韩黄视频| 欧美丰满美乳xxx高潮www| 欧美日韩高清不卡| 欧美一级理论性理论a| 日韩精品中文字幕在线不卡尤物| 日韩免费看的电影| 欧美日韩国产经典色站一区二区三区| 在线观看亚洲专区| 在线成人小视频| 日韩西西人体444www| 久久综合九色综合欧美就去吻| 久久精品一二三| 亚洲日本护士毛茸茸| 亚洲四区在线观看| 天堂蜜桃一区二区三区| 国产综合一区二区| av激情综合网| 在线日韩国产精品| 欧美一二区视频| 久久久天堂av| 亚洲日穴在线视频| 欧美bbbbb| 成人免费观看视频| 欧美自拍丝袜亚洲| 精品裸体舞一区二区三区| 中文字幕欧美日韩一区| 一级精品视频在线观看宜春院 | 亚洲综合久久久久| 视频一区二区三区在线| 九色综合狠狠综合久久| 99久久综合精品| 欧美日韩国产另类一区| 久久九九全国免费| 亚洲国产cao| 国产不卡一区视频| 91精品国产一区二区| 国产精品丝袜久久久久久app| 一区二区高清在线| 国产精品一区在线| 欧美日韩国产高清一区| 国产日韩欧美制服另类| 亚洲成人一二三| 成人美女在线视频| 欧美一区二区三区啪啪| 亚洲欧洲日韩在线| 久草中文综合在线| 欧美系列一区二区| 国产色产综合产在线视频| 亚洲图片一区二区| 成人免费av在线| 精品不卡在线视频| 亚洲一区二区三区美女| 国产91露脸合集magnet| 欧美一区二区三区四区久久| 亚洲女人的天堂| 大白屁股一区二区视频| 日韩精品一区二区三区在线| 亚洲精品国产精品乱码不99| 国产91精品露脸国语对白| 欧美白人最猛性xxxxx69交| 亚洲成人福利片| a级精品国产片在线观看| 欧美成人精品高清在线播放| 亚洲妇熟xx妇色黄| 91在线精品一区二区| 久久五月婷婷丁香社区| 日本欧美久久久久免费播放网| 色诱亚洲精品久久久久久| 国产精品丝袜91| 国产精品一区二区久久精品爱涩 | 91国偷自产一区二区三区成为亚洲经典| 精品捆绑美女sm三区| 亚洲国产精品嫩草影院| 日本韩国精品一区二区在线观看| 亚洲国产精品国自产拍av| 国产精品中文有码| 久久色视频免费观看| 韩国视频一区二区| 精品国产亚洲一区二区三区在线观看| 污片在线观看一区二区| 欧美亚洲综合网| 亚洲精品大片www| 色又黄又爽网站www久久| 国产精品人妖ts系列视频| 国产成人精品www牛牛影视| 久久久国产精华| 国产盗摄一区二区| 久久久.com| 成人爱爱电影网址| 中文字幕一区二区三区精华液 | 首页综合国产亚洲丝袜| 在线观看成人免费视频| 亚洲综合久久久| 欧美日韩一区视频| 日韩av一二三| 欧美成人免费网站| 国产成人精品三级| 成人免费在线观看入口| 91黄色激情网站| 偷窥少妇高潮呻吟av久久免费 | 亚洲欧美一区二区久久| 91日韩一区二区三区| 亚洲在线成人精品| 制服丝袜亚洲色图| 精品一区二区三区影院在线午夜| 精品国产人成亚洲区| 丁香一区二区三区| 一区二区三区在线看| 日韩小视频在线观看专区| 麻豆国产欧美一区二区三区| 精品国产一区二区三区不卡| 国产精品亚洲成人| 国产精品美女久久久久aⅴ | 99久久久久免费精品国产 | 亚洲乱码国产乱码精品精可以看| 一本久道久久综合中文字幕| 香蕉av福利精品导航| 精品日韩在线观看| 91婷婷韩国欧美一区二区| 午夜视频在线观看一区二区| 日韩一卡二卡三卡| av动漫一区二区| 日韩成人免费在线| 亚洲国产精品黑人久久久| 欧美色欧美亚洲另类二区| 国产一区欧美二区| 亚洲精选一二三| 日韩精品自拍偷拍| 91麻豆视频网站| 美女一区二区视频| 亚洲色欲色欲www在线观看| 在线电影一区二区三区| 成人激情校园春色| 日本不卡的三区四区五区| 欧美激情艳妇裸体舞| 欧美精品乱码久久久久久| 国产a级毛片一区| 日本成人中文字幕| 亚洲日穴在线视频| 久久免费国产精品| 欧美少妇一区二区| 成人美女在线观看| 久久电影网电视剧免费观看| 亚洲精品高清在线| 久久精品视频在线免费观看| 欧美性感一区二区三区| 成人永久aaa| 黑人巨大精品欧美一区| 无吗不卡中文字幕| 亚洲人成亚洲人成在线观看图片| www国产成人免费观看视频 深夜成人网|