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

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

?? os_cpu_a_backup.s

?? UCOS在ARM7TDMI上的移植。與它的官方版不同的是
?? S
?? 第 1 頁(yè) / 共 2 頁(yè)
字號(hào):
        LDR     R11, [SP], #4
        LDR     R12, [SP], #4
        LDR     LR,  [SP], #4
        LDR     PC,  [SP], #4


;*********************************************************************************************************
;                   PERFORM A CONTEXT SWITCH (From interrupt level) - OSIntCtxSw()
;
; Note(s) : 1) OSIntCtxSw() is called in SYS mode with BOTH FIQ and IRQ interrupts DISABLED
;
;           2) The pseudo-code for OSCtxSw() is:
;              a) OSTaskSwHook();
;              b) OSPrioCur             = OSPrioHighRdy;
;              c) OSTCBCur              = OSTCBHighRdy;
;              d) SP                    = OSTCBHighRdy->OSTCBStkPtr;
;              e) Restore the new task's context from the new task's stack
;              f) Return to new task's code
;
;           3) Upon entry: 
;              OSTCBCur      points to the OS_TCB of the task to suspend
;              OSTCBHighRdy  points to the OS_TCB of the task to resume
;*********************************************************************************************************

;        RSEG CODE:CODE:NOROOT(2)
        CODE32

OSIntCtxSw
        BL      OSTaskSwHook            ; OSTaskSwHook();

        LDR     R4,=OSPrioCur         ; OSPrioCur = OSPrioHighRdy
        LDR     R5,=OSPrioHighRdy
        LDRB    R6,[R5]
        STRB    R6,[R4]
        
        LDR     R4,=OSTCBCur          ; OSTCBCur  = OSTCBHighRdy;
        LDR     R6,=OSTCBHighRdy
        LDR     R6,[R6]
        STR     R6,[R4]

        LDR     SP,[R6]                 ; SP = OSTCBHighRdy->OSTCBStkPtr;

                                        ; RESTORE NEW TASK'S CONTEXT
        LDR     R4,  [SP], #4           ;    pop new task's CPSR
        MSR     CPSR_cxsf, R4
        LDR     R0,  [SP], #4           ;    pop new task's context
        LDR     R1,  [SP], #4
        LDR     R2,  [SP], #4
        LDR     R3,  [SP], #4
        LDR     R4,  [SP], #4
        LDR     R5,  [SP], #4
        LDR     R6,  [SP], #4
        LDR     R7,  [SP], #4
        LDR     R8,  [SP], #4
        LDR     R9,  [SP], #4
        LDR     R10, [SP], #4
        LDR     R11, [SP], #4
        LDR     R12, [SP], #4
        LDR     LR,  [SP], #4
        LDR     PC,  [SP], #4


;*********************************************************************************************************
;                                      IRQ Interrupt Service Routine
;*********************************************************************************************************

;        RSEG CODE:CODE:NOROOT(2)
        CODE32

OS_CPU_IRQ_ISR
                                        
        STR     R3,  [SP, #-4]!                ; PUSH WORKING REGISTERS ONTO IRQ STACK
        STR     R2,  [SP, #-4]!
        STR     R1,  [SP, #-4]!
        
        MOV     R1, SP                         ; Save   IRQ stack pointer
        
        ADD     SP, SP,#12                     ; Adjust IRQ stack pointer 
        
        SUB     R2, LR,#4                      ; Adjust PC for return address to task

        MRS     R3, SPSR                       ; Copy SPSR (i.e. interrupted task's CPSR) to R3
        
        MSR     CPSR_c, #(NO_INT | SYS32_MODE) ; Change to SYS mode

                                               ; SAVE TASK'S CONTEXT ONTO TASK'S STACK
        STR     R2,  [SP, #-4]!                ;    Push task's Return PC 
        STR     LR,  [SP, #-4]!                ;    Push task's LR
        STR     R12, [SP, #-4]!                ;    Push task's R12-R4
        STR     R11, [SP, #-4]!
        STR     R10, [SP, #-4]!
        STR     R9,  [SP, #-4]!
        STR     R8,  [SP, #-4]!
        STR     R7,  [SP, #-4]!
        STR     R6,  [SP, #-4]!
        STR     R5,  [SP, #-4]!
        STR     R4,  [SP, #-4]!
        
        LDR     R4,  [R1], #4                  ;    Move task's R1-R3 from IRQ stack to SYS stack
        LDR     R5,  [R1], #4        
        LDR     R6,  [R1], #4
        STR     R6,  [SP, #-4]!
        STR     R5,  [SP, #-4]!
        STR     R4,  [SP, #-4]!
        
        STR     R0,  [SP, #-4]!                ;    Push task's R0    onto task's stack
        STR     R3,  [SP, #-4]!                ;    Push task's CPSR (i.e. IRQ's SPSR)
                
                                               ; HANDLE NESTING COUNTER
        LDR     R0, =OSIntNesting            ; OSIntNesting++;
        LDRB    R1, [R0]
        ADD     R1, R1,#1
        STRB    R1, [R0]

        CMP     R1, #1                         ; if (OSIntNesting == 1) {
        BNE     OS_CPU_IRQ_ISR_1

        LDR     R4, =OSTCBCur                ;     OSTCBCur->OSTCBStkPtr = SP
        LDR     R5, [R4]
        STR     SP, [R5]                       ; }

OS_CPU_IRQ_ISR_1
        MSR     CPSR_c, #(NO_INT | IRQ32_MODE) ; Change to IRQ mode (to use the IRQ stack to handle interrupt)
        
        BL      OS_CPU_IRQ_ISR_Handler         ; OS_CPU_IRQ_ISR_Handler();
        
        MSR     CPSR_c, #(NO_INT | SYS32_MODE) ; Change to SYS mode
        
        BL      OSIntExit                     ; OSIntExit();
        
                                              ; RESTORE TASK'S CONTEXT and RETURN TO TASK
        LDR     R4,  [SP], #4                 ;    pop new task's CPSR
        MSR     CPSR_cxsf, R4
        LDR     R0,  [SP], #4                 ;    pop new task's context
        LDR     R1,  [SP], #4
        LDR     R2,  [SP], #4
        LDR     R3,  [SP], #4
        LDR     R4,  [SP], #4
        LDR     R5,  [SP], #4
        LDR     R6,  [SP], #4
        LDR     R7,  [SP], #4
        LDR     R8,  [SP], #4
        LDR     R9,  [SP], #4
        LDR     R10, [SP], #4
        LDR     R11, [SP], #4
        LDR     R12, [SP], #4
        LDR     LR,  [SP], #4
        LDR     PC,  [SP], #4

;FIQ NOT NEEDEDs	!
;*********************************************************************************************************
;                                      FIQ Interrupt Service Routine
;*********************************************************************************************************

;        RSEG CODE:CODE:NOROOT(2)
;        CODE32

;OS_CPU_FIQ_ISR
;                                        
;        STMFD   SP!,{R1-R3}                   ; PUSH WORKING REGISTERS ONTO IRQ STACK
;        
;        MOV     R1,SP                         ; Save   IRQ stack pointer
;        
;        ADD     SP,SP,#12                     ; Adjust FIQ stack pointer 
;        
;        SUB     R2,LR,#4                      ; Adjust PC for return address to task
;
;        MRS     R3,SPSR                       ; Copy SPSR (i.e. interrupted task's CPSR) to R3
;        
;        MSR     CPSR_c,#(NO_INT | SYS32_MODE) ; Change to SYS mode
;
;                                              ; SAVE TASK'S CONTEXT ONTO TASK'S STACK
;        STMFD   SP!,{R2}                      ;    Push task's Return PC 
;        STMFD   SP!,{R4-R12,LR}               ;    Push task's LR,R12-R4
        
;        LDMFD   R1!,{R4-R6}                   ;    Move task's R1-R3 from IRQ stack to SYS stack
;        STMFD   SP!,{R4-R6}
;        STMFD   SP!,{R0}                      ;    Push task's R0    onto task's stack
;        STMFD   SP!,{R3}                      ;    Push task's CPSR (i.e. IRQ's SPSR)
;        
;                                              ; HANDLE NESTING COUNTER
;        LDR     R0,=OSIntNesting            ; OSIntNesting++;
;        LDRB    R1,[R0]
;        ADD     R1,R1,#1
;        STRB    R1,[R0]
;
;        CMP     R1,#1                         ; if (OSIntNesting == 1) {
;        BNE     OS_CPU_FIQ_ISR_1
;
;        LDR     R4,=OSTCBCur                ;     OSTCBCur->OSTCBStkPtr = SP
;        LDR     R5,[R4]
;        STR     SP,[R5]                       ; }

;OS_CPU_FIQ_ISR_1
;        MSR     CPSR_c,#(NO_INT | FIQ32_MODE) ; Change to FIQ mode (to use the FIQ stack to handle interrupt)
;        
;        BL      OS_CPU_FIQ_ISR_Handler        ; OS_CPU_FIQ_ISR_Handler();
;        
;        MSR     CPSR_c,#(NO_INT | SYS32_MODE) ; Change to SYS mode
;        
;        BL      OSIntExit                     ; OSIntExit();
;        
;                                              ; RESTORE TASK'S CONTEXT and RETURN TO TASK
;        LDMFD   SP!,{R4}                      ; pop new task's CPSR
;        MSR     CPSR_cxsf,r4
;        LDMFD   SP!,{R0-R12,LR,PC}            ; pop new task's R0-R12,LR & PC
;
;
;;*********************************************************************************************************
;;                                     POINTERS TO VARIABLES
;*********************************************************************************************************

;        DATA
             
;=OS_IntNesting:
;        DC32    OSIntNesting

;=OS_PrioCur:
;        DC32    OSPrioCur

;=OS_PrioHighRdy:
;        DC32    OSPrioHighRdy

;=OS_Running:
;        DC32    OSRunning

;=OS_TCBCur:
;        DC32    OSTCBCur

;=OS_TCBHighRdy:
;        DC32    OSTCBHighRdy

        END

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美性做爰猛烈叫床潮| 99久久精品免费精品国产| 亚洲精品亚洲人成人网在线播放| 国产日韩欧美精品综合| 国产日韩综合av| 中文字幕的久久| 中文字幕成人在线观看| 国产精品乱人伦| 亚洲国产精华液网站w| 国产欧美日韩中文久久| 国产欧美日韩在线视频| 国产精品免费久久久久| 亚洲天堂av老司机| 一区二区久久久| 视频在线观看国产精品| 老司机免费视频一区二区三区| 麻豆高清免费国产一区| 国产一区二区三区av电影 | 一区二区三区精品| 一区二区三区在线免费视频| 亚洲韩国一区二区三区| 日韩不卡一区二区| 国产精品一区二区在线观看网站| 国产91精品一区二区麻豆网站| av福利精品导航| 欧美系列日韩一区| 日韩精品一区二区三区swag| 国产色91在线| 一级特黄大欧美久久久| 男男视频亚洲欧美| 国产91综合网| 欧美午夜宅男影院| 精品粉嫩超白一线天av| 国产精品国产三级国产aⅴ原创| 亚洲黄色录像片| 蓝色福利精品导航| 成人app软件下载大全免费| 欧美日韩在线播放| 加勒比av一区二区| 国产在线视频不卡二| 福利一区福利二区| 欧美国产日韩一二三区| 日产国产高清一区二区三区| 国产·精品毛片| 色婷婷综合久久| 欧美日韩国产高清一区| 久久久噜噜噜久噜久久综合| 亚洲人成网站在线| 蜜臀av一区二区在线免费观看| 国产99久久久国产精品免费看| 欧美视频你懂的| 国产视频一区不卡| 五月激情综合网| 成人精品视频一区二区三区 | 99精品欧美一区二区三区小说| 欧美日韩国产高清一区二区三区 | 丝袜亚洲另类欧美| 国产精品羞羞答答xxdd| 欧美主播一区二区三区美女| 欧美xxxxxxxx| 国产日韩三级在线| 国产精品自产自拍| aa级大片欧美| 色婷婷综合中文久久一本| 日韩一级片在线播放| 亚洲视频图片小说| 国产一区久久久| 欧美日韩国产高清一区二区| 中文字幕永久在线不卡| 蜜臂av日日欢夜夜爽一区| 一本久道中文字幕精品亚洲嫩| 久久久www免费人成精品| 日韩精品91亚洲二区在线观看| 97久久超碰国产精品| 久久精品日韩一区二区三区| 青青草国产成人av片免费| 日本精品一区二区三区四区的功能| 国产丝袜在线精品| 精品在线播放午夜| 91精品久久久久久久99蜜桃| 亚洲一卡二卡三卡四卡无卡久久| 成人高清视频在线| 欧美激情一区二区三区在线| 久久av中文字幕片| 日韩一区二区三区四区| 香蕉久久夜色精品国产使用方法| 国产一区二区三区在线观看免费| 青青草国产精品亚洲专区无| 国产精品乱码一区二三区小蝌蚪| 亚洲人xxxx| 成人黄动漫网站免费app| 久久夜色精品国产欧美乱极品| 亚洲五码中文字幕| 欧洲一区在线电影| 亚洲精品久久嫩草网站秘色| 成人的网站免费观看| 欧美国产欧美亚州国产日韩mv天天看完整 | 人禽交欧美网站| 欧美群妇大交群中文字幕| 一区二区三区国产豹纹内裤在线| 99re在线精品| 亚洲欧美色图小说| 91色.com| 一二三四社区欧美黄| 在线观看一区二区视频| 一区二区成人在线观看| 色八戒一区二区三区| 亚洲精品伦理在线| 欧美中文字幕一二三区视频| 一区二区三区中文字幕电影| 欧美在线短视频| 亚洲不卡一区二区三区| 欧美老女人第四色| 人人精品人人爱| 久久久亚洲综合| 成人精品视频.| 亚洲色图都市小说| 欧美无砖砖区免费| 不卡的av网站| 亚洲国产视频一区二区| 国精产品一区一区三区mba桃花| 日韩一级片在线观看| 狠狠色丁香久久婷婷综合_中| 精品国产乱码久久久久久夜甘婷婷| 久久99精品久久久久| 国产亚洲污的网站| 99精品视频在线观看免费| 亚洲综合自拍偷拍| 欧美一区三区二区| 国产成人av电影在线观看| 中文字幕中文字幕一区| 精品视频资源站| 麻豆国产一区二区| 国产日韩欧美综合一区| 色综合久久99| 免费观看在线色综合| 国产拍欧美日韩视频二区| 色菇凉天天综合网| 看电视剧不卡顿的网站| 久久久综合激的五月天| 91美女精品福利| 日本女人一区二区三区| 国产三级精品视频| 欧美日韩视频在线第一区| 国产一区二区三区免费在线观看| 国产精品福利一区二区三区| 欧美日韩高清一区二区三区| 国产一区二区影院| 亚洲一区二区三区四区的| 欧美成人性战久久| 91黄视频在线| 国产一区欧美日韩| 亚洲123区在线观看| 国产免费成人在线视频| 欧美精品一卡二卡| 不卡在线视频中文字幕| 日本欧美肥老太交大片| 日韩毛片一二三区| 久久亚洲综合av| 欧美日韩国产天堂| 成人av动漫在线| 麻豆国产精品官网| 一级精品视频在线观看宜春院| 国产肉丝袜一区二区| 国产精品人妖ts系列视频| 国产精品一区二区你懂的| 国产成人精品一区二| 国产日韩三级在线| 欧美日韩一级片在线观看| 视频一区在线视频| 日韩一区二区在线看| 国产乱人伦偷精品视频不卡| 91精品国产91综合久久蜜臀| 国产欧美日韩视频在线观看| 亚洲一区在线观看免费观看电影高清| 成人免费观看男女羞羞视频| 日韩丝袜情趣美女图片| 欧美aⅴ一区二区三区视频| 欧美日韩成人在线一区| 亚洲一区二区视频在线观看| 欧美日韩在线播| 蜜桃久久久久久久| 色视频一区二区| 久久亚洲二区三区| 久久爱www久久做| 欧美剧在线免费观看网站| 亚洲va国产天堂va久久en| 国产成人精品免费| 国产午夜精品久久久久久免费视 | 亚洲在线视频免费观看| www.成人在线| 亚洲va在线va天堂| 国产精品美女一区二区| 欧美一卡二卡在线| 6080午夜不卡| 欧美色精品天天在线观看视频| 96av麻豆蜜桃一区二区| 成人激情图片网| 成人动漫一区二区在线| 国产99久久精品|