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

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

?? core_cmfunc.h

?? uCOSII_lwip_lpc1768
?? 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) */


/** \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");
}


/** \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");
}


/** \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"
}


/** \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");

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久亚洲综合色| 91精品视频网| 91最新地址在线播放| 一区二区三区蜜桃| 亚洲成人你懂的| 日韩一区二区三区精品视频| 紧缚捆绑精品一区二区| 亚洲精品成a人| 国产精品电影一区二区三区| 国产成人福利片| 99久久综合国产精品| 91久久精品国产91性色tv| 在线观看日韩国产| 欧美xxxxx牲另类人与| 国产欧美一区二区精品忘忧草| 国产精品另类一区| 日本女人一区二区三区| 国产成人在线视频网址| 日本丶国产丶欧美色综合| 日韩一区二区三区视频在线| 国产亚洲人成网站| 日av在线不卡| 91蜜桃网址入口| 亚洲免费视频成人| 日本一区中文字幕| 99久久免费国产| 精品国产乱码久久久久久影片| 亚洲欧洲成人精品av97| 美日韩一级片在线观看| 在线观看91视频| 国产精品欧美一区喷水| 亚洲女同女同女同女同女同69| 欧美日韩国产色站一区二区三区| 久久精品男人天堂av| 日本成人在线电影网| 欧美三级一区二区| 亚洲在线成人精品| 欧美三级韩国三级日本三斤| 中文字幕在线不卡| 91老司机福利 在线| 国产精品久久久久永久免费观看| 蜜桃av一区二区三区电影| 欧美日韩一级大片网址| 天堂成人国产精品一区| 欧美一区二区视频在线观看2022 | 欧美成人伊人久久综合网| 三级欧美韩日大片在线看| 欧美性生活久久| 日韩av一级片| 精品国产乱码久久久久久久| 九九热在线视频观看这里只有精品| 日韩一区二区在线看| 国产电影一区在线| 中文字幕一区二区三区不卡| 97国产一区二区| 日韩不卡一二三区| 日本一区二区三级电影在线观看| 99精品视频中文字幕| 视频在线观看一区| 欧美激情一二三区| 欧美日韩精品免费| 高清免费成人av| 蜜桃视频在线观看一区二区| 久久日韩粉嫩一区二区三区| 91国偷自产一区二区三区成为亚洲经典| 一区二区三区精品视频在线| 欧美成人午夜电影| 欧美日韩亚州综合| 91蜜桃免费观看视频| 免费一区二区视频| 日韩电影在线观看电影| 国产精品久久久久天堂| 欧美精品一区视频| 欧美日韩视频在线第一区| av爱爱亚洲一区| 国产成人精品一区二区三区四区| 日韩国产精品久久久久久亚洲| 中文字幕中文字幕中文字幕亚洲无线 | 视频一区二区国产| 国产精品日韩成人| 国产偷国产偷亚洲高清人白洁 | 国产精品免费av| 国产亚洲欧洲997久久综合| 精品日韩99亚洲| 精品人在线二区三区| 日韩免费一区二区三区在线播放| 欧美日韩一区二区在线观看视频| 99久久久久久| 精品视频1区2区3区| 欧美视频中文一区二区三区在线观看| 91麻豆国产精品久久| 一本大道久久a久久精二百| 91麻豆自制传媒国产之光| 在线观看精品一区| 在线成人免费视频| 久久亚区不卡日本| 欧美韩国日本一区| 香蕉久久一区二区不卡无毒影院 | 欧美视频精品在线| 精品久久久久久久久久久久久久久久久| 欧美精品自拍偷拍| 日韩视频在线永久播放| 国产日产欧美一区二区视频| 亚洲国产成人午夜在线一区| 一区二区三区精密机械公司| 日本不卡1234视频| 96av麻豆蜜桃一区二区| 9191国产精品| 国产午夜亚洲精品午夜鲁丝片 | 美腿丝袜亚洲三区| 国产精品一区专区| 在线视频观看一区| 国产免费成人在线视频| 亚洲成人一区二区在线观看| 国产大陆亚洲精品国产| 欧美人狂配大交3d怪物一区| 国产欧美一区视频| 九九视频精品免费| 欧美高清视频www夜色资源网| 国产精品视频你懂的| 日韩和的一区二区| 欧美性一二三区| 一区二区三区四区精品在线视频| 经典一区二区三区| 精品久久久久久综合日本欧美| 一区二区国产视频| 色婷婷国产精品| 一区二区三区四区国产精品| 一区二区三区日韩精品| 国产精品 日产精品 欧美精品| 日韩视频免费观看高清完整版| 亚洲美女视频一区| 色婷婷亚洲精品| 一区二区三区日韩欧美精品| 色哦色哦哦色天天综合| 亚洲精品精品亚洲| 欧美日韩成人综合天天影院| 亚洲午夜激情av| 欧美片在线播放| 美国十次综合导航| 久久久夜色精品亚洲| 丁香亚洲综合激情啪啪综合| 国产精品美女久久久久久久久| 丁香另类激情小说| 亚洲国产一区视频| 欧美www视频| 95精品视频在线| 全国精品久久少妇| 亚洲国产高清不卡| 欧美伦理电影网| 韩国毛片一区二区三区| 综合久久久久久久| 日韩欧美精品在线视频| 成人丝袜视频网| 天天操天天综合网| 国产精品久久久久久久久搜平片| 欧美视频你懂的| 成人免费高清在线观看| 偷拍亚洲欧洲综合| 亚洲精品视频自拍| 久久免费国产精品| 91精品国产福利在线观看| 丁香婷婷深情五月亚洲| 久久电影国产免费久久电影| 综合在线观看色| 国产精品视频你懂的| 精品久久久久香蕉网| 欧美一区二区啪啪| 欧美久久久久久蜜桃| 色综合天天视频在线观看 | 在线免费视频一区二区| av高清不卡在线| 高清beeg欧美| 成人免费看片app下载| 激情文学综合插| 国产999精品久久久久久绿帽| 精品一区二区三区香蕉蜜桃 | 欧美顶级少妇做爰| 欧美日韩精品电影| 7777精品久久久大香线蕉| 欧美日韩免费一区二区三区视频 | 亚洲欧美日韩电影| ...xxx性欧美| 日韩精品一区第一页| 日本成人在线网站| 国产尤物一区二区在线| 国产精品一区二区在线观看不卡| 国产一区二区伦理| 99久久99久久综合| 成人18精品视频| 欧美日韩一区二区电影| 日韩亚洲国产中文字幕欧美| 久久婷婷综合激情| 国产成人自拍网| 成人av免费观看| 欧美午夜精品免费| 国产清纯白嫩初高生在线观看91| 日本一区二区在线不卡| 亚洲成人黄色小说| 成人免费毛片app|