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

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

?? os_cpu_a.s

?? ARM7的一些試驗程序
?? S
字號:
;********************************************************************************************************
;                                               uC/OS-II
;                                         The Real-Time Kernel
;
;                               (c) Copyright 1992-2004, Micrium, Weston, FL
;                                          All Rights Reserved
;
;                                           Generic ARM Port
;
; File      : OS_CPU_A.ASM
; Version   : V1.60
; By        : Jean J. Labrosse
;
; For       : ARM7 or ARM9
; Mode      : ARM or Thumb
; Toolchain : ARM Developer Suite Version 1.2 and higher
;********************************************************************************************************

            IMPORT  OSRunning                    ; External references
            IMPORT  OSPrioCur
            IMPORT  OSPrioHighRdy
            IMPORT  OSTCBCur
            IMPORT  OSTCBHighRdy
            IMPORT  OSIntNesting
            IMPORT  OSIntExit
            IMPORT  OSTaskSwHook
            IMPORT  OSTimeTickISRHandler
            IMPORT  OSTimeTick


            EXPORT  OS_CPU_SR_Save               ; Functions declared in this file
            EXPORT  OS_CPU_SR_Restore
            EXPORT  OSStartHighRdy               
            EXPORT  OSCtxSw
            EXPORT  OSIntCtxSw
            EXPORT  OSTimeTickISR


NO_INT      EQU     0xC0                         ; Mask used to disable interrupts (Both FIR and IRQ)
SVC32_MODE  EQU     0x13
FIQ32_MODE  EQU     0x11
IRQ32_MODE  EQU     0x12

            AREA    |.text|,CODE

            CODE32

;*********************************************************************************************************
;                                   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.
;
; Prototypes :     OS_CPU_SR  OS_CPU_SR_Save(void);
;                  void       OS_CPU_SR_Restore(OS_CPU_SR cpu_sr);
;
;
; Note(s)    : 1) These functions are used in general like this:
;
;                 void Task (void *p_arg)
;                 {
;                 #if OS_CRITICAL_METHOD == 3          /* Allocate storage for CPU status register */
;                     OS_CPU_SR  cpu_sr;
;                 #endif
;
;                          :
;                          :
;                     OS_ENTER_CRITICAL();             /* cpu_sr = OS_CPU_SaveSR();                */
;                          :
;                          :
;                     OS_EXIT_CRITICAL();              /* OS_CPU_RestoreSR(cpu_sr);                */
;                          :
;                          :
;                 }
;
;              2) OS_CPU_SaveSR() is implemented as recommended by Atmel's application note:
;
;                    "Disabling Interrupts at Processor Level"
;*********************************************************************************************************

OS_CPU_SR_Save
        MRS     R0,CPSR                     ; Set IRQ and FIQ bits in CPSR to disable all interrupts
        ORR     R1,R0,#NO_INT
        MSR     CPSR_c,R1
        MRS     R1,CPSR                     ; Confirm that CPSR contains the proper interrupt disable flags
        AND     R1,R1,#NO_INT
        CMP     R1,#NO_INT
        BNE     OS_CPU_SR_Save              ; Not properly disabled (try again)
        BX      LR                          ; Disabled, return the original CPSR contents in R0

OS_CPU_SR_Restore
        MSR     CPSR_c,R0
        BX      LR

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

OSStartHighRdy

        MSR     CPSR_c, #0xD3           ; Switch to SVC mode with IRQ and FIQ disabled

        LDR     R0, =OSTaskSwHook       ; OSTaskSwHook();
        MOV     LR, PC
        BX      R0            

        LDR     R4, =OSRunning          ; OSRunning = TRUE
        MOV     R5, #1
        STRB    R5, [R4]

                                        ; SWITCH TO HIGHEST PRIORITY TASK
        LDR     R4, =OSTCBHighRdy       ;    Get highest priority task TCB address
        LDR     R4, [R4]                ;    get stack pointer
        LDR     SP, [R4]                ;    switch to the new stack

        LDR     R4,  [SP], #4           ;    pop new task's CPSR
        MSR     SPSR_cxsf,R4
        LDMFD   SP!, {R0-R12,LR,PC}^    ;    pop new task's context

;*********************************************************************************************************
;                         PERFORM A CONTEXT SWITCH (From task level) - OSCtxSw()
;
; Note(s) : 1) OSCtxSw() is called in SYS mode with BOTH FIQ and IRQ interrupts DISABLED
;
;           2) The pseudo-code for OSCtxSw() is:
;              a) Save the current task's context onto the current task's stack
;              b) OSTCBCur->OSTCBStkPtr = SP;
;              c) OSTaskSwHook();
;              d) OSPrioCur             = OSPrioHighRdy;
;              e) OSTCBCur              = OSTCBHighRdy;
;              f) SP                    = OSTCBHighRdy->OSTCBStkPtr;
;              g) Restore the new task's context from the new task's stack
;              h) 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
;*********************************************************************************************************

OSCtxSw
                                        ; SAVE CURRENT TASK'S CONTEXT
        STMFD   SP!, {LR}               ;     Push return address
        STMFD   SP!, {LR}
        STMFD   SP!, {R0-R12}           ;     Push registers
        MRS     R4,  CPSR               ;     Push current CPSR
        TST     LR, #1                  ;     See if called from Thumb mode
        ORRNE   R4,  R4, #0x20          ;     If yes, Set the T-bit
        STMFD   SP!, {R4}
        
        LDR     R4, =OSTCBCur           ; OSTCBCur->OSTCBStkPtr = SP;
        LDR     R5, [R4]
        STR     SP, [R5]

        LDR     R0, =OSTaskSwHook       ; OSTaskSwHook();
        MOV     LR, PC
        BX      R0            

        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
        LDMFD   SP!, {R4}               ;    Pop new task's CPSR
        MSR     SPSR_cxsf, R4
        
        LDMFD   SP!, {R0-R12,LR,PC}^    ;    Pop new task's context

;*********************************************************************************************************
;                   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
;*********************************************************************************************************

OSIntCtxSw
        LDR     R0, =OSTaskSwHook       ; OSTaskSwHook();
        MOV     LR, PC
        BX      R0            

        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
        LDMFD   SP!, {R4}               ;    Pop new task's CPSR
        MSR     SPSR_cxsf, R4
        
        LDMFD   SP!, {R0-R12,LR,PC}^    ;    Pop new task's context

;*********************************************************************************************************
;                                Time Tick IRQ Interrupt Service Routine
;*********************************************************************************************************

OSTimeTickISR

        STMFD   SP!, {R1-R3}                   ; PUSH WORKING REGISTERS ONTO IRQ STACK                     
        
        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 | SVC32_MODE) ; Change to SVC mode

                                               ; SAVE TASK'S CONTEXT ONTO TASK'S STACK
        STMFD   SP!, {R2}                      ;    Push task's Return PC
        STMFD   SP!, {LR}                      ;    Push task's LR
        STMFD   SP!, {R4-R12}                  ;    Push task's R12-R4
        
        LDMFD   R1!, {R4-R6}                   ;    Move task's R1-R3 from IRQ stack to SVC 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_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)
        
        LDR     R0, =OSTimeTickISRHandler      ; OSTimeTickISRHandler();
        MOV     LR, PC
        BX      R0

        LDR     R0, =OSTimeTick                ; OSTimeTick();
        MOV     LR, PC
        BX      R0

        MSR     CPSR_c, #(NO_INT | SVC32_MODE) ; Change to SVC mode
        
        LDR     R0, =OSIntExit                 ; OSIntExit();
        MOV     LR, PC
        BX      R0            
        
                                               ; RESTORE NEW TASK'S CONTEXT
        LDMFD   SP!, {R4}                      ;    Pop new task's CPSR
        MSR     SPSR_cxsf, R4
        
        LDMFD   SP!, {R0-R12,LR,PC}^           ;    Pop new task's context

        END

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美韩日一区二区三区| 国产一级精品在线| 国产一区二区三区在线观看免费| 国产精品 欧美精品| 成人午夜av电影| 8x8x8国产精品| 综合色天天鬼久久鬼色| 精品一区二区在线看| 欧美日韩视频在线观看一区二区三区 | 国产精品 欧美精品| 欧美日韩综合色| 亚洲私人影院在线观看| 国产精品白丝jk白祙喷水网站| 欧美电影在线免费观看| 亚洲人成7777| 成人黄色在线看| 精品成人免费观看| 蜜桃久久久久久久| 91精品黄色片免费大全| 亚洲高清不卡在线观看| 91成人免费电影| 亚洲女人的天堂| 一本久久综合亚洲鲁鲁五月天| 国产亚洲欧美一级| 国产精品一区2区| 欧美激情一区二区三区蜜桃视频| 开心九九激情九九欧美日韩精美视频电影 | 国产色综合久久| 国内成人自拍视频| 日韩欧美你懂的| 激情欧美一区二区三区在线观看| 欧美一卡2卡3卡4卡| 亚洲妇女屁股眼交7| 欧美视频自拍偷拍| 亚洲一区二区三区美女| 欧美日韩三级在线| 偷偷要91色婷婷| 欧美日韩不卡一区二区| 日韩精品一卡二卡三卡四卡无卡| 51精品久久久久久久蜜臀| 日韩精品1区2区3区| 日韩欧美国产1| 国内精品伊人久久久久av影院 | 91精品国产91久久久久久一区二区| 亚洲一区二区三区自拍| 91精品黄色片免费大全| 青娱乐精品在线视频| 久久久久久久久免费| 99热在这里有精品免费| 亚洲精选视频在线| 在线不卡免费av| 国内精品免费**视频| 国产精品沙发午睡系列990531| a美女胸又www黄视频久久| 亚洲午夜日本在线观看| 欧美一级片在线| 国产一区二区在线电影| 中文久久乱码一区二区| 欧洲av一区二区嗯嗯嗯啊| 毛片一区二区三区| 中文字幕成人av| 在线成人免费视频| 豆国产96在线|亚洲| 一区二区欧美视频| 日韩欧美一区二区在线视频| 国产精品一二三四区| 尤物av一区二区| 精品少妇一区二区三区免费观看| 国产成人高清在线| 亚洲成人免费电影| 国产无遮挡一区二区三区毛片日本| 色偷偷久久一区二区三区| 椎名由奈av一区二区三区| 成人动漫av在线| 日产欧产美韩系列久久99| 中文字幕一区二区三区精华液| 在线播放视频一区| 成人高清视频在线观看| 麻豆精品视频在线观看免费| 亚洲情趣在线观看| 精品福利一区二区三区免费视频| 欧洲视频一区二区| 国产精品一级在线| 奇米四色…亚洲| 亚洲综合色噜噜狠狠| 久久精品夜色噜噜亚洲a∨| 91麻豆精品国产91久久久资源速度| 成人丝袜18视频在线观看| 久久精品国产99国产精品| 亚洲一区av在线| 国产精品成人在线观看| 国产亚洲精品aa| 精品国产乱码久久久久久老虎| 91国偷自产一区二区使用方法| 国产成人午夜精品5599| 国产麻豆一精品一av一免费| 日韩av一区二区在线影视| 亚洲一二三四区| 亚洲美女精品一区| 亚洲免费在线看| 亚洲欧洲无码一区二区三区| 国产欧美日韩综合精品一区二区| 欧美成人免费网站| 在线不卡中文字幕| 欧美日韩大陆一区二区| 欧美三级三级三级爽爽爽| 色婷婷综合久色| 在线观看精品一区| 日本道免费精品一区二区三区| 91麻豆蜜桃一区二区三区| 粉嫩嫩av羞羞动漫久久久| 国产黄色精品视频| 国产精品羞羞答答xxdd| 国产乱人伦偷精品视频免下载| 久久精品国产亚洲5555| 国产在线精品一区二区不卡了| 免费精品视频最新在线| 麻豆久久一区二区| 久久99久久99小草精品免视看| 免费观看在线色综合| 精品一区二区久久| 国产一区二区免费在线| 丁香六月久久综合狠狠色| 成人毛片视频在线观看| 91麻豆国产福利在线观看| 欧美色图在线观看| 911国产精品| 欧美精品一区二| 欧美国产精品中文字幕| 亚洲精品美国一| 亚洲成a人在线观看| 欧美aaa在线| 国产乱码字幕精品高清av| 成人av电影免费在线播放| 在线视频一区二区免费| 欧美一区二区在线看| 久久日韩精品一区二区五区| 中文字幕在线观看不卡视频| 一区二区三区产品免费精品久久75| 污片在线观看一区二区| 国产成人久久精品77777最新版本| 波多野结衣中文字幕一区二区三区| 91在线高清观看| 欧美日韩成人综合天天影院| 精品1区2区在线观看| 成人免费视频在线观看| 亚洲高清在线视频| 国产 欧美在线| 在线观看免费视频综合| 久久亚区不卡日本| 夜夜嗨av一区二区三区中文字幕| 精品一区二区三区免费观看| av一区二区三区在线| 日韩欧美你懂的| 亚洲欧美激情插 | 亚洲va欧美va人人爽午夜| 韩国av一区二区三区| 色婷婷综合久久久中文一区二区 | 91超碰这里只有精品国产| 国产丝袜欧美中文另类| 五月婷婷综合在线| 国产99久久久久久免费看农村| 欧美午夜免费电影| 中文字幕乱码亚洲精品一区| 日韩精品久久久久久| 91影院在线免费观看| 精品国精品国产| 午夜精品一区二区三区免费视频| 成人自拍视频在线观看| 日韩视频永久免费| 亚洲中国最大av网站| 粉嫩嫩av羞羞动漫久久久| 日韩一级片网址| 亚洲h精品动漫在线观看| 99视频一区二区| 日本一区二区视频在线观看| 开心九九激情九九欧美日韩精美视频电影| 91啪亚洲精品| 国产精品国产三级国产普通话99| 久久国产精品99精品国产| 欧美美女黄视频| 亚洲国产乱码最新视频| 一本大道久久a久久综合| 国产午夜精品理论片a级大结局| 精品一区二区三区在线播放视频| 在线播放中文一区| 亚洲成人你懂的| 欧美午夜精品久久久久久孕妇| 中文字幕中文字幕一区二区| 国产盗摄精品一区二区三区在线| 日韩免费高清电影| 美女在线一区二区| 91麻豆精品国产91久久久使用方法| 亚洲第一福利视频在线| 色8久久人人97超碰香蕉987| 亚洲欧美电影一区二区| 色哟哟精品一区| 亚洲综合免费观看高清完整版在线| 欧洲亚洲精品在线| 亚洲成人久久影院|