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

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

?? os_cpu.h

?? KEIL平臺下,LPC23XX官方的UCOSii的移植文件,包含各種功能的測試程序.
?? H
字號:
/*
*********************************************************************************************************
*                                               uC/OS-II
*                                         The Real-Time Kernel
*
*
*                             (c) Copyright 1992-2007, Micrium, Weston, FL
*                                          All Rights Reserved
*
*                                           Generic ARM Port
*
* File      : OS_CPU.H
* Version   : V1.82
* By        : Jean J. Labrosse
*             Jean-Denis Hatier
*
* For       : ARM7 or ARM9
* Mode      : ARM or Thumb
* Toolchain : RealView Development Suite
*             RealView Microcontroller Development Kit (MDK)
*             ARM Developer Suite (ADS)
*             Keil uVision
*********************************************************************************************************
*/

#ifndef  OS_CPU_H
#define  OS_CPU_H


#ifdef   OS_CPU_GLOBALS
#define  OS_CPU_EXT
#else
#define  OS_CPU_EXT  extern
#endif

#ifndef  OS_CPU_FPU_EN
#define  OS_CPU_FPU_EN    0                      /* HW floating point support disabled by default      */
#endif

/*
*********************************************************************************************************
*                                   INTERRUPT DISABLE TIME MEASUREMENT
*********************************************************************************************************
*/

#define  OS_CPU_INT_DIS_MEAS_EN    0


/*
*********************************************************************************************************
*                                           EXCEPTION DEFINES
*********************************************************************************************************
*/

                                                                /* ARM exception IDs                                    */
#define  OS_CPU_ARM_EXCEPT_RESET                                                                    0x00
#define  OS_CPU_ARM_EXCEPT_UNDEF_INSTR                                                              0x01
#define  OS_CPU_ARM_EXCEPT_SWI                                                                      0x02
#define  OS_CPU_ARM_EXCEPT_PREFETCH_ABORT                                                           0x03
#define  OS_CPU_ARM_EXCEPT_DATA_ABORT                                                               0x04
#define  OS_CPU_ARM_EXCEPT_ADDR_ABORT                                                               0x05
#define  OS_CPU_ARM_EXCEPT_IRQ                                                                      0x06
#define  OS_CPU_ARM_EXCEPT_FIQ                                                                      0x07
#define  OS_CPU_ARM_EXCEPT_MAX                                                                      0x08

                                                                /* ARM exception vectors addresses                      */
#define  OS_CPU_ARM_EXCEPT_RESET_VECT_ADDR              (OS_CPU_ARM_EXCEPT_RESET          * 0x04 + 0x00)
#define  OS_CPU_ARM_EXCEPT_UNDEF_INSTR_VECT_ADDR        (OS_CPU_ARM_EXCEPT_UNDEF_INSTR    * 0x04 + 0x00)
#define  OS_CPU_ARM_EXCEPT_SWI_VECT_ADDR                (OS_CPU_ARM_EXCEPT_SWI            * 0x04 + 0x00)
#define  OS_CPU_ARM_EXCEPT_PREFETCH_ABORT_VECT_ADDR     (OS_CPU_ARM_EXCEPT_PREFETCH_ABORT * 0x04 + 0x00)
#define  OS_CPU_ARM_EXCEPT_DATA_ABORT_VECT_ADDR         (OS_CPU_ARM_EXCEPT_DATA_ABORT     * 0x04 + 0x00)
#define  OS_CPU_ARM_EXCEPT_ADDR_ABORT_VECT_ADDR         (OS_CPU_ARM_EXCEPT_ADDR_ABORT     * 0x04 + 0x00)
#define  OS_CPU_ARM_EXCEPT_IRQ_VECT_ADDR                (OS_CPU_ARM_EXCEPT_IRQ            * 0x04 + 0x00)
#define  OS_CPU_ARM_EXCEPT_FIQ_VECT_ADDR                (OS_CPU_ARM_EXCEPT_FIQ            * 0x04 + 0x00)

                                                                /* ARM exception handlers addresses                     */
#define  OS_CPU_ARM_EXCEPT_RESET_HANDLER_ADDR           (OS_CPU_ARM_EXCEPT_RESET          * 0x04 + 0x20)
#define  OS_CPU_ARM_EXCEPT_UNDEF_INSTR_HANDLER_ADDR     (OS_CPU_ARM_EXCEPT_UNDEF_INSTR    * 0x04 + 0x20)
#define  OS_CPU_ARM_EXCEPT_SWI_HANDLER_ADDR             (OS_CPU_ARM_EXCEPT_SWI            * 0x04 + 0x20)
#define  OS_CPU_ARM_EXCEPT_PREFETCH_ABORT_HANDLER_ADDR  (OS_CPU_ARM_EXCEPT_PREFETCH_ABORT * 0x04 + 0x20)
#define  OS_CPU_ARM_EXCEPT_DATA_ABORT_HANDLER_ADDR      (OS_CPU_ARM_EXCEPT_DATA_ABORT     * 0x04 + 0x20)
#define  OS_CPU_ARM_EXCEPT_ADDR_ABORT_HANDLER_ADDR      (OS_CPU_ARM_EXCEPT_ADDR_ABORT     * 0x04 + 0x20)
#define  OS_CPU_ARM_EXCEPT_IRQ_HANDLER_ADDR             (OS_CPU_ARM_EXCEPT_IRQ            * 0x04 + 0x20)
#define  OS_CPU_ARM_EXCEPT_FIQ_HANDLER_ADDR             (OS_CPU_ARM_EXCEPT_FIQ            * 0x04 + 0x20)

                                                                /* ARM "Jump To Self" assembled instruction             */
#define  OS_CPU_ARM_INSTR_JUMP_TO_SELF                   0xEAFFFFFE
                                                                /* ARM "Jump To Exception Handler" assembled instruction*/
#define  OS_CPU_ARM_INSTR_JUMP_TO_HANDLER                0xE59FF018


/*
*********************************************************************************************************
*                                              DATA TYPES
*                                         (Compiler Specific)
*********************************************************************************************************
*/

typedef unsigned char  BOOLEAN;
typedef unsigned char  INT8U;                    /* Unsigned  8 bit quantity                           */
typedef signed   char  INT8S;                    /* Signed    8 bit quantity                           */
typedef unsigned short INT16U;                   /* Unsigned 16 bit quantity                           */
typedef signed   short INT16S;                   /* Signed   16 bit quantity                           */
typedef unsigned int   INT32U;                   /* Unsigned 32 bit quantity                           */
typedef signed   int   INT32S;                   /* Signed   32 bit quantity                           */
typedef float          FP32;                     /* Single precision floating point                    */
typedef double         FP64;                     /* Double precision floating point                    */

typedef unsigned int   OS_STK;                   /* Each stack entry is 32-bit wide                    */
typedef unsigned int   OS_CPU_SR;                /* Define size of CPU status register (PSR = 32 bits) */

/*
*********************************************************************************************************
*                                                ARM
*
* Method #1:  Disable/Enable interrupts using simple instructions.  After critical section, interrupts
*             will be enabled even if they were disabled before entering the critical section.
*             NOT IMPLEMENTED
*
* Method #2:  Disable/Enable interrupts by preserving the state of interrupts.  In other words, if
*             interrupts were disabled before entering the critical section, they will be disabled when
*             leaving the critical section.
*             NOT IMPLEMENTED
*
* Method #3:  Disable/Enable interrupts by preserving the state of interrupts.  Generally speaking you
*             would store the state of the interrupt disable flag in the local variable 'cpu_sr' and then
*             disable interrupts.  'cpu_sr' is allocated in all of uC/OS-II's functions that need to
*             disable interrupts.  You would restore the interrupt disable state by copying back 'cpu_sr'
*             into the CPU's status register.
*********************************************************************************************************
*/

#define  OS_CRITICAL_METHOD    3


#if      OS_CRITICAL_METHOD == 3

#if      OS_CPU_INT_DIS_MEAS_EN > 0

#define  OS_ENTER_CRITICAL()  {cpu_sr = OS_CPU_SR_Save();  \
                               OS_CPU_IntDisMeasStart();}
#define  OS_EXIT_CRITICAL()   {OS_CPU_IntDisMeasStop();   \
                               OS_CPU_SR_Restore(cpu_sr);}

#else

#define  OS_ENTER_CRITICAL()  {cpu_sr = OS_CPU_SR_Save();}
#define  OS_EXIT_CRITICAL()   {OS_CPU_SR_Restore(cpu_sr);}

#endif

#endif

/*
*********************************************************************************************************
*                                         ARM Miscellaneous
*********************************************************************************************************
*/

#define  OS_STK_GROWTH        1                   /* Stack grows from HIGH to LOW memory on ARM        */

#define  OS_TASK_SW()         OSCtxSw()

/*
*********************************************************************************************************
*                                            GLOBAL VARIABLES
*********************************************************************************************************
*/

                                                  /* Variables used to measure interrupt disable time  */
#if OS_CPU_INT_DIS_MEAS_EN > 0
OS_CPU_EXT  INT16U  OS_CPU_IntDisMeasNestingCtr;
OS_CPU_EXT  INT16U  OS_CPU_IntDisMeasCntsEnter;
OS_CPU_EXT  INT16U  OS_CPU_IntDisMeasCntsExit;
OS_CPU_EXT  INT16U  OS_CPU_IntDisMeasCntsMax;
OS_CPU_EXT  INT16U  OS_CPU_IntDisMeasCntsDelta;
OS_CPU_EXT  INT16U  OS_CPU_IntDisMeasCntsOvrhd;
#endif

/*
*********************************************************************************************************
*                                              PROTOTYPES
*********************************************************************************************************
*/

#if OS_CRITICAL_METHOD == 3
       OS_CPU_SR  OS_CPU_SR_Save(void);           /* See OS_CPU_A.ASM                                  */
       void       OS_CPU_SR_Restore(OS_CPU_SR cpu_sr);
#endif

       void       OS_CPU_SR_INT_Dis(void);
       void       OS_CPU_SR_INT_En(void);
       void       OS_CPU_SR_FIQ_Dis(void);
       void       OS_CPU_SR_FIQ_En(void);
       void       OS_CPU_SR_IRQ_Dis(void);
       void       OS_CPU_SR_IRQ_En(void);

#if OS_CPU_FPU_EN > 0
       void       OS_CPU_FP_Init(void);           /* See OS_CPU_C.C                                    */
       void       OS_CPU_FP_Restore(void *pblk);
       void       OS_CPU_FP_Save(void *pblk);
#endif

       void       OSCtxSw(void);
       void       OSIntCtxSw(void);
       void       OSStartHighRdy(void);

       void       OS_CPU_InitExceptVect(void);

       void       OS_CPU_ARM_ExceptResetHndlr(void);
       void       OS_CPU_ARM_ExceptUndefInstrHndlr(void);
       void       OS_CPU_ARM_ExceptSwiHndlr(void);
       void       OS_CPU_ARM_ExceptPrefetchAbortHndlr(void);
       void       OS_CPU_ARM_ExceptDataAbortHndlr(void);
       void       OS_CPU_ARM_ExceptAddrAbortHndlr(void);
       void       OS_CPU_ARM_ExceptIrqHndlr(void);
       void       OS_CPU_ARM_ExceptFiqHndlr(void);

       void       OS_CPU_ExceptHndlr(INT32U  except_type);

#if OS_CPU_INT_DIS_MEAS_EN > 0
       void       OS_CPU_IntDisMeasInit(void);
       void       OS_CPU_IntDisMeasStart(void);
       void       OS_CPU_IntDisMeasStop(void);
       INT16U     OS_CPU_IntDisMeasTmrRd(void);
#endif

#if OS_CPU_ARM_DCC_EN > 0
       void       OSDCC_Handler(void);
#endif

#endif

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品色眯眯| 欧美三级三级三级| 中文成人av在线| av午夜精品一区二区三区| 国产精品免费av| 成人毛片视频在线观看| 亚洲男人都懂的| 欧美久久久影院| 激情深爱一区二区| 国产精品青草综合久久久久99| 成人激情av网| 一区二区三区成人在线视频| 欧美日韩成人综合天天影院| 免费视频一区二区| 亚洲国产成人一区二区三区| 91美女片黄在线| 日本亚洲免费观看| 国产午夜精品久久久久久免费视| av在线播放不卡| 亚洲图片欧美一区| 26uuu另类欧美亚洲曰本| 99精品国产热久久91蜜凸| 五月婷婷久久丁香| 亚洲国产精品成人综合色在线婷婷| jizz一区二区| 蜜臀精品一区二区三区在线观看| 久久精品无码一区二区三区| 91麻豆免费视频| 免费成人av资源网| 亚洲天堂精品视频| 精品va天堂亚洲国产| 91麻豆免费看| 国产激情视频一区二区三区欧美 | 欧美中文字幕一二三区视频| 日本vs亚洲vs韩国一区三区| 中文字幕一区日韩精品欧美| 91麻豆精品国产91久久久久久久久| 狠狠色狠狠色合久久伊人| 亚洲欧美成人一区二区三区| 精品女同一区二区| 色狠狠综合天天综合综合| 国内精品不卡在线| 午夜精品一区二区三区免费视频 | 99re这里只有精品视频首页| 日韩不卡一二三区| 亚洲欧美日韩国产综合在线| 日韩视频免费观看高清完整版 | 免费在线观看一区| 亚洲人成7777| 国产日韩精品一区| 日韩久久精品一区| 欧美日韩国产首页| 色婷婷一区二区| 99视频有精品| 国产成人鲁色资源国产91色综 | 国产精品一区在线观看乱码 | 色吊一区二区三区| 成人av第一页| 成人综合婷婷国产精品久久蜜臀| 免费三级欧美电影| 丝袜诱惑亚洲看片| 亚洲国产日韩一区二区| 亚洲日本在线视频观看| 久久精品一区二区三区av| 日韩午夜av电影| 在线不卡免费av| 欧美性大战久久久久久久蜜臀| 成人高清在线视频| 成人午夜私人影院| 成人a免费在线看| 成人一二三区视频| 成人性色生活片| www.在线欧美| 成人av第一页| 日本电影欧美片| 色成年激情久久综合| 91久久免费观看| 91传媒视频在线播放| 色综合久久88色综合天天免费| 99久久国产综合精品麻豆| 成人午夜在线播放| 色婷婷av一区二区| 欧美午夜宅男影院| 欧美精品xxxxbbbb| 精品国产乱码久久久久久免费 | 精品国产第一区二区三区观看体验| 欧美一区二区网站| 日韩欧美一级特黄在线播放| 欧美大片在线观看一区| 精品国产123| 中文字幕欧美国产| 亚洲精品视频在线观看网站| 亚洲一区二区在线观看视频 | 国产一区二区三区久久久| 国模冰冰炮一区二区| 国产高清久久久| 一本久久综合亚洲鲁鲁五月天| 在线免费观看一区| 91精品国产乱| 中文字幕乱码日本亚洲一区二区| 中文字幕一区二区三区四区不卡| 亚洲日本青草视频在线怡红院| 亚洲国产成人高清精品| 久久99精品一区二区三区三区| 国产夫妻精品视频| 色偷偷久久人人79超碰人人澡| 欧美日韩aaa| 久久婷婷综合激情| 亚洲免费在线播放| 麻豆精品一二三| 国产成人av电影免费在线观看| 91在线视频18| 日韩一级完整毛片| 综合色中文字幕| 久久精品国产亚洲aⅴ| 成人a级免费电影| 欧美日韩精品免费观看视频| 久久亚洲私人国产精品va媚药| 亚洲欧美福利一区二区| 精品在线免费观看| 91视频免费看| 欧美精品一区二区三区视频| 亚洲精品欧美激情| 国产原创一区二区| 在线电影一区二区三区| 国产精品色呦呦| 蜜臀精品久久久久久蜜臀| 91在线精品一区二区| 精品国产自在久精品国产| 樱花草国产18久久久久| 国内成人精品2018免费看| 91猫先生在线| 国产亚洲短视频| 免费国产亚洲视频| 日本黄色一区二区| 国产偷国产偷精品高清尤物| 亚洲国产欧美在线| 99精品热视频| 欧美国产乱子伦| 久热成人在线视频| 欧美吻胸吃奶大尺度电影| 国产欧美视频在线观看| 日本aⅴ亚洲精品中文乱码| 在线观看精品一区| 综合久久一区二区三区| 国产精品一级片在线观看| 欧美日韩aaaaaa| 亚洲丶国产丶欧美一区二区三区| www.日韩av| 国产亚洲精品久| 夫妻av一区二区| 久久精品网站免费观看| 狠狠狠色丁香婷婷综合激情| 欧美久久一区二区| 婷婷久久综合九色国产成人| 91久久精品一区二区三区| 亚洲欧美另类小说| 一本高清dvd不卡在线观看| 国产精品女人毛片| 国产91丝袜在线播放九色| 日韩美女一区二区三区四区| 蜜桃精品视频在线观看| 91麻豆精品久久久久蜜臀| 天天色天天操综合| 欧美日韩国产综合视频在线观看| 一区二区三区四区不卡视频| 成人黄色电影在线| 国产精品福利影院| 北岛玲一区二区三区四区| 国产精品久久毛片a| 成人精品免费看| 亚洲色欲色欲www在线观看| 不卡欧美aaaaa| 一区二区三区在线免费| 在线视频欧美精品| 亚洲综合在线五月| 欧美日韩亚洲综合在线| 日韩中文字幕1| 欧美岛国在线观看| 国产激情一区二区三区| 中文字幕日韩精品一区| 色综合天天综合网国产成人综合天 | 不卡大黄网站免费看| 日本一区二区视频在线观看| 成人黄色一级视频| 亚洲一级不卡视频| 欧美一级高清片在线观看| 国产精品一品视频| 亚洲欧洲制服丝袜| 欧美日韩免费视频| 免费在线成人网| 日本一区二区久久| 欧日韩精品视频| 久久精品免费观看| 一区二区中文字幕在线| 欧美日韩在线直播| 国产精品一区二区果冻传媒| 亚洲精品视频一区二区| 制服丝袜av成人在线看| 韩国三级电影一区二区|