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

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

?? core_cmfunc.h

?? LPC1788的USBHOST的FATFS移植
?? H
?? 第 1 頁 / 共 2 頁
字號:
/**************************************************************************//**
 * @file     core_cmFunc.h
 * @brief    CMSIS Cortex-M Core Function Access Header File
 * @version  V2.01
 * @date     06. December 2010
 *
 * @note
 * Copyright (C) 2009-2010 ARM Limited. All rights reserved.
 *
 * @par
 * ARM Limited (ARM) is supplying this software for use with Cortex-M
 * processor based microcontrollers.  This file can be freely distributed
 * within development tools that are supporting such ARM based processors.
 *
 * @par
 * THIS SOFTWARE IS PROVIDED "AS IS".  NO WARRANTIES, WHETHER EXPRESS, IMPLIED
 * OR STATUTORY, INCLUDING, BUT NOT LIMITED TO, IMPLIED WARRANTIES OF
 * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE APPLY TO THIS SOFTWARE.
 * ARM SHALL NOT, IN ANY CIRCUMSTANCES, BE LIABLE FOR SPECIAL, INCIDENTAL, OR
 * CONSEQUENTIAL DAMAGES, FOR ANY REASON WHATSOEVER.
 *
 ******************************************************************************/

#ifndef __CORE_CMFUNC_H__
#define __CORE_CMFUNC_H__

/* ###########################  Core Function Access  ########################### */
/** \ingroup  CMSIS_Core_FunctionInterface
    \defgroup CMSIS_Core_RegAccFunctions CMSIS Core Register Access Functions
  @{
 */

#if defined ( __CC_ARM   ) /*------------------ RealView Compiler ----------------*/
/* ARM armcc specific functions */

/* intrinsic void __enable_irq();     */
/* intrinsic void __disable_irq();    */

/** \brief  Get Control Register

    This function returns the content of the Control Register.

    \return               Control Register value
 */
#if       (__ARMCC_VERSION <  400000)
extern          uint32_t __get_CONTROL(void);
#else  /* (__ARMCC_VERSION >= 400000) */
static __INLINE uint32_t __get_CONTROL(void)
{
  register uint32_t __regControl         __ASM("control");
  return(__regControl);
}
#endif /*  __ARMCC_VERSION  */


/** \brief  Set Control Register

    This function writes the given value to the Control Register.

    \param [in]    control  Control Register value to set
 */
#if       (__ARMCC_VERSION <  400000)
extern          void __set_CONTROL(uint32_t control);
#else  /* (__ARMCC_VERSION >= 400000) */
static __INLINE void __set_CONTROL(uint32_t control)
{
  register uint32_t __regControl         __ASM("control");
  __regControl = control;
}
#endif /*  __ARMCC_VERSION  */


/** \brief  Get ISPR Register

    This function returns the content of the ISPR Register.

    \return               ISPR Register value
 */
#if       (__ARMCC_VERSION <  400000)
extern          uint32_t __get_IPSR(void);
#else  /* (__ARMCC_VERSION >= 400000) */
static __INLINE uint32_t __get_IPSR(void)
{
  register uint32_t __regIPSR          __ASM("ipsr");
  return(__regIPSR);
}
#endif /*  __ARMCC_VERSION  */


/** \brief  Get APSR Register

    This function returns the content of the APSR Register.

    \return               APSR Register value
 */
#if       (__ARMCC_VERSION <  400000)
extern          uint32_t __get_APSR(void);
#else  /* (__ARMCC_VERSION >= 400000) */
static __INLINE uint32_t __get_APSR(void)
{
  register uint32_t __regAPSR          __ASM("apsr");
  return(__regAPSR);
}
#endif /*  __ARMCC_VERSION  */


/** \brief  Get xPSR Register

    This function returns the content of the xPSR Register.

    \return               xPSR Register value
 */
#if       (__ARMCC_VERSION <  400000)
extern          uint32_t __get_xPSR(void);
#else  /* (__ARMCC_VERSION >= 400000) */
static __INLINE uint32_t __get_xPSR(void)
{
  register uint32_t __regXPSR          __ASM("xpsr");
  return(__regXPSR);
}
#endif /*  __ARMCC_VERSION  */


/** \brief  Get Process Stack Pointer

    This function returns the current value of the Process Stack Pointer (PSP).

    \return               PSP Register value
 */
#if       (__ARMCC_VERSION <  400000)
extern          uint32_t __get_PSP(void);
#else  /* (__ARMCC_VERSION >= 400000) */
static __INLINE uint32_t __get_PSP(void)
{
  register uint32_t __regProcessStackPointer  __ASM("psp");
  return(__regProcessStackPointer);
}
#endif /*  __ARMCC_VERSION  */


/** \brief  Set Process Stack Pointer

    This function assigns the given value to the Process Stack Pointer (PSP).

    \param [in]    topOfProcStack  Process Stack Pointer value to set
 */
#if       (__ARMCC_VERSION <  400000)
extern          void __set_PSP(uint32_t topOfProcStack);
#else  /* (__ARMCC_VERSION >= 400000) */
static __INLINE void __set_PSP(uint32_t topOfProcStack)
{
  register uint32_t __regProcessStackPointer  __ASM("psp");
  __regProcessStackPointer = topOfProcStack;
}
#endif /*  __ARMCC_VERSION  */


/** \brief  Get Main Stack Pointer

    This function returns the current value of the Main Stack Pointer (MSP).

    \return               MSP Register value
 */
#if       (__ARMCC_VERSION <  400000)
extern          uint32_t __get_MSP(void);
#else  /* (__ARMCC_VERSION >= 400000) */
static __INLINE uint32_t __get_MSP(void)
{
  register uint32_t __regMainStackPointer     __ASM("msp");
  return(__regMainStackPointer);
}
#endif /*  __ARMCC_VERSION  */


/** \brief  Set Main Stack Pointer

    This function assigns the given value to the Main Stack Pointer (MSP).

    \param [in]    topOfMainStack  Main Stack Pointer value to set
 */
#if       (__ARMCC_VERSION <  400000)
extern          void __set_MSP(uint32_t topOfMainStack);
#else  /* (__ARMCC_VERSION >= 400000) */
static __INLINE void __set_MSP(uint32_t topOfMainStack)
{
  register uint32_t __regMainStackPointer     __ASM("msp");
  __regMainStackPointer = topOfMainStack;
}
#endif /*  __ARMCC_VERSION  */


/** \brief  Get Priority Mask

    This function returns the current state of the priority mask bit from the Priority Mask Register.

    \return               Priority Mask value
 */
#if       (__ARMCC_VERSION <  400000)
extern          uint32_t __get_PRIMASK(void);
#else  /* (__ARMCC_VERSION >= 400000) */
static __INLINE uint32_t __get_PRIMASK(void)
{
  register uint32_t __regPriMask         __ASM("primask");
  return(__regPriMask);
}
#endif /*  __ARMCC_VERSION  */


/** \brief  Set Priority Mask

    This function assigns the given value to the Priority Mask Register.

    \param [in]    priMask  Priority Mask
 */
#if       (__ARMCC_VERSION <  400000)
extern          void __set_PRIMASK(uint32_t priMask);
#else  /* (__ARMCC_VERSION >= 400000) */
static __INLINE void __set_PRIMASK(uint32_t priMask)
{
  register uint32_t __regPriMask         __ASM("primask");
  __regPriMask = (priMask);
}
#endif /*  __ARMCC_VERSION  */


#if       (__CORTEX_M >= 0x03)

/** \brief  Enable FIQ

    This function enables FIQ interrupts by clearing the F-bit in the CPSR.
    Can only be executed in Privileged modes.
 */
#define __enable_fault_irq                __enable_fiq


/** \brief  Disable FIQ

    This function disables FIQ interrupts by setting the F-bit in the CPSR.
    Can only be executed in Privileged modes.
 */
#define __disable_fault_irq               __disable_fiq


/** \brief  Get Base Priority

    This function returns the current value of the Base Priority register.

    \return               Base Priority register value
 */
#if       (__ARMCC_VERSION <  400000)
extern          uint32_t __get_BASEPRI(void);
#else  /* (__ARMCC_VERSION >= 400000) */
static __INLINE uint32_t  __get_BASEPRI(void)
{
  register uint32_t __regBasePri         __ASM("basepri");
  return(__regBasePri);
}
#endif /*  __ARMCC_VERSION  */


/** \brief  Set Base Priority

    This function assigns the given value to the Base Priority register.

    \param [in]    basePri  Base Priority value to set
 */
#if       (__ARMCC_VERSION <  400000)
extern          void __set_BASEPRI(uint32_t basePri);
#else  /* (__ARMCC_VERSION >= 400000) */
static __INLINE void __set_BASEPRI(uint32_t basePri)
{
  register uint32_t __regBasePri         __ASM("basepri");
  __regBasePri = (basePri & 0xff);
}
#endif /*  __ARMCC_VERSION  */


/** \brief  Get Fault Mask

    This function returns the current value of the Fault Mask register.

    \return               Fault Mask register value
 */
#if       (__ARMCC_VERSION <  400000)
extern          uint32_t __get_FAULTMASK(void);
#else  /* (__ARMCC_VERSION >= 400000) */
static __INLINE uint32_t __get_FAULTMASK(void)
{
  register uint32_t __regFaultMask       __ASM("faultmask");
  return(__regFaultMask);
}
#endif /*  __ARMCC_VERSION  */


/** \brief  Set Fault Mask

    This function assigns the given value to the Fault Mask register.

    \param [in]    faultMask  Fault Mask value to set
 */
#if       (__ARMCC_VERSION <  400000)
extern          void __set_FAULTMASK(uint32_t faultMask);
#else  /* (__ARMCC_VERSION >= 400000) */
static __INLINE void __set_FAULTMASK(uint32_t faultMask)
{
  register uint32_t __regFaultMask       __ASM("faultmask");
  __regFaultMask = (faultMask & 1);
}
#endif /*  __ARMCC_VERSION  */

#endif /* (__CORTEX_M >= 0x03) */


#if       (__CORTEX_M == 0x04)

/** \brief  Get FPSCR

    This function returns the current value of the Floating Point Status/Control register.

    \return               Floating Point Status/Control register value
 */
static __INLINE uint32_t __get_FPSCR(void)
{
#if (__FPU_PRESENT == 1)
  register uint32_t __regfpscr         __ASM("fpscr");
  return(__regfpscr);
#else
   return(0);
#endif
}


/** \brief  Set FPSCR

    This function assigns the given value to the Floating Point Status/Control register.

    \param [in]    fpscr  Floating Point Status/Control value to set
 */
static __INLINE void __set_FPSCR(uint32_t fpscr)
{
#if (__FPU_PRESENT == 1)
  register uint32_t __regfpscr         __ASM("fpscr");
  __regfpscr = (fpscr);
#endif
}

#endif /* (__CORTEX_M == 0x04) */


 #elif (defined (__ICCARM__)) /*---------------- ICC Compiler ---------------------*/
/* IAR iccarm specific functions */

#if defined (__ICCARM__)
  #include <intrinsics.h>                     /* IAR Intrinsics   */
#endif

#pragma diag_suppress=Pe940

/** \brief  Enable IRQ Interrupts

  This function enables IRQ interrupts by clearing the I-bit in the CPSR.
  Can only be executed in Privileged modes.
 */
#define __enable_irq                              __enable_interrupt


/** \brief  Disable IRQ Interrupts

  This function disables IRQ interrupts by setting the I-bit in the CPSR.
  Can only be executed in Privileged modes.
 */
#define __disable_irq                             __disable_interrupt


/* intrinsic unsigned long __get_CONTROL( void ); (see intrinsic.h) */
/* intrinsic void __set_CONTROL( unsigned long ); (see intrinsic.h) */


#if (__VER__) < 6020000
/** \brief  Get ISPR Register

    This function returns the content of the ISPR Register.

    \return               ISPR Register value
 */
static uint32_t __get_IPSR(void)
{
  __ASM("mrs r0, ipsr");
}
#endif

#if (__VER__) < 6020000
/** \brief  Get APSR Register

    This function returns the content of the APSR Register.

    \return               APSR Register value
 */
static uint32_t __get_APSR(void)
{
  __ASM("mrs r0, apsr");
}
#endif

/** \brief  Get xPSR Register

    This function returns the content of the xPSR Register.

    \return               xPSR Register value
 */
static uint32_t __get_xPSR(void)
{
  __ASM("mrs r0, psr");           // assembler does not know "xpsr"
}


#if (__VER__) < 6020000
/** \brief  Get Process Stack Pointer

    This function returns the current value of the Process Stack Pointer (PSP).

    \return               PSP Register value
 */
static uint32_t __get_PSP(void)
{
  __ASM("mrs r0, psp");
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲国产精品成人久久综合一区| 亚洲福利视频一区| 亚洲日本va午夜在线影院| 亚洲国产视频一区二区| 国产精品69久久久久水密桃| www..com久久爱| 久久久久97国产精华液好用吗| 亚洲一区在线视频| 国产成人免费高清| 91精品国产福利在线观看 | 国产一区二区不卡在线 | 婷婷久久综合九色国产成人| 精品无人区卡一卡二卡三乱码免费卡| 91在线视频官网| 久久久电影一区二区三区| 奇米色一区二区三区四区| 99re在线精品| 欧美激情一区二区在线| 国内精品久久久久影院色| 日韩久久免费av| 五月天国产精品| 91极品美女在线| 亚洲精品你懂的| 色综合久久综合网欧美综合网| 国产欧美精品一区二区三区四区| 精品制服美女丁香| 亚洲精品一区二区精华| 午夜伊人狠狠久久| 制服丝袜中文字幕一区| 爽好久久久欧美精品| 欧美日本一道本| 午夜视频在线观看一区二区三区| 在线观看网站黄不卡| 玉足女爽爽91| 欧美日韩黄色一区二区| 日本视频一区二区| 日韩一区二区三区四区五区六区| 日本麻豆一区二区三区视频| 欧美一级夜夜爽| 久久99国产精品麻豆| 精品国产123| 国产精品中文欧美| 国产婷婷精品av在线| 成人涩涩免费视频| 成人免费小视频| 欧美在线看片a免费观看| 一区二区三区蜜桃| 欧美二区三区的天堂| 久久精品国产亚洲5555| 国产偷国产偷精品高清尤物 | 色偷偷一区二区三区| 亚洲女厕所小便bbb| 在线精品观看国产| 免费人成网站在线观看欧美高清| 精品久久久久久久久久久久久久久| 久久国产生活片100| 欧美国产日韩精品免费观看| 91国偷自产一区二区使用方法| 五月天亚洲精品| 26uuu亚洲综合色| 色狠狠综合天天综合综合| 日韩福利视频网| 国产精品妹子av| 在线播放中文一区| 国产精品一级二级三级| 亚洲精品久久7777| 日韩欧美成人一区二区| 91在线国内视频| 激情五月播播久久久精品| 亚洲欧美另类小说| 日韩欧美一区二区久久婷婷| www.欧美亚洲| 国内精品久久久久影院薰衣草| 亚洲精品一二三| 欧美mv日韩mv国产网站app| 色综合久久综合网欧美综合网| 蜜臀a∨国产成人精品| 一区在线观看视频| 日韩欧美中文字幕制服| 91香蕉国产在线观看软件| 麻豆精品视频在线观看视频| 国产精品久久久99| 精品国产乱子伦一区| 色婷婷综合久久久中文一区二区| 久久狠狠亚洲综合| 五月综合激情婷婷六月色窝| 日本一区二区三区视频视频| 欧美电影在哪看比较好| 成人aa视频在线观看| 九一久久久久久| 日韩经典中文字幕一区| 亚洲欧美日韩国产成人精品影院 | 亚洲三级电影网站| 26uuu国产电影一区二区| 在线一区二区视频| 成人高清免费观看| 国产一区二区三区在线观看免费 | 成人欧美一区二区三区白人| 2024国产精品| 欧美xxxxx牲另类人与| 欧美日本一区二区三区| 一本大道久久a久久精二百| eeuss鲁片一区二区三区| 韩国精品主播一区二区在线观看 | 懂色av中文一区二区三区| 日本成人中文字幕| 亚洲第一狼人社区| 一区二区在线观看av| 最近日韩中文字幕| 1区2区3区精品视频| 中文欧美字幕免费| 国产欧美精品一区二区色综合| 久久久久88色偷偷免费| 欧美国产精品v| 国产日产亚洲精品系列| 日本一区二区成人| 国产精品久久精品日日| 亚洲色欲色欲www| 亚洲另类在线视频| 亚洲va国产天堂va久久en| 亚洲成a人v欧美综合天堂下载| 五月天激情综合网| 韩日av一区二区| 成人av在线看| 在线一区二区三区做爰视频网站| 欧美网站一区二区| 欧美福利视频导航| 欧美成人官网二区| 国产欧美日韩不卡| 一区二区三区在线免费观看| 香港成人在线视频| 久久www免费人成看片高清| 国产福利精品一区| 色综合天天综合网天天狠天天| 欧美在线一二三四区| 欧美一二三四在线| 国产精品无遮挡| 亚洲一区自拍偷拍| 久久99久久久久久久久久久| 国产999精品久久久久久绿帽| 99国产精品久久久久久久久久久 | 欧美在线999| 日韩欧美一级片| 久久九九99视频| 亚洲男同1069视频| 日韩av在线播放中文字幕| 国产激情视频一区二区三区欧美| 91黄色激情网站| 久久日韩粉嫩一区二区三区| 亚洲人吸女人奶水| 久久精品国产一区二区| 91在线精品一区二区| 精品日韩欧美在线| 免费观看久久久4p| 不卡的看片网站| 91精品国产综合久久久久| 国产精品久久久久久久久动漫| 亚洲成a天堂v人片| 成人黄动漫网站免费app| 欧美日韩不卡视频| 综合色天天鬼久久鬼色| 黄色成人免费在线| 欧美三级日本三级少妇99| 国产婷婷精品av在线| 无码av中文一区二区三区桃花岛| 丁香天五香天堂综合| 91.成人天堂一区| 综合久久久久综合| 成人性生交大片免费看中文| 3d动漫精品啪啪一区二区竹菊| 中文字幕一区二区三| 韩国理伦片一区二区三区在线播放| 欧美色图12p| 亚洲欧美激情小说另类| 国产91富婆露脸刺激对白| 欧美sm美女调教| 麻豆91精品视频| 欧美日韩黄视频| 亚洲一区二区欧美日韩| 99这里只有精品| 中文字幕在线不卡一区 | 日本精品视频一区二区| 国产日韩高清在线| 国产在线精品视频| 日韩你懂的在线观看| 日韩av在线发布| 欧美一区二区视频网站| 亚洲成人免费观看| 欧美性猛交xxxxxxxx| 亚洲精品第一国产综合野| 国产高清精品网站| 久久精品亚洲国产奇米99| 国内精品伊人久久久久av影院| 精品久久久久久亚洲综合网| 热久久免费视频| 日韩午夜在线观看| 精品午夜久久福利影院| 欧美精品一区二区三区蜜桃视频| 日韩1区2区日韩1区2区| 欧美一区二区三区在线观看 |