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

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

?? os_cpu.h

?? LPC2106開發板上面的uCOS移植代碼最新版2.83
?? H
字號:
/*
*********************************************************************************************************
*                                               uC/OS-II
*                                         The Real-Time Kernel
*
*
*                             (c) Copyright 1992-2006, Micrium, Weston, FL
*                                          All Rights Reserved
*
*                                           Generic ARM Port
*
* File      : OS_CPU.H
* Version   : V1.81
* By        : Jean J. Labrosse
*             Jean-Denis Hatier
*
* For       : ARM7 or ARM9
* Mode      : ARM or Thumb
* Toolchain : IAR's EWARM V4.11a and higher
*********************************************************************************************************
*/

#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
__arm  OS_CPU_SR  OS_CPU_SR_Save(void);           /* See OS_CPU_A.S                                    */
__arm  void       OS_CPU_SR_Restore(OS_CPU_SR cpu_sr);
#endif

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

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

       void       OS_CPU_InitExceptVect(void);

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

       void       OS_CPU_ExceptHndlr(INT32U  except_id);

#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

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
在线不卡a资源高清| 97久久久精品综合88久久| 亚洲美女一区二区三区| 欧美激情一区二区三区不卡| 日韩精品一区二区三区视频| 日韩欧美的一区二区| 日韩欧美123| 日韩区在线观看| 日韩欧美国产高清| 精品成人佐山爱一区二区| 欧美tickling网站挠脚心| 欧美不卡激情三级在线观看| 亚洲精品一区二区三区四区高清| 精品国产乱码久久久久久1区2区| 中文字幕国产一区| 国产精品美女视频| 亚洲三级在线看| 亚洲香肠在线观看| 另类小说图片综合网| 蜜芽一区二区三区| 丁香婷婷综合网| 91成人免费在线视频| 日韩欧美区一区二| 国产精品免费人成网站| 亚洲制服丝袜av| 激情亚洲综合在线| 99久久精品国产毛片| 欧美亚洲精品一区| 欧美成人乱码一区二区三区| 亚洲国产精品精华液2区45| 一区二区在线观看视频| 蜜桃av一区二区三区电影| 国产成a人亚洲精| 欧美日韩高清在线| 国产精品欧美一级免费| 亚洲一区二区三区国产| 国产一区二区精品久久91| 91黄色免费观看| 国产亚洲精品久| 天天av天天翘天天综合网色鬼国产| 国产一区二区三区蝌蚪| 欧美日韩一区二区三区免费看| 久久综合九色综合欧美亚洲| 亚洲综合激情网| 成人免费视频视频| 日韩视频免费观看高清完整版在线观看| 国产女主播视频一区二区| 视频一区中文字幕| 91久久久免费一区二区| 国产精品日日摸夜夜摸av| 美国欧美日韩国产在线播放| 欧美三级日本三级少妇99| 国产精品美女久久久久久久| 另类欧美日韩国产在线| 欧美精品777| 一二三四区精品视频| 99久久精品一区二区| 亚洲国产成人一区二区三区| 美女精品一区二区| 欧美喷潮久久久xxxxx| 亚洲精品视频在线观看网站| 成人免费高清在线| 久久无码av三级| 久久99国产精品久久99果冻传媒| 91福利在线观看| 亚洲乱码精品一二三四区日韩在线| 国产精品99久| 国产亚洲成年网址在线观看| 精品亚洲欧美一区| 精品国产亚洲一区二区三区在线观看 | 欧美电影免费观看高清完整版| 一区二区三国产精华液| 99久久伊人精品| 中文字幕亚洲一区二区av在线 | 国产精品私人影院| 国产宾馆实践打屁股91| 久久精品日韩一区二区三区| 九色|91porny| 久久精品亚洲麻豆av一区二区| 国产在线精品不卡| 欧美极品美女视频| 99久久精品国产导航| 亚洲视频免费观看| 欧美午夜一区二区三区免费大片| 亚洲一区二区三区免费视频| 国产精品看片你懂得| 成人午夜电影小说| 国产精品美女久久久久av爽李琼| 99久久伊人精品| 亚洲成人在线网站| 欧美电视剧在线观看完整版| 韩国女主播成人在线| 国产日产欧产精品推荐色 | 亚洲妇女屁股眼交7| 欧美视频在线播放| 蜜臀91精品一区二区三区| 精品国产亚洲在线| 不卡视频一二三四| 亚洲第一成年网| 日韩精品一区二区三区swag| a美女胸又www黄视频久久| 亚洲mv在线观看| 26uuu久久综合| 一本高清dvd不卡在线观看| 青青草视频一区| 亚洲欧美在线视频观看| 欧美一区二区三区男人的天堂| 国产一区二区视频在线| 一区二区三区在线视频观看58| 欧美一区二区大片| 99v久久综合狠狠综合久久| 亚洲国产一区二区在线播放| 久久久久久久久伊人| 国产精品国产三级国产aⅴ中文| 亚洲美女视频在线| 国产尤物一区二区| 亚洲综合在线电影| 免费成人深夜小野草| 中文欧美字幕免费| 91精品一区二区三区在线观看| 国产精品91xxx| 五月天中文字幕一区二区| 中文在线资源观看网站视频免费不卡| 在线观看欧美日本| 粉嫩欧美一区二区三区高清影视| 亚洲小少妇裸体bbw| 亚洲国产精品激情在线观看| 欧美一级精品在线| 欧美午夜精品久久久久久超碰| 高清不卡在线观看| 国内欧美视频一区二区| 亚洲电影视频在线| 136国产福利精品导航| 久久日一线二线三线suv| 精品视频1区2区| 色婷婷亚洲精品| 成年人网站91| 国产成人啪午夜精品网站男同| 热久久一区二区| 亚洲成年人网站在线观看| 1000部国产精品成人观看| 国产欧美日韩三区| 精品成人私密视频| 日韩丝袜情趣美女图片| 欧美日韩国产片| 欧美这里有精品| 91片黄在线观看| 91一区在线观看| 国产91清纯白嫩初高中在线观看| 国产精品亚洲专一区二区三区| 另类小说色综合网站| 日韩av电影免费观看高清完整版在线观看 | 2021国产精品久久精品| 日韩一级片网站| 日韩视频一区二区三区在线播放| 91精品综合久久久久久| 欧美精品日韩一本| 在线成人av网站| www国产亚洲精品久久麻豆| 精品久久久久久久人人人人传媒| 日韩欧美三级在线| 久久亚洲影视婷婷| 欧美国产精品中文字幕| 亚洲视频在线一区观看| 一区二区三区中文在线观看| 亚洲综合成人在线| 日本中文在线一区| 国产一区二区三区观看| 成人免费看黄yyy456| 色综合色综合色综合| 欧美亚洲自拍偷拍| 日韩欧美一级二级| 欧美激情一区在线| 一区二区三区中文字幕| 日韩电影免费在线看| 国产99一区视频免费| 色欲综合视频天天天| 欧美精品电影在线播放| 精品久久人人做人人爽| 国产精品久久久99| 性做久久久久久免费观看| 久久精品国产99国产精品| 不卡一区在线观看| 欧美精品一级二级| 国产精品午夜电影| 亚洲一区视频在线| 国产一区二区毛片| 色吧成人激情小说| 亚洲精品一区二区在线观看| 亚洲日本在线视频观看| 美女视频免费一区| 91天堂素人约啪| 日韩欧美中文字幕公布| 国产精品人妖ts系列视频| 五月激情综合网| 99re热这里只有精品视频| 日韩免费一区二区三区在线播放| 亚洲同性同志一二三专区| 免费观看在线综合| 在线观看国产日韩|