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

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

?? os_cpu_a.asm

?? ucos-ii 的完整代碼
?? ASM
字號:
/*;************************************************************************************************;                                         uC/OS-II;                                    The Real-Time Kernel; ;                         (c) Copyright 2006, Micrium, Inc., Weston, FL;                                     All Rights Reserved;  ; File        : OS_CPU_A.ASM; By          : Jean J. Labrosse;; Note(s)     : 1) This port uses the MOVEM.L (A7),D0-D7/A0-A6, LEA 60(A7)A7 construct instead of        ;                  the traditional 68xxx MOVEM.L (A7)+,D0-D7/A0-A6.  It is perfectly in order to ;                  push/pop individual registers using MOVEM.L (A7)+,D2, etc. but it's a bit slower;                  (and more verbose).              ;                                           ;               2) The LEA instruction is required because the ColdFire cannot push multiple ;                  registers directly to the stack.         ;;               3) Changed OSIntCtxSw for new uC/OS-II version 2.51 features.;**************************************************************************************************//*;*************************************************************************************************;                                       PUBLIC DECLARATIONS;**************************************************************************************************/        .global  _OS_CPU_SR_Save        .global  _OS_CPU_SR_Restore        .global  _OSCtxSw        .global  _OSIntCtxSw        .global  _OSStartHighRdy        		.global  _OS_My_ISR/*;**************************************************************************************************;                                     EXTERNAL DECLARATIONS;***************************************************************************************************/        .extern  _OSRunning        .extern  _OSIntExit        .extern  _OSIntNesting        .extern  _OSLockNesting        .extern  _OSPrioCur        .extern  _OSPrioHighRdy        .extern  _OSRdyGrp        .extern  _OSRdyTbl        .extern  _OSTaskSwHook        .extern  _OSTCBCur        .extern  _OSTCBHighRdy        .extern  _OSIntEnter        .text        .align 4/*;********************************************************************************************************;                              OSCPUSaveSR() for OS_CRITICAL_METHOD #3;; Description : This functions implements the OS_CRITICAL_METHOD #3 function to preserve the state of the ;               interrupt disable flag in order to be able to restore it later.;; Arguments   : none;; Returns     : It is assumed that the return value is placed in the D0 register as expected by the;               compiler.;*********************************************************************************************************/_OS_CPU_SR_Save:        MOVE.W   SR,D0            ; Copy SR into D0         MOVE.L   D0,-(A7)         ; Save D0        ORI.L    #0x0700,D0       ; Disable interrupts        MOVE     D0,SR        MOVE.L   (A7)+,D0         ; Restore D0        RTS/*;********************************************************************************************************;                              OSCPURestoreSR() for OS_CRITICAL_METHOD #3;; Description : This functions implements the OS_CRITICAL_METHOD #3 function to restore the state of the;               interrupt flag.;; Arguments   : os_cpu_sr   is the contents of the SR to restore.  It is assumed that this 'argument' is ;                           passed on the stack as follows:;;               A7 +  0 ->  D0;                  +  4     return address;                  +  8     return address;                  +  4     D0;               A7 +  0 ->;; Returns     : None ;*********************************************************************************************************/_OS_CPU_SR_Restore:        MOVE.L   D0,-(A7)         ; Save D0        MOVE.W   10(A7),D0        MOVE.W    D0,SR        MOVE.L   (A7)+,D0         ; Restore D0        RTS/*;*******************************************************************************************;                            START HIGHEST PRIORITY TASK READY-TO-RUN;; Description: This function is called by OSStart() to start the highest priority task that;              was created by your application before calling OSStart().;; Arguments  : none;; Note(s)    : 1) The stack frame is assumed to look as follows:;             ;                  OSTCBHighRdy->OSTCBStkPtr +  0  ---->  D0         Low Memory;                                            +  4         D1 ;                                            +  8         D2;                                            + 12         D3;                                            + 16         D4;                                            + 20         D5;                                            + 24         D6;                                            + 28         D7;                                            + 32         A0;                                            + 36         A1;                                            + 40         A2;                                            + 44         A3;                                            + 48         A4;                                            + 52         A5;                                            + 56         A6;                                            + 60         Format, Vector, OS_INITIAL_SR;                                            + 64         task;                                            + 68         task;                                            + 72         p_arg       High Memory;;              2) OSStartHighRdy() MUST:;                    a) Call OSTaskSwHook() then,;                    b) Set OSRunning to TRUE,;                    c) Switch to the highest priority task.;********************************************************************************************/_OSStartHighRdy:       JSR       _OSTaskSwHook            /* Invoke user defined context switch hook       */       MOVEQ.L   #1, D4                   /* OSRunning = TRUE;                             */       MOVE.B    D4,_OSRunning            /*   Indicates that we are multitasking          */       MOVE.L    (_OSTCBHighRdy),A1       /* Point to TCB of highest prio task ready to run*/       MOVE.L    (A1),A7                  /* Get the stack pointer of the task to resume   */       MOVEM.L   (A7),D0-D7/A0-A6     	  /* Store all the regs                            */       LEA       60(A7),A7                /* Advance the stack pointer                     */       RTE                                /* Return to task                                *//*;*******************************************************************************************;                                     TASK LEVEL CONTEXT SWITCH;; Description : This function is called when a task makes a higher prio task ready-to-run.; ; Arguments   : none;; Note(s)     : 1) Upon entry,;                   OSTCBCur     points to the OS_TCB of the task to suspend;                   OSTCBHighRdy points to the OS_TCB of the task to resume;;               2) The stack frame of the task to suspend looks as follows (the registers ;                  for task to suspend need to be saved):;;                                         SP +  0  ---->  Format, Vector, SR   Low Memory;                                            +  4         PC of task           High Memory;;               3) The stack frame of the task to resume looks as follows:; ;                  OSTCBHighRdy->OSTCBStkPtr +  0  ---->  D0                   Low Memory;                                            +  4         D1;                                            +  8         D2;                                            + 12         D3;                                            + 16         D4;                                            + 20         D5;                                            + 24         D6;                                            + 28         D7;                                            + 32         A0;                                            + 36         A1;                                            + 40         A2;                                            + 44         A3;                                            + 48         A4;                                            + 52         A5;                                            + 56         A6;                                            + 60         SR of task;                                            + 64         PC of task           High Memory;;********************************************************************************************/_OSCtxSw:       LEA       -60(A7),A7       MOVEM.L   D0-D7/A0-A6,(A7)     	  /* Save the registers of the current task        */       MOVE.L    (_OSTCBCur),A1           /* Save stack pointer in the suspended task TCB  */       MOVE.L    A7,(A1)       JSR       _OSTaskSwHook            /* Invoke user defined context switch hook       */       MOVE.L    (_OSTCBHighRdy),A1       /* OSTCBCur = OSTCBHighRdy                       */       MOVE.L    A1,(_OSTCBCur)       MOVE.L    (A1),A7                  /* Get the stack pointer of the task to resume   */         MOVE.B    (_OSPrioHighRdy),D0      /* OSPrioCur = OSPrioHighRdy                     */       MOVE.B    D0,(_OSPrioCur)         MOVEM.L   (A7),D0-D7/A0-A6     	  /* Restore the CPU registers                     */       LEA       60(A7),A7       RTE                                /* Run task                                      *//*;*******************************************************************************************;                                 INTERRUPT LEVEL CONTEXT SWITCH;;; Description : This function is provided for backward compatibility and to ;  				satisfy OSIntExit() ;               in OS_CORE.C.;; Arguments   : none;********************************************************************************************/_OSIntCtxSw:       JSR        _OSTaskSwHook            /* Invoke user defined context switch hook       */      MOVE.B     (_OSPrioHighRdy),D0      /* OSPrioCur = OSPrioHighRdy                     */      MOVE.B     D0,(_OSPrioCur)          MOVE.L     (_OSTCBHighRdy),A1       /* OSTCBCur  = OSTCBHighRdy                      */      MOVE.L     A1,(_OSTCBCur)      MOVE.L     (A1),A7                  /* SP        = OSTCBHighRdy->OSTCBStkPtr         */          MOVEM.L    (A7),D0-D7/A0-A6     	  /* Restore ALL CPU registers from new task stack */      LEA        60(A7),A7      RTE                                 /* Run task                                      *//*;*******************************************************************************************;                                        GENERIC ISR;; Description : This function shows how to write ISRs;; Arguments   : none;; Notes       : 1) You MUST save ALL the CPU registers as shown below;               2) You MUST increment 'OSIntNesting' and NOT call OSIntEnter();               3) You MUST JUMP to OSIntExitCF() instead of call the function.;               4) You MUST NOT use OSIntExit() to exit an ISR with the MCF5275.;********************************************************************************************/_OS_My_ISR:      MOVE.W     #0x2700,SR               /* Disable interrupts                            */      LEA        -60(A7),A7               /* Save processor registers onto stack           */      MOVEM.L    D0-D7/A0-A6,(A7)      MOVEQ.L    #0,D0                    /* OSIntNesting++                                */      MOVE.L     (_OSIntNesting),D0      ADDQ.L     #1,D0                  MOVE.L     D0,(_OSIntNesting)      CMPI.L     #1, D0                   /* if (OSIntNesting == 1)                        */      BNE        _OS_My_ISR_1      MOVE.L     (_OSTCBCur), A1          /*     OSTCBCur-<OSTCBStkPtr = SP                */      MOVE.L     A7,(A1)_OS_My_ISR_1:      JSR        _OS_My_ISR_Handler       /* OS_My_ISR_Handler()                           */      JSR        _OSIntExit               /* Exit the ISR                                  */      MOVEM.L    (A7),D0-D7/A0-A6         /* Restore processor registers from stack        */      LEA        60(A7),A7      RTE                                 /* Return to task or nested ISR                  */_OS_My_ISR_Handler:      RTS      .end

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
中文字幕亚洲一区二区av在线| 欧美主播一区二区三区美女| 精品久久国产字幕高潮| 久久99精品国产91久久来源| 精品国产乱码久久久久久牛牛 | 久久久噜噜噜久久中文字幕色伊伊| 免费观看在线综合色| 日韩精品在线看片z| 国内精品伊人久久久久影院对白| 久久女同性恋中文字幕| av一区二区三区在线| 国产精品国产精品国产专区不片| 在线视频国内自拍亚洲视频| 蜜桃精品视频在线| 国产精品三级av在线播放| 欧美性猛交xxxxxx富婆| 日韩一区精品视频| 国产色产综合色产在线视频| 91久久精品网| 男女视频一区二区| 国产精品久久三| 欧美一区午夜视频在线观看| 国产电影一区在线| 午夜精品福利视频网站| 国产日韩欧美精品电影三级在线| 色综合久久久网| 久久福利资源站| 亚洲黄色在线视频| www国产成人免费观看视频 深夜成人网| 成人av资源网站| 美女免费视频一区| 自拍偷拍国产精品| 亚洲精品一线二线三线无人区| 成人性视频免费网站| 日本不卡123| 亚洲男同性视频| 精品国产乱码久久久久久闺蜜 | 国产一区二区三区久久悠悠色av| 亚洲欧美日韩国产一区二区三区| 精品精品国产高清a毛片牛牛| 色综合激情五月| 高清在线观看日韩| 日韩av中文字幕一区二区三区| 亚洲欧美综合另类在线卡通| 日韩欧美国产wwwww| 欧美在线你懂的| 99re成人精品视频| 精品亚洲免费视频| 首页国产欧美久久| 亚洲欧美中日韩| 国产欧美一区二区三区鸳鸯浴| 欧美日韩国产另类一区| 99视频在线观看一区三区| 激情六月婷婷综合| 蜜桃av噜噜一区二区三区小说| 亚洲一区日韩精品中文字幕| 国产精品视频一二| 久久久久久久久久久电影| 日韩精品一区二区三区四区视频| 欧美日韩精品一区二区三区四区| 99免费精品视频| 成人美女视频在线观看18| 精品一区二区三区免费观看| 男女性色大片免费观看一区二区| 亚洲成人先锋电影| 亚洲国产日韩综合久久精品| 激情六月婷婷久久| 久久精品久久综合| 免费观看91视频大全| 午夜精品在线看| 香港成人在线视频| 日韩不卡一二三区| 热久久免费视频| 美女被吸乳得到大胸91| 日本va欧美va精品发布| 毛片av中文字幕一区二区| 日本成人在线看| 久久99精品国产.久久久久久 | 亚洲无线码一区二区三区| 亚洲美女视频一区| 艳妇臀荡乳欲伦亚洲一区| 亚洲一区二区三区视频在线播放 | 欧美视频一区二区三区四区| 色婷婷精品大视频在线蜜桃视频| 91在线视频免费观看| 成人国产精品免费网站| 成人丝袜高跟foot| 91亚洲精品一区二区乱码| 一本大道综合伊人精品热热| 欧洲视频一区二区| 在线电影国产精品| 日韩视频一区二区| 国产色综合一区| 亚洲色图视频网| 亚洲国产中文字幕在线视频综合| 日韩精品电影一区亚洲| 久久国产精品露脸对白| 国产福利精品一区二区| 99久久精品免费看| 欧美日韩国产bt| 精品粉嫩aⅴ一区二区三区四区| 国产日本欧美一区二区| 亚洲激情在线播放| 天堂影院一区二区| 国产成人在线视频网站| 欧美最猛性xxxxx直播| 欧美一区二区免费观在线| 欧美极品美女视频| 一区二区三区欧美久久| 久久国产精品99久久人人澡| 成人丝袜18视频在线观看| 欧美日韩激情一区二区| 国产色产综合色产在线视频 | 国产精品视频一二三| 亚洲一区二区偷拍精品| 国产乱人伦精品一区二区在线观看| 成人不卡免费av| 欧美二区三区91| 国产精品视频一二三| 日韩av不卡一区二区| 丁香婷婷综合五月| 91麻豆精品国产自产在线 | 欧美日韩国产综合一区二区三区| 日韩三区在线观看| 1区2区3区国产精品| 日本91福利区| 日本久久一区二区三区| 精品国产一二三| 亚洲1区2区3区4区| 成人毛片老司机大片| 精品日本一线二线三线不卡| 亚洲欧美日韩成人高清在线一区| 麻豆极品一区二区三区| 91成人国产精品| 国产精品人妖ts系列视频| 免费成人在线播放| 在线观看日韩高清av| 国产婷婷精品av在线| 日韩av网站免费在线| 在线精品观看国产| 国产精品国产三级国产普通话蜜臀| 精品亚洲欧美一区| 3d成人动漫网站| 亚洲在线视频网站| av一区二区三区在线| 国产午夜精品美女毛片视频| 蜜桃91丨九色丨蝌蚪91桃色| 欧美日韩一卡二卡| 亚洲午夜羞羞片| 在线观看国产日韩| 亚洲天堂成人在线观看| 国产iv一区二区三区| 久久综合资源网| 免费观看成人鲁鲁鲁鲁鲁视频| 欧美日韩免费观看一区三区| 亚洲欧美日韩国产手机在线 | 亚洲一区二区三区四区在线观看| av不卡一区二区三区| 中文一区在线播放| jlzzjlzz亚洲日本少妇| 国产精品嫩草影院com| 成人免费毛片高清视频| 欧美激情一区二区三区不卡| 国产成人av资源| 国产精品久久久一本精品| 成人性生交大片免费看视频在线 | 97se狠狠狠综合亚洲狠狠| 国产精品美女久久久久aⅴ国产馆| 国产精品自拍在线| 久久影院电视剧免费观看| 国内精品视频666| 精品三级av在线| 久久99国产精品久久99 | 91色综合久久久久婷婷| 亚洲人快播电影网| 91成人国产精品| 婷婷丁香久久五月婷婷| 色激情天天射综合网| 亚洲一二三专区| 91麻豆精品国产自产在线观看一区 | 欧美一级日韩免费不卡| 激情五月激情综合网| 欧美国产一区二区| 一本久久精品一区二区| 一区二区三国产精华液| 欧美精品乱码久久久久久| 亚洲成人777| xf在线a精品一区二区视频网站| 国产精品亚洲午夜一区二区三区| 国产欧美日韩综合| 色综合久久久久综合体桃花网| 午夜伦理一区二区| xvideos.蜜桃一区二区| youjizz久久| 亚洲国产精品久久一线不卡| 91精品一区二区三区在线观看| 国产麻豆日韩欧美久久| 最近中文字幕一区二区三区| 欧美无乱码久久久免费午夜一区| 蜜桃精品在线观看|