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

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

?? os_cpu_a.s

?? S3CEB2410_ucos
?? S
字號:
#********************************************************************************************************
#                                               uC/OS-II
#                                         The Real-Time Kernel
#
#                          (c) Copyright 1992-2002, Jean J. Labrosse, Weston, FL
#                                          All Rights Reserved
#
# File : OS_CPU_A.ASM
# By   : Jean J. Labrosse
#********************************************************************************************************

#********************************************************************************************************
#                                               ARM Port
#
#                 Target           : ARM (Includes ARM7, ARM9)
#                 Ported by        : Michael Anburaj
#                 URL              : http://geocities.com/michaelanburaj/    Email : michaelanburaj@hotmail.com
#
#********************************************************************************************************



        .text

#*********************************************************************************************************
#                                          START MULTITASKING
#                                       void OSStartHighRdy(void)
#
# Note : OSStartHighRdy() MUST:
#           a) Call OSTaskSwHook() then,
#           b) Set OSRunning to TRUE,
#           c) Switch to the highest priority task.
#*********************************************************************************************************

        .EXTERN  OSTaskSwHook
        .EXTERN  OSRunning
        .EXTERN  OSTCBHighRdy

        .GLOBAL  OSStartHighRdy

OSStartHighRdy:  

        bl OSTaskSwHook             @ Call user defined task switch hook

        ldr r4,=OSRunning           @ Indicate that multitasking has started
        mov r5,#1
        strb r5,[r4]

        ldr r4,=OSTCBHighRdy        @ Get highest priority task TCB address

        ldr r4,[r4]                 @ get stack pointer
        ldr sp,[r4]                 @ switch to the new stack

        ldmfd sp!,{r4}              @ pop new task's spsr
        msr SPSR_cxsf,r4
        ldmfd sp!,{r4}              @ pop new task's psr
        msr CPSR_cxsf,r4
        ldmfd sp!,{r0-r12,lr,pc}    @ pop new task's r0-r12,lr & pc

#*********************************************************************************************************
#                                PERFORM A CONTEXT SWITCH (From task level)
#                                           void OSCtxSw(void)
#
# Note(s):    Upon entry, 
#             OSTCBCur     points to the OS_TCB of the task to suspend
#             OSTCBHighRdy points to the OS_TCB of the task to resume
#
#*********************************************************************************************************

        .EXTERN  OSTCBCur
        .EXTERN  OSTaskSwHook
        .EXTERN  OSTCBHighRdy
        .EXTERN  OSPrioCur
        .EXTERN  OSPrioHighRdy

        .GLOBAL  OSCtxSw

OSCtxSw:
# Special optimised code below:
        stmfd sp!,{lr}              @ push pc (lr should be pushed in place of PC)
        stmfd sp!,{r0-r12,lr}       @ push lr & register file
        mrs r4,cpsr
        stmfd sp!,{r4}              @ push current psr
        mrs r4,spsr
        stmfd sp!,{r4}              @ push current spsr

        # OSPrioCur = OSPrioHighRdy
        ldr r4,=OSPrioCur
        ldr r5,=OSPrioHighRdy
        ldrb r6,[r5]
        strb r6,[r4]
        
        # Get current task TCB address
        ldr r4,=OSTCBCur
        ldr r5,[r4]
        str sp,[r5]                 @ store sp in preempted tasks's TCB

        bl OSTaskSwHook             @ call Task Switch Hook

        # Get highest priority task TCB address
        ldr r6,=OSTCBHighRdy
        ldr r6,[r6]
        ldr sp,[r6]                 @ get new task's stack pointer

        # OSTCBCur = OSTCBHighRdy
        str r6,[r4]                 @ set new current task TCB address

        ldmfd sp!,{r4}              @ pop new task's spsr
        msr SPSR_cxsf,r4
        ldmfd sp!,{r4}              @ pop new task's psr
        msr CPSR_cxsf,r4
        ldmfd sp!,{r0-r12,lr,pc}    @ pop new task's r0-r12,lr & pc


#*********************************************************************************************************
#                                PERFORM A CONTEXT SWITCH (From an ISR)
#                                        void OSIntCtxSw(void)
#
# Note(s): This function only flags a context switch to the ISR Handler
#
#*********************************************************************************************************

        .EXTERN  OSIntCtxSwFlag

        .GLOBAL  OSIntCtxSw

OSIntCtxSw:

        #OSIntCtxSwFlag = True
        ldr r0,=OSIntCtxSwFlag
        mov r1,#1
        str r1,[r0]
        mov pc,lr
        

#*********************************************************************************************************
#                                            IRQ HANDLER
#
#        This handles all the IRQs
#        Note: FIQ Handler should be written similar to this
#
#*********************************************************************************************************

        .EXTERN  IsrIRQ
        .EXTERN  OSIntEnter
        .EXTERN  OSIntExit

        .EXTERN  OSIntCtxSwFlag
        .EXTERN  OSTCBCur
        .EXTERN  OSTaskSwHook
        .EXTERN  OSTCBHighRdy
        .EXTERN  OSPrioCur
        .EXTERN  OSPrioHighRdy

#Pre-defined constants
.equ 	USERMODE,	0x10
.equ 	FIQMODE,	0x11
.equ 	IRQMODE,	0x12
.equ 	SVCMODE,	0x13
.equ 	ABORTMODE,	0x17
.equ 	UNDEFMODE,	0x1b
.equ 	MODEMASK,	0x1f
.equ 	NOINT,		0xc0

        .GLOBAL  UserIRQ_Handle
UserIRQ_Handle:

        stmfd sp!,{r0-r3,r12,lr}

        bl OSIntEnter
        bl IsrIRQ
        bl OSIntExit

        ldr r0,=OSIntCtxSwFlag
        ldr r1,[r0]
        cmp r1,#1
        beq _IntCtxSw

        ldmfd sp!,{r0-r3,r12,lr}
        subs pc,lr,#4


_IntCtxSw:
        mov r1,#0
        str r1,[r0]

        ldmfd sp!,{r0-r3,r12,lr}
        stmfd sp!,{r0-r3}
        mov r1,sp
        add sp,sp,#16
        sub r2,lr,#4

        mrs r3,spsr
        orr r0,r3,#NOINT
        msr spsr_c,r0

        ldr r0,=.+8
        movs pc,r0

        stmfd sp!,{r2}              @ push old task's pc
        stmfd sp!,{r4-r12,lr}       @ push old task's lr,r12-r4
        mov r4,r1                   @ Special optimised code below
        mov r5,r3
        ldmfd r4!,{r0-r3}
        stmfd sp!,{r0-r3}           @ push old task's r3-r0
        stmfd sp!,{r5}              @ push old task's psr
        mrs r4,spsr
        stmfd sp!,{r4}              @ push old task's spsr
        
        # OSPrioCur = OSPrioHighRdy
        ldr r4,=OSPrioCur
        ldr r5,=OSPrioHighRdy
        ldrb r5,[r5]
        strb r5,[r4]
        
        # Get current task TCB address
        ldr r4,=OSTCBCur
        ldr r5,[r4]
        str sp,[r5]                 @ store sp in preempted tasks's TCB

        bl OSTaskSwHook             @ call Task Switch Hook

        # Get highest priority task TCB address
        ldr r6,=OSTCBHighRdy
        ldr r6,[r6]
        ldr sp,[r6]                 @ get new task's stack pointer

        # OSTCBCur = OSTCBHighRdy
        str r6,[r4]                 @ set new current task TCB address

        ldmfd sp!,{r4}              @ pop new task's spsr
        msr SPSR_cxsf,r4
        ldmfd sp!,{r4}              @ pop new task's psr
        msr CPSR_cxsf,r4

        ldmfd sp!,{r0-r12,lr,pc}    @ pop new task's r0-r12,lr & pc

#*********************************************************************************************************
#                                   CRITICAL SECTION METHOD 3 FUNCTIONS
#
# Description: 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.
#
#              OS_CPU_SR OSCPUSaveSR()
# Arguments  : none
#
# Returns    : OS_CPU_SR
#
#              OSCPURestoreSR(OS_CPU_SR cpu_sr)
# Arguments  : OS_CPU_SR
#
# Returns    : none
#
# Note(s)    : These functions are used in general like this,
#
#            void Task (void *data)
#            {
#                    #if OS_CRITICAL_METHOD == 3 /* Allocate storage for CPU status register */
#                          OS_CPU_SR  cpu_sr#
#                    #endif
#                         :
#                         :
#                    OS_ENTER_CRITICAL()# /* cpu_sr = OSCPUSaveSR()# */
#                         :
#                         :
#                    OS_EXIT_CRITICAL()#  /* OSCPURestoreSR(cpu_sr)# */
#                         :
#                         :
#            }
#*********************************************************************************************************

        .GLOBAL  OSCPUSaveSR
OSCPUSaveSR:

        mrs r0,CPSR
        orr r1,r0,#NOINT
        msr CPSR_c,r1
        mov pc,lr


        .GLOBAL  OSCPURestoreSR
OSCPURestoreSR:

        msr CPSR_c,r0
        mov pc,lr


#        END

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品国产乱码久久久久久免费 | 日本欧美肥老太交大片| 色综合久久六月婷婷中文字幕| 久久久久99精品国产片| 国产成人av自拍| 国产视频一区二区在线| 成人中文字幕在线| 国产精品国产三级国产aⅴ入口| 成人福利视频网站| 综合婷婷亚洲小说| 在线亚洲免费视频| 天天综合日日夜夜精品| 欧美一区二区三区视频在线 | 国产精品国产自产拍在线| 91一区一区三区| 五月天网站亚洲| 久久精品视频一区| av电影一区二区| 亚洲成人福利片| 久久久久国产一区二区三区四区| 国产精品一二三区在线| 中文字幕精品一区二区精品绿巨人 | 日韩欧美一级二级三级| 国产精品91一区二区| 中文字幕日韩一区二区| 在线免费观看成人短视频| 免费成人美女在线观看.| 日本一区二区成人| 在线观看国产91| 黑人巨大精品欧美一区| 亚洲日本在线天堂| 精品人在线二区三区| 成人av午夜电影| 视频一区中文字幕| 国产精品免费视频网站| 91精品综合久久久久久| 成人在线一区二区三区| 视频一区欧美精品| 国产精品第四页| 制服丝袜在线91| av在线一区二区| 久久成人精品无人区| 国产精品视频观看| 欧美一区二区久久| 91在线国产观看| 久久电影网电视剧免费观看| 伊人婷婷欧美激情| 精品日韩在线观看| 在线观看91视频| 大白屁股一区二区视频| 麻豆精品视频在线观看免费| 亚洲少妇30p| 国产蜜臀av在线一区二区三区| 在线看日韩精品电影| www.亚洲在线| 免费高清不卡av| 亚洲一二三四区| 中文字幕一区日韩精品欧美| 精品国产成人系列| 欧美精品乱码久久久久久按摩| 99久久免费视频.com| 国产一区二区三区美女| 毛片不卡一区二区| 午夜视频一区二区| 亚洲福利视频导航| 一区二区三区精品视频在线| 欧美极品少妇xxxxⅹ高跟鞋 | 欧美经典三级视频一区二区三区| 91精品国产综合久久精品app| 99久久国产综合精品女不卡| 在线中文字幕一区| 99国产一区二区三精品乱码| 成人激情黄色小说| 成人天堂资源www在线| 国产一区二区三区美女| 国产自产视频一区二区三区| 国内外成人在线视频| 激情成人综合网| 国产精品99久久久| 成人综合激情网| av资源网一区| 色婷婷亚洲综合| 欧美亚洲自拍偷拍| 欧美日韩激情在线| 欧美一级理论片| 亚洲精品在线三区| 国产亚洲一区二区三区四区| 国产午夜亚洲精品理论片色戒 | 国产欧美一区二区精品性色超碰 | 在线视频一区二区三区| 在线免费观看视频一区| 欧美亚洲一区三区| 欧美日韩三级一区| 制服丝袜中文字幕亚洲| 精品国产免费人成电影在线观看四季| 欧美一区二区播放| 久久美女高清视频| 中文字幕一区二区不卡| 亚洲一区二区三区四区中文字幕| 三级影片在线观看欧美日韩一区二区| 日韩黄色片在线观看| 激情成人综合网| 成人av先锋影音| 欧美日韩国产另类一区| 日韩一区二区三区在线观看| 国产三级一区二区| 亚洲女同女同女同女同女同69| 一区二区三区小说| 免费三级欧美电影| 懂色av一区二区在线播放| 91久久香蕉国产日韩欧美9色| 欧美男人的天堂一二区| 精品国产乱码久久久久久闺蜜| 国产精品欧美精品| 午夜欧美视频在线观看| 国产在线国偷精品免费看| 91麻豆成人久久精品二区三区| 欧美日韩日日夜夜| 日本一区二区三区四区| 亚洲成人三级小说| 国产精品99久久久久久似苏梦涵| 色婷婷av一区二区三区gif | 久久日韩精品一区二区五区| 国产精品色婷婷久久58| 丝袜亚洲另类丝袜在线| 成人爱爱电影网址| 欧美日韩高清一区| 中文字幕一区二区在线播放| 蜜桃一区二区三区在线| 99久久99久久综合| 欧美精品一区视频| 亚洲国产精品久久人人爱| 风间由美一区二区三区在线观看 | 青草av.久久免费一区| 成人激情动漫在线观看| 日韩一区二区在线看| 中文字幕日韩一区二区| 国产在线视频精品一区| 欧美日韩亚洲综合在线| 中文字幕欧美一| 激情深爱一区二区| 欧美视频一区二区三区在线观看| 国产日韩欧美精品综合| 久久精品99国产精品| 欧美综合欧美视频| 国产精品久久久久天堂| 国产综合久久久久久鬼色| 欧美一区二区成人| 亚洲成人免费影院| 色欧美乱欧美15图片| 中文字幕 久热精品 视频在线| 日韩成人av影视| 欧美色图片你懂的| 亚洲精品综合在线| 成人av电影免费在线播放| 久久综合中文字幕| 久久国产精品第一页| 欧美精品高清视频| 性欧美疯狂xxxxbbbb| 91九色02白丝porn| 亚洲色图在线视频| 91在线国产观看| 亚洲欧美国产高清| 99久久免费视频.com| 国产精品第13页| 99久久精品国产导航| 国产精品毛片久久久久久| 国产成a人亚洲| 久久久不卡影院| 成人永久免费视频| 亚洲国产精品ⅴa在线观看| 国产福利91精品| 中文av一区二区| 99久久久免费精品国产一区二区| 日本一区二区三区四区在线视频| 国产99久久久精品| 国产精品美女www爽爽爽| jiyouzz国产精品久久| 国产精品久久久久aaaa| 99久久99久久精品免费观看| 亚洲色图制服诱惑 | 久久99久久久久久久久久久| 欧美精品v国产精品v日韩精品| 日韩影院免费视频| xf在线a精品一区二区视频网站| 国产一区二区免费看| 国产精品网站在线播放| 91麻豆免费观看| 天堂资源在线中文精品| 日韩精品一区在线观看| 国产mv日韩mv欧美| 综合欧美一区二区三区| 欧美三级一区二区| 免费不卡在线视频| 亚洲国产电影在线观看| 欧美性大战久久久久久久蜜臀| 视频一区二区欧美| 中文字幕av资源一区| 精品视频一区二区不卡| 国产乱一区二区|