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

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

?? os_cpu.h

?? mcb2100下的基于ucos-ii的CAN驅動
?? 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一区二区三区免费野_久草精品视频
国产精品久久久久久久久免费樱桃 | 日本伊人午夜精品| 色av综合在线| 亚洲一二三区不卡| 欧美丰满高潮xxxx喷水动漫| 日韩电影免费一区| 精品国产污污免费网站入口| 国产乱码精品一区二区三区av| 久久久亚洲精华液精华液精华液| 欧美一区二区三区白人| 久久国产三级精品| 欧美国产精品一区二区三区| 99久久婷婷国产综合精品电影| 亚洲欧美激情在线| 欧美日韩在线播放三区| 久草热8精品视频在线观看| 国产亚洲精品久| 91美女片黄在线| 日韩av一区二| 中文字幕乱码亚洲精品一区| 欧美性视频一区二区三区| 青青草国产精品亚洲专区无| 国产亚洲一区二区三区四区 | 亚洲婷婷综合久久一本伊一区| 在线免费精品视频| 九九精品视频在线看| 国产精品久久看| 777精品伊人久久久久大香线蕉| 国产一区二区在线观看视频| 亚洲码国产岛国毛片在线| 777午夜精品免费视频| 国产高清精品久久久久| 亚洲午夜在线视频| 久久久www成人免费毛片麻豆| 91视频免费看| 久久99精品久久久| 一区二区三区在线免费播放| 日韩欧美国产麻豆| 91毛片在线观看| 极品少妇xxxx精品少妇| 亚洲精品免费在线| 久久久久99精品国产片| 欧美乱熟臀69xxxxxx| av在线播放成人| 久久97超碰国产精品超碰| bt欧美亚洲午夜电影天堂| 午夜久久久久久久久久一区二区| 国产精品人妖ts系列视频| 日韩欧美一级二级| 欧美日韩免费一区二区三区视频 | 欧美国产精品v| 欧美一级片在线| 欧洲日韩一区二区三区| 成人免费视频一区二区| 精品一区二区综合| 日韩精品一二区| 亚洲一区二区在线视频| 中文字幕亚洲精品在线观看| 久久久噜噜噜久久人人看 | 精品区一区二区| 欧美久久久久久久久久| 色综合久久精品| 成人高清视频在线观看| 国产成人综合在线观看| 另类欧美日韩国产在线| 蜜桃精品视频在线| 天天综合色天天| 亚洲成人自拍网| 亚洲制服丝袜av| 亚洲电影你懂得| 亚洲自拍偷拍网站| 亚洲永久免费av| 亚洲一区二区三区免费视频| 亚洲三级视频在线观看| 久88久久88久久久| 奇米精品一区二区三区在线观看一| 亚洲一区二区三区美女| 亚洲成人激情综合网| 亚洲福利视频导航| 日韩激情av在线| 另类成人小视频在线| 国产一区二区三区最好精华液| 精品一区二区三区日韩| 激情深爱一区二区| 国产精品亚洲一区二区三区在线 | 亚洲日本中文字幕区| 国产精品久久久久久一区二区三区| 日本一区二区三区电影| 国产精品区一区二区三| 中文字幕一区二区三区在线观看 | 国产ts人妖一区二区| 成人免费看视频| 日本高清免费不卡视频| 欧美日韩国产a| 精品日韩成人av| 欧美激情在线观看视频免费| 成人欧美一区二区三区视频网页| 国产精品乱码妇女bbbb| 一级中文字幕一区二区| 五月婷婷综合在线| 国模套图日韩精品一区二区 | 99久久精品国产精品久久| 国产区在线观看成人精品| 国产精品久久久久久久久久久免费看 | 欧美成人性战久久| 国产精品区一区二区三| 亚洲国产一区二区三区| 久久99九九99精品| av在线播放不卡| 91精品啪在线观看国产60岁| 久久久精品天堂| 亚洲福利视频一区| 国产精品自拍av| 91久久精品一区二区二区| 日韩欧美亚洲国产另类| 亚洲天天做日日做天天谢日日欢| 日本亚洲视频在线| 国产成人综合亚洲网站| 欧美在线观看一区| 精品美女在线观看| 亚洲激情第一区| 国内久久婷婷综合| 欧美日韩国产精品自在自线| 久久欧美一区二区| 亚洲成av人片一区二区梦乃| 国产在线一区二区| 欧美亚洲日本国产| 欧美激情一区二区三区全黄 | 亚洲女厕所小便bbb| 美女尤物国产一区| 在线观看日韩高清av| 久久九九久久九九| 日韩激情视频网站| 色88888久久久久久影院野外| 久久综合色婷婷| 亚洲国产精品一区二区久久 | 国产九色sp调教91| 在线播放一区二区三区| 日韩毛片高清在线播放| 国产另类ts人妖一区二区| 5858s免费视频成人| 亚洲美女在线国产| 成人丝袜视频网| www亚洲一区| 日韩成人精品在线| 91高清视频免费看| 国产精品久久久久四虎| 国产成人日日夜夜| 欧美变态tickle挠乳网站| 亚洲成人av中文| 欧日韩精品视频| 国产精品每日更新| 国产精品一区二区不卡| 欧美刺激脚交jootjob| 亚洲人成网站影音先锋播放| 欧美色爱综合网| 中文字幕日韩一区二区| 久久精品网站免费观看| 麻豆精品新av中文字幕| 日本一区二区免费在线观看视频 | 97aⅴ精品视频一二三区| 亚洲精品一区二区三区蜜桃下载| 日本精品裸体写真集在线观看 | 精品伊人久久久久7777人| 欧美精品精品一区| 亚洲图片有声小说| 欧美亚洲愉拍一区二区| 亚洲永久免费av| 欧美在线三级电影| 亚洲制服丝袜av| 欧美另类变人与禽xxxxx| 亚洲成人一二三| 欧美军同video69gay| 舔着乳尖日韩一区| 欧美日产国产精品| 免费精品视频在线| 亚洲精品一区二区三区香蕉| 黑人巨大精品欧美一区| 国产日韩欧美精品在线| 丁香五精品蜜臀久久久久99网站| 国产日韩一级二级三级| gogo大胆日本视频一区| 一区二区三区在线观看国产| 欧美揉bbbbb揉bbbbb| 日韩在线播放一区二区| 精品久久99ma| 成人免费高清在线| 一区二区三区欧美视频| 欧美伦理电影网| 国内精品久久久久影院色| 国产精品国产自产拍高清av| 在线观看网站黄不卡| 麻豆国产精品官网| 日本一区二区三区高清不卡| 一本色道久久综合亚洲91| 视频在线观看一区| 久久久国产精品午夜一区ai换脸| 不卡大黄网站免费看| 亚洲国产精品人人做人人爽| 欧美变态tickle挠乳网站|