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

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

?? os_cpu.h

?? several peripheral examples of LPC2368 embedded chip
?? H
字號(hào):
/*
*********************************************************************************************************
*                                               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

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
韩国视频一区二区| 国产精品久久夜| 亚洲国产岛国毛片在线| 中文字幕一区二区视频| 一二三区精品福利视频| 亚洲国产精品麻豆| 紧缚奴在线一区二区三区| 成人中文字幕电影| 在线日韩一区二区| 久久久久久久久蜜桃| 亚洲特黄一级片| 另类小说综合欧美亚洲| 成人污视频在线观看| 欧美性色欧美a在线播放| 日韩欧美激情四射| 亚洲美女少妇撒尿| 久久99热狠狠色一区二区| 97成人超碰视| 精品剧情在线观看| 亚洲乱码国产乱码精品精的特点 | 色婷婷一区二区| 欧美高清hd18日本| 中文字幕的久久| 日韩av高清在线观看| 成人免费av在线| 制服.丝袜.亚洲.另类.中文| 国产亚洲欧美一区在线观看| 亚洲精品免费电影| 国产美女一区二区三区| 欧美在线制服丝袜| 国产视频一区不卡| 亚洲国产一二三| 白白色 亚洲乱淫| 欧美一区二区三区白人| 亚洲欧美一区二区久久| 久久se精品一区精品二区| 91久久精品一区二区| 久久精品视频一区二区| 日韩av高清在线观看| 色欲综合视频天天天| 久久精品一区二区| 蜜芽一区二区三区| 色天天综合色天天久久| 国产无人区一区二区三区| 亚洲1区2区3区视频| 成人a区在线观看| 欧美精品一区二区三| 亚洲777理论| 一本到不卡精品视频在线观看| 久久久久久久久久久黄色| 日本伊人色综合网| 欧美综合欧美视频| 亚洲三级视频在线观看| 国产超碰在线一区| 欧美成人国产一区二区| 日韩国产在线观看一区| 91久久精品日日躁夜夜躁欧美| 国产精品区一区二区三| 久久69国产一区二区蜜臀| 欧美电影在哪看比较好| 亚洲午夜久久久| 日本高清不卡aⅴ免费网站| 亚洲色欲色欲www| 国产91高潮流白浆在线麻豆| 久久久久国产精品厨房| 久久精品免费观看| 日韩欧美国产成人一区二区| 亚洲一级在线观看| 欧美日韩综合在线| 一个色在线综合| 欧美丝袜丝nylons| 亚洲午夜久久久久久久久久久| 欧美综合欧美视频| 亚洲在线中文字幕| 欧美亚洲动漫制服丝袜| 亚洲一区免费观看| 欧美日韩免费高清一区色橹橹 | 欧美在线免费观看亚洲| 久久精品国产77777蜜臀| 日韩一区二区三区三四区视频在线观看 | 日日摸夜夜添夜夜添亚洲女人| 91久久精品网| 亚洲va欧美va国产va天堂影院| 欧美理论电影在线| 日韩国产成人精品| 欧美成人福利视频| 国产精品一区二区男女羞羞无遮挡| 欧美精品一区二区三区蜜桃| 国产一区二区三区免费观看| 国产清纯在线一区二区www| 国产福利精品导航| 一区二区中文视频| 日韩一区二区三免费高清| 欧美va亚洲va| 亚洲综合无码一区二区| 国产精品乱码久久久久久| 久久av老司机精品网站导航| 日韩欧美电影一区| 国产成人免费视频| 国产福利一区二区三区视频在线 | 欧美一区二区三区男人的天堂| 亚洲成av人片一区二区| 欧美一区二区精品| 国产在线精品一区二区| 中文字幕中文字幕一区| 9色porny自拍视频一区二区| 亚洲综合色成人| 91精品午夜视频| 国产成a人亚洲| 一区二区高清在线| 日韩精品一区在线观看| 丰满放荡岳乱妇91ww| 亚洲蜜臀av乱码久久精品蜜桃| 欧美日韩亚洲综合在线 | 欧美一区欧美二区| 国产美女主播视频一区| 日韩一区有码在线| 日韩午夜在线影院| 成人精品电影在线观看| 亚洲123区在线观看| 久久亚洲免费视频| 日本韩国视频一区二区| 九九精品视频在线看| 亚洲欧美日韩中文播放| 日韩三级精品电影久久久| 福利91精品一区二区三区| 亚洲成人久久影院| 国产日韩高清在线| 欧美电影一区二区| av成人老司机| 久久精品国产免费看久久精品| 国产精品久99| 精品久久久久久最新网址| 91网上在线视频| 蓝色福利精品导航| 一区二区在线观看不卡| 精品成人a区在线观看| 在线一区二区三区| 国产成人精品三级麻豆| 蜜臀久久99精品久久久久宅男 | 99精品一区二区| 美女网站在线免费欧美精品| 亚洲另类中文字| 久久精品一区二区三区不卡牛牛| 中文字幕一区二区三区在线观看 | 国产乱码字幕精品高清av| 国产激情偷乱视频一区二区三区| 成人国产精品免费观看| 日本韩国欧美一区| 久久久精品综合| 免费成人你懂的| 91福利社在线观看| 亚洲女子a中天字幕| 成人午夜精品在线| 久久精品男人的天堂| 麻豆国产一区二区| 亚洲动漫第一页| 国产精品久久久久aaaa| 2欧美一区二区三区在线观看视频| 在线观看不卡一区| 白白色亚洲国产精品| 国产在线观看一区二区| 日韩高清不卡一区二区三区| 一区二区三区四区不卡在线| 国产精品入口麻豆九色| 久久午夜免费电影| 欧美一级欧美三级| 欧美日韩1234| 欧美最猛黑人xxxxx猛交| 色综合咪咪久久| 成人少妇影院yyyy| 国产成人在线视频免费播放| 久久精品国产网站| 老司机一区二区| 美腿丝袜亚洲一区| 三级成人在线视频| 五月婷婷综合在线| 一区二区三区高清不卡| 亚洲精品一二三四区| 中文字幕在线一区免费| 国产精品久久久久婷婷| 国产欧美精品区一区二区三区| 亚洲精品在线观看网站| 日韩精品中文字幕在线不卡尤物| 91麻豆精品国产91久久久使用方法 | 亚洲成人1区2区| 亚洲主播在线观看| 亚洲v日本v欧美v久久精品| 亚洲最大的成人av| 亚洲一区二区三区视频在线| 夜夜嗨av一区二区三区中文字幕| 亚洲精品日产精品乱码不卡| 一区二区三区成人| 亚洲午夜久久久久久久久电影院| 亚洲午夜av在线| 日日夜夜一区二区| 久久精品国产99国产| 国产福利精品导航| 不卡的电视剧免费网站有什么| 91麻豆精品在线观看|