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

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

?? os_cpu_a.s

?? uc/os的多任務處理。20ms間隔
?? S
字號:
;*
;* File: os_cpu_a.s
;*
;*            (c) Copyright ARM Limited 1999.  All rights reserved. 
;*
;*                               ARM Specific code
;*
;*
; 
;	Functions defined in this module:
;
;	void ARMDisableInt(void)	/* disable interrupts when in SVC */
;	void ARMEnableInt(void)		/* enable interrupts when in SVC */
;	void OS_TASK_SWAP(void)		/* context switch */
;	void OSStartHighRdy(void)	/* start highest priority task */

SwiV		EQU	0x08
IrqV		EQU	0x18
FiqV		EQU	0x1C
NoInt		EQU	0x80

SVC32Mode	EQU	0x13
IRQ32Mode	EQU	0x12
FIQ32Mode	EQU	0x11

OSEnterSWI	EQU	0x00


BIT_TIMER0	EQU		(0x1<<13)
I_ISPC		EQU		0x1e00024
INTMSK		EQU		0x1e0000c



	AREA	|subr|, CODE, READONLY;|subr|

	; External symbols we need the addresses of
			IMPORT	OSTCBCur      ;Current TCB pointer
addr_OSTCBCur		DCD	OSTCBCur  ;define 1 word for OSTCBCur's address
			IMPORT	OSTCBHighRdy  ;The TCB pointer of the Task which has the highest priority in the Ready Table
addr_OSTCBHighRdy	DCD	OSTCBHighRdy
			IMPORT	OSPrioCur
addr_OSPrioCur		DCD	OSPrioCur
			IMPORT	OSPrioHighRdy
addr_OSPrioHighRdy	DCD	OSPrioHighRdy

	IMPORT	need_to_swap_context
	IMPORT	IrqStart              ;IRQ
	IMPORT	OSTimeTick
	IMPORT	IrqFinish

	IMPORT	OutDebug
	IMPORT	BreakPoint
	
	EXPORT IRQContextSwap

IRQContextSwap
        LDMIA    sp!,{a1-v1, lr} ;the context in sp-->r0-r4,lr(r0-r4 maybe the para. for the routine)
        SUBS	 pc, lr, #4      ;pc=lr-4; it's a jump instruction,used to return from IRQ


        SUB             lr, lr, #4;lr=lr-4;
        MOV             r12, lr   ;r12=lr;

        MRS             lr, SPSR  ;lr=SPSR
		AND				lr, lr, #0xFFFFFFE0;clr the mode
		ORR				lr, lr, #0xD3      ;disable the interrupt and enter SVC mode
        MSR             CPSR_cxsf, lr      ;CPSR_cxsf=lr



	EXPORT	__Tick
__Tick
	STMDB    sp!,{r0-r11,lr}      ;=push  lr, r0-r11-->sp

	;interrupt disable(not nessary)
	mrs		r0, CPSR            ; r0=CPSR
	orr		r0, r0, #0x80		; and set IRQ disable flag
	msr		CPSR_cxsf, R0       ; CPSR_cxsf=R0
	
	;End of interrupt
	;(Clear pending bit of INTPEND that don't accessed it.)
	;	rI_ISPC= BIT_TIMER0;
	LDR	r0, =I_ISPC
	LDR	r1, =BIT_TIMER0;clr INT_TIMER0 pending bit
	STR	r1, [r0]       ;r1-->[r0]

	BL	IrqStart
	
	BL	OSTimeTick

	BL	IrqFinish

	
	LDR		r0, =need_to_swap_context
	LDR		r2, [r0]   ;ldr: memory to register,r2=need_to_swap_context
	CMP		r2, #1
	LDREQ	pc, =_CON_SW;if equal,then switch context

    EXPORT  _NOT_CON_SW

_NOT_CON_SW
	;not context switching
	LDMIA    sp!,{r0-r11, lr}
	SUBS	pc, lr, #4

    EXPORT  _CON_SW

_CON_SW
	;set need_to_swap_context is '0'
	MOV		r1, #0
	STR		r1, [r0]


	;now context switching
	LDMIA    sp!,{r0-r11,lr}  ;pop
	SUB		lr, lr, #4

	STR		lr, [pc, #SAVED_LR-.-8];???

	;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
	;Change Supervisor mode
	;!!!r12 register don't preserved. (r12 that PC of task)

        MRS             lr, SPSR            ;lr=SPSR
	AND		lr, lr, #0xFFFFFFE0 ;enable all IRQ FIQ
	ORR		lr, lr, #0x13
        MSR             CPSR_cxsf, lr       ;CPSR_cxsf

	;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
	;Now  Supervisor mode
	;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
	STR		r12, [sp, #-8]	; saved r12->sp-8
	LDR		r12, [pc, #SAVED_LR-.-8]
	STMFD	sp!, {r12}		; push r12 that PC of task under SVC mode
	SUB		sp, sp, #4		; inclease stack point
	LDMIA	sp!, {r12}		; restore r12
	
	STMFD	sp!, {lr}		; save lr (CPSR?)
	STMFD	sp!, {r0-r12}	; save register file and ret address
	MRS		r4, CPSR        ; r4=CPSR
	STMFD	sp!, {r4}		; save current PSR
	MRS		r4, SPSR		; YYY+
	STMFD	sp!, {r4}		; YYY+ save SPSR


	; OSPrioCur = OSPrioHighRdy
	LDR	r4, addr_OSPrioCur
	LDR	r5, addr_OSPrioHighRdy
	LDRB	r6, [r5]        ;[r5]->r6
	STRB	r6, [r4]        ;r6->[r4]
	
	; Get current task TCB address
	LDR	r4, addr_OSTCBCur   ;sp->OSTCBCur.OSTCBStkPtr; 
	LDR	r5, [r4]
	STR	sp, [r5]		    ; store sp in preempted tasks's TCB;sp->[r5]

	; Get highest priority task TCB address
	LDR	r6, addr_OSTCBHighRdy
	LDR	r6, [r6]
	LDR	sp, [r6]		    ; get new task's stack pointer;sp<-[r6]

	; OSTCBCur = OSTCBHighRdy
	STR	r6, [r4]		    ; set new current task TCB address

	LDMFD	sp!, {r4}		; YYY+                        ;pop r4
;	AND		r4, r4, #0xFFFFFF20
;	ORR		r4, r4, #0x13
	MSR	SPSR_cxsf, r4		; YYY+                        ;PSR=r4
	LDMFD	sp!, {r4}		; YYY+                        ;pop r4
;	AND		r4, r4, #0xFFFFFF20
;	ORR		r4, r4, #0x13
	MSR	CPSR_cxsf, r4		; YYY+                        ;CPSR_cxsf=r4
	LDMFD	sp!, {r0-r12, lr, pc}	; YYY+                ;pop to r0-r12,lr,pc


SAVED_LR		DCD		0


;	void DisableInt(void)
;	void EnableInt(void)
;
;	Disable and enable IRQ and FIQ preserving current CPU mode.
;
	EXPORT	ARMDisableInt
ARMDisableInt
	STMDB	sp!, {r0}
	MRS		r0, CPSR
	ORR		r0, r0, #NoInt
	MSR		CPSR_cxsf, r0
	LDMIA	sp!, {r0}
	MOV	pc, lr


	EXPORT	ARMEnableInt
ARMEnableInt
	STMDB	sp!, {r0}
	MRS	r0, CPSR
	BIC	r0, r0, #NoInt
	MSR	CPSR_cxsf, r0
	LDMIA	sp!, {r0}
	MOV	pc, lr



;	void OS_TASK_SW(void)  called by OSSched()
;	
;	Perform a context switch.
;
;	On entry, OSTCBCur and OSPrioCur hold the current TCB and priority
;	and OSTCBHighRdy and OSPrioHighRdy contain the same for the task
;	to be switched to.
;
;	The following code assumes that the virtual memory is directly
;	mapped into  physical memory. If this is not true, the cache must 
;	be flushed at context switch to avoid address aliasing.
	EXPORT	OS_TASK_SW
OS_TASK_SW
	STMFD	sp!, {lr}		; save pc
	STMFD	sp!, {lr}		; save lr
	STMFD	sp!, {r0-r12}	; save register file and ret address
	MRS	r4, CPSR
	STMFD	sp!, {r4}		; save current PSR
	MRS	r4, SPSR		; YYY+
	STMFD	sp!, {r4}		; YYY+ save SPSR

	; OSPrioCur = OSPrioHighRdy
	LDR	r4, addr_OSPrioCur
	LDR	r5, addr_OSPrioHighRdy
	LDRB	r6, [r5]
	STRB	r6, [r4]
	
	; Get current task TCB address
	LDR	r4, addr_OSTCBCur
	LDR	r5, [r4]
	STR	sp, [r5]		; store sp in preempted tasks's TCB

	; Get highest priority task TCB address
	LDR	r6, addr_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}		; YYY+
	MSR	SPSR_cxsf, r4		; YYY+
	LDMFD	sp!, {r4}		; YYY+
	MSR	CPSR_cxsf, r4		; YYY+
	LDMFD	sp!, {r0-r12, lr, pc}	; YYY+



;	void OSStartHighRdy(void)
;	
;	Start the task with the highest priority;
;
	EXPORT	OSStartHighRdy
OSStartHighRdy
	LDR	r4, addr_OSTCBCur	; Get current task TCB address
	LDR	r5, addr_OSTCBHighRdy	; Get highest priority task TCB address

	LDR	r5, [r5]		; get stack pointer
	LDR	sp, [r5]		; switch to the new stack

	STR	r5, [r4]		; set new current task TCB address

	LDMFD	sp!, {r4}		; YYY
	MSR	SPSR_cxsf, r4
	LDMFD	sp!, {r4}		; get new state from top of the stack
	MSR	CPSR_cxsf, r4		; CPSR should be SVC32Mode
	LDMFD	sp!, {r0-r12, lr, pc }	; start the new task

	END

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
不卡影院免费观看| 国产激情视频一区二区在线观看| 欧美激情综合五月色丁香小说| 欧美日本一区二区| 在线播放欧美女士性生活| 欧美偷拍一区二区| 欧美日本在线播放| 日韩限制级电影在线观看| 日韩你懂的电影在线观看| 亚洲精品一区二区三区福利| 日韩欧美中文一区| 久久精品一区二区| 国产精品大尺度| 亚洲男人的天堂在线观看| 亚洲激情自拍视频| 免费视频最近日韩| 国产在线视频一区二区三区| 国产 日韩 欧美大片| 99re这里只有精品视频首页| 色老头久久综合| 91精品国产综合久久蜜臀| 精品剧情在线观看| 国产精品久久久久一区二区三区| 亚洲天堂2014| 日本特黄久久久高潮| 国产一区二区三区| 在线精品视频免费播放| 欧美一区二区三区喷汁尤物| 26uuu亚洲| 一区二区三区在线观看欧美| 日本女人一区二区三区| 国产成人精品综合在线观看 | 国产精品久久福利| 亚洲精品国产品国语在线app| 婷婷开心激情综合| 国产suv精品一区二区6| 色就色 综合激情| 日韩久久免费av| 中文字幕一区二区三区在线播放| 婷婷六月综合亚洲| 成人精品在线视频观看| 91精品国产综合久久久久久| 国产精品理论在线观看| 男人操女人的视频在线观看欧美| 不卡视频在线看| 日韩一卡二卡三卡四卡| 亚洲精品视频在线| 国产精品影视在线观看| 欧美日韩成人激情| 综合久久久久综合| 国产精品亚洲午夜一区二区三区| 日本高清无吗v一区| 欧美国产日本视频| 日韩成人免费电影| 欧美午夜视频网站| 成人免费在线观看入口| 国产一区二区三区av电影| 制服丝袜激情欧洲亚洲| 一区二区三区波多野结衣在线观看| 国产精品正在播放| 精品国产一区二区三区忘忧草 | 国产精品一区二区黑丝| 欧美麻豆精品久久久久久| 最新欧美精品一区二区三区| 国产盗摄一区二区| 精品福利一区二区三区免费视频| 亚洲国产成人av| 色94色欧美sute亚洲13| 亚洲欧美国产毛片在线| 丁香啪啪综合成人亚洲小说| 久久久精品免费观看| 精品中文字幕一区二区| 欧美成人三级在线| 捆绑紧缚一区二区三区视频| 日韩一区二区三区电影在线观看 | 制服丝袜在线91| 亚洲国产你懂的| 欧美三级蜜桃2在线观看| 亚洲色图在线视频| 色综合久久综合| 亚洲在线观看免费视频| 欧美午夜片在线观看| 亚洲va韩国va欧美va精品| 欧美日韩视频不卡| 天堂在线亚洲视频| 欧美成人bangbros| 国产一区二区主播在线| 久久九九久久九九| 99久久99精品久久久久久| 亚洲蜜桃精久久久久久久| 在线观看视频一区二区欧美日韩| 亚洲va天堂va国产va久| 日韩欧美在线一区二区三区| 国产麻豆视频精品| 国产精品久久久久婷婷二区次| www.视频一区| 亚洲国产一区二区a毛片| 日韩一区二区高清| 成人午夜看片网址| 亚洲精品美国一| 欧美一级欧美一级在线播放| 国产精品996| 亚洲成a人v欧美综合天堂| 欧美www视频| 99精品欧美一区二区三区小说 | 国产精品丝袜91| 日本韩国欧美一区二区三区| 日本不卡高清视频| 日本一区二区视频在线观看| 欧美色电影在线| 国产精品亚洲专一区二区三区| 亚洲精品久久久久久国产精华液| 欧美草草影院在线视频| 91在线观看免费视频| 免费在线观看一区| 综合色天天鬼久久鬼色| 日韩片之四级片| 日本道色综合久久| 国产一区二区按摩在线观看| 亚洲另类春色校园小说| 欧美大胆人体bbbb| 91日韩在线专区| 韩国精品主播一区二区在线观看 | 久久久天堂av| 欧美私模裸体表演在线观看| 国产成人免费av在线| 男人操女人的视频在线观看欧美| 亚洲少妇最新在线视频| 久久久久久久久一| 欧美二区在线观看| 色婷婷av一区二区三区之一色屋| 国产麻豆日韩欧美久久| 日韩avvvv在线播放| 亚洲国产综合在线| 亚洲天天做日日做天天谢日日欢| 久久天堂av综合合色蜜桃网| 777久久久精品| 欧美日韩精品一区二区| 一本久久a久久精品亚洲| 粉嫩在线一区二区三区视频| 狠狠色丁香婷综合久久| 亚州成人在线电影| 亚洲第一主播视频| 亚洲福利国产精品| 亚洲精品日产精品乱码不卡| 亚洲婷婷综合色高清在线| 中文字幕在线一区二区三区| 国产亚洲精品aa午夜观看| 欧美成人欧美edvon| 久久综合av免费| 久久嫩草精品久久久久| 久久久天堂av| 国产欧美日韩精品一区| 精品国产乱码久久久久久蜜臀| 欧美一区二区久久久| 91精品国产91综合久久蜜臀| 欧美精品亚洲二区| 91精品国产一区二区| 69堂国产成人免费视频| 7777精品伊人久久久大香线蕉的| 欧美二区乱c少妇| 日韩精品在线一区二区| 精品美女一区二区三区| 久久先锋资源网| 欧美国产乱子伦| 亚洲视频综合在线| 一区二区三区丝袜| 日韩高清不卡在线| 狠狠v欧美v日韩v亚洲ⅴ| 国产精品自在在线| 一本大道久久a久久精二百| 91黄视频在线观看| 91精品国产一区二区三区蜜臀 | 中文字幕五月欧美| 一区二区成人在线| 日韩av一区二区在线影视| 国产精品91一区二区| 色婷婷av一区二区三区软件| 欧美精选午夜久久久乱码6080| 精品日韩欧美在线| 国产精品国产三级国产专播品爱网 | 久久超级碰视频| 国产精选一区二区三区| 91丨九色丨蝌蚪丨老版| 日韩欧美激情一区| 国产精品国产三级国产aⅴ入口 | 国产亚洲精品aa| 亚洲精品高清在线| 久久精品国产精品亚洲红杏| jvid福利写真一区二区三区| 欧美日本在线看| 国产精品久久久久天堂| 亚洲成av人片在线观看无码| 国产高清不卡一区二区| 欧美日韩综合在线免费观看| 中文av一区特黄| 麻豆91在线看| 99精品视频在线观看免费| 亚洲一区二区三区四区不卡| 亚洲精品你懂的|