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

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

?? os_cpu_a.s

?? 三星44b0上面的一個ucos程序,可在ads1.2下面編譯通過
?? 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一区二区三区免费野_久草精品视频
久久久天堂av| 7777精品伊人久久久大香线蕉 | 欧美成人精精品一区二区频| 99精品视频一区二区| 99天天综合性| 91蜜桃传媒精品久久久一区二区| 丁香另类激情小说| 高清久久久久久| 91视频在线看| 色女孩综合影院| 欧美日韩一区中文字幕| 欧美精品一卡两卡| 欧美一区二区视频网站| 日韩欧美一卡二卡| 日本一区二区视频在线观看| 国产精品久久久久久久久免费桃花 | 久久午夜色播影院免费高清| 亚洲色图欧洲色图婷婷| 1区2区3区精品视频| 一区二区三区日韩精品视频| 午夜精品久久久久久久久久| 日韩国产欧美在线播放| 久久成人久久爱| 成人美女在线观看| 在线一区二区三区四区五区| 9191精品国产综合久久久久久| 91精品国产一区二区三区蜜臀| 日韩欧美国产电影| 欧美激情艳妇裸体舞| 一区二区三区日韩精品| 免费视频一区二区| zzijzzij亚洲日本少妇熟睡| 91国产丝袜在线播放| 日韩精品影音先锋| 中文字幕一区二区三区不卡| 亚洲国产日韩一区二区| 国产主播一区二区三区| 在线免费亚洲电影| 欧美精品一区二区三| 亚洲另类中文字| 国产在线视频精品一区| 色88888久久久久久影院野外| 欧美va日韩va| 一区二区欧美在线观看| 国产福利91精品一区| 欧美亚洲一区二区在线观看| 久久久久久毛片| 亚洲1区2区3区4区| 99re热这里只有精品视频| 欧美mv日韩mv| 无吗不卡中文字幕| caoporn国产一区二区| 精品国产一区二区三区av性色| 亚洲人成网站在线| 高清不卡一二三区| 精品久久久久香蕉网| 亚洲va韩国va欧美va| 91麻豆.com| 国产精品国产三级国产| 国产一区在线视频| 欧美成人一级视频| 蜜臀av国产精品久久久久| 欧美天堂亚洲电影院在线播放| 国产精品久久久久久久久免费丝袜 | 日本不卡视频在线观看| 欧美天堂亚洲电影院在线播放| 国产精品国产自产拍高清av| 经典一区二区三区| 欧美成人乱码一区二区三区| 日韩电影一区二区三区四区| 欧美日韩视频在线观看一区二区三区 | 欧美一区永久视频免费观看| 一区二区三区电影在线播| 91视频你懂的| 亚洲靠逼com| 欧美午夜精品一区二区三区| 亚洲激情六月丁香| 欧美在线制服丝袜| 亚洲一区二区三区四区在线| 欧美在线free| 亚欧色一区w666天堂| 欧美午夜电影网| 午夜一区二区三区在线观看| 欧美日韩中文一区| 同产精品九九九| 日韩视频一区二区三区在线播放| 日本欧美韩国一区三区| 日韩欧美激情四射| 国产精品一级二级三级| 亚洲天堂中文字幕| 欧美日韩国产a| 久久综合综合久久综合| 久久久99精品久久| 99国产精品国产精品毛片| 一区二区欧美国产| 欧美一区二区三区性视频| 国产一区激情在线| 椎名由奈av一区二区三区| 欧美在线小视频| 麻豆国产欧美一区二区三区| 国产日产欧美一区| 欧美最新大片在线看| 免费视频一区二区| 国产精品激情偷乱一区二区∴| 91在线无精精品入口| 日韩电影在线一区二区三区| 久久久精品影视| 91国产免费看| 狠狠色狠狠色综合日日91app| 国产精品区一区二区三区| 在线观看日产精品| 极品美女销魂一区二区三区| 综合在线观看色| 91麻豆精品国产91久久久久久久久 | 亚洲成人一二三| 久久久久久久免费视频了| 欧美在线999| 不卡一卡二卡三乱码免费网站| 亚洲香蕉伊在人在线观| 精品国产第一区二区三区观看体验| 91在线高清观看| 九九精品一区二区| 亚洲激情男女视频| 国产午夜精品一区二区三区视频 | 久久久久久久久99精品| 欧美最新大片在线看| 国产成人在线免费| 日本欧美加勒比视频| 日韩毛片视频在线看| 26uuu亚洲综合色| 91精品国产麻豆| 欧美综合一区二区三区| 成熟亚洲日本毛茸茸凸凹| 免费成人在线网站| 亚洲国产另类精品专区| 成人免费一区二区三区视频| 久久精品免费在线观看| 精品蜜桃在线看| 91精品国产一区二区三区香蕉| 91黄视频在线| 色综合天天综合| 91麻豆国产福利在线观看| 不卡一二三区首页| 成人国产在线观看| av影院午夜一区| 成人av小说网| av中文字幕不卡| 99国产精品久久久久久久久久久| 国产99久久久国产精品免费看| 精品一区二区三区在线观看国产| 首页欧美精品中文字幕| 日韩精品电影在线| 日本不卡高清视频| 蜜桃av一区二区三区电影| 日本亚洲免费观看| 免费av网站大全久久| 免费高清视频精品| 国产乱人伦精品一区二区在线观看| 麻豆精品在线视频| 国模冰冰炮一区二区| 国产一区二区不卡老阿姨| 国产福利一区二区| 波多野结衣的一区二区三区| 91在线高清观看| 欧美色图激情小说| 欧美人妇做爰xxxⅹ性高电影| 欧美精品乱码久久久久久按摩| 7777女厕盗摄久久久| 日韩女优av电影在线观看| ww亚洲ww在线观看国产| 国产精品网站在线播放| |精品福利一区二区三区| 亚洲自拍另类综合| 日本视频一区二区| 国产黄人亚洲片| 欧美在线制服丝袜| 日韩一级二级三级| 国产日韩欧美不卡在线| 亚洲免费观看高清完整版在线观看 | 中文av一区二区| 亚洲精品中文在线| 蜜桃av一区二区| 成人高清免费观看| 欧美肥胖老妇做爰| 中文字幕免费不卡在线| 亚洲国产综合色| 国产成人免费9x9x人网站视频| 成人一区二区三区在线观看| 在线视频欧美精品| 久久免费偷拍视频| 亚洲国产精品一区二区久久 | 99re这里都是精品| 欧美一区二区三区免费大片| 国产精品全国免费观看高清| 午夜视频在线观看一区二区| 国产高清在线精品| 欧美一区二区三区免费视频 | 亚洲高清中文字幕| 处破女av一区二区| 日韩一级视频免费观看在线|