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

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

?? os_cpu_a.asm

?? ucos-ii在80c52的實(shí)施指南與實(shí)例
?? ASM
字號(hào):
; os_cpu_a.asm 
;
; Port of uC/OS-II (C) to the Intel 80x86 (32-bit flat protected mode)
; By Jean L. Gareau (jean.gareau@exposecorp.com)
;
; Copyright (C) 1997-1999, Jean L. Gareau. All rights reserved. 
; This file or its content can not be used for commercial applications 
; without the prior written permission of the author.
; 
; Description:
;	This file contains the assembly language routines of the port 
;	(see os_cpu_c.c for the C routines). A full description of the port 
;	can be found in Port86pm.doc. Although most of this routines could be 
;	embedded in os_cpu_c.c under Visual C++ 6.0, some compilers do not 
;	support this feature. Thus, all the assembly code is in this file.
;
;	The implementation has been upgraded from the initial port (to uC/OS).
;	Comments have been added to reflects the pseudo-code provided in 
;	Chapter 10 of the uC/OS-II book.
;
;	Compared to the real mode implementation found in the uC/OS-II book,
;	the most important differences are:
;		a) 32-bit intructions are always used instead of 16-bit;
;		b) There is no segment to worry about.
;
; Development Environment:
;	This file has been developed with Microsoft Assembler 6.11 using the
;	following command:
;
;		ml /c /Fl /coff [/D_DEBUG] os_cpu_a.asm
;
;	The macro _DEBUG can be enabled to dump the stack of unexpected interrupts.
;	In that case, os_cpu_c.c must also be compiled with _DEBUG defined as well.
;
; Versions:
;	1.00 14-Dec-97	Initial release.
;	2.00 28-Feb-99	Upgrade from uC/OS to uC/OS-II
;	2.01 10-Nov-99	Adjusted the current priority in OSCtxSw() and OSIntCtxSw().

;	TITLE	os_cpu_a.asm
	.386P						; Priviledged instructions can be used.

; The following segments are expected by Microsoft's CL compiler.

_TEXT	SEGMENT PARA USE32 PUBLIC 'CODE'
_TEXT	ENDS
_DATA	SEGMENT DWORD USE32 PUBLIC 'DATA'
_DATA	ENDS
CONST	SEGMENT DWORD USE32 PUBLIC 'CONST'
CONST	ENDS
_BSS	SEGMENT DWORD USE32 PUBLIC 'BSS'
_BSS	ENDS
_TLS	SEGMENT DWORD USE32 PUBLIC 'TLS'
_TLS	ENDS

; Put all segment directives into one single group (flat memory model).

GFLAT	GROUP _TEXT, _DATA, CONST, _BSS
		ASSUME	CS: GFLAT, DS: GFLAT, ES: GFLAT, SS: GFLAT

_TEXT	SEGMENT

;=======================================================================
; uCOS-II Functions
;=======================================================================

;-----------------------------------------------------------------------
; OSTickISR
;-----------------------------------------------------------------------

PUBLIC	_OSTickISR
EXTRN	_OSIntEnter:NEAR
EXTRN	_OSTimeTick:NEAR
EXTRN	_OSIntExit:NEAR

_OSTickISR	PROC NEAR

		pushad

; Send an end-of-interrupt to the i8259.

		mov	al,20h
		out	20h,al

; Standard uCOS processing.

		call	_OSIntEnter
		call	_OSTimeTick
		call	_OSIntExit

		popad
		iretd

_OSTickISR ENDP

;-----------------------------------------------------------------------
; OSStartHighRdy
;-----------------------------------------------------------------------

PUBLIC	_OSStartHighRdy
EXTRN	_OSTaskSwHook:NEAR
EXTRN	_OSRunning:BYTE
EXTRN	_OSTCBHighRdy:DWORD

_OSStartHighRdy PROC NEAR


	; Call OSTaskSwHook();

		call	_OSTaskSwHook

	; Increment OSRunning by 1 (the documentation says to set it to 1,
	; but the ix86l example increments it).

		inc		[_OSRunning]

	; Load the processor stack pointer with OSTCBHighRdy->OSTCBStkPtr

		mov	eax,[_OSTCBHighRdy]	; Point to TCB of highest priority task ready to run
		mov	esp,[eax]			; ESP = OSTCBHighRdy->OSTCBStkPtr

	; Pop all the processor registers from the stack

		popad

	; Execute a Return from interrupt intruction;

		iretd

_OSStartHighRdy ENDP

;-----------------------------------------------------------------------
; OSCtxSw
;-----------------------------------------------------------------------

PUBLIC	_OSCtxSw
EXTRN	_OSTCBCur:DWORD
EXTRN	_OSTaskSwHook:NEAR
EXTRN	_OSPrioHighRdy:BYTE
EXTRN	_OSPrioCur:BYTE
EXTRN	_OSTCBHighRdy:DWORD

_OSCtxSw	PROC NEAR

	; PUSH processor registers onto the current task's stack

		pushad

	; Save the stack pointer into OSTCBCur->OSTCBStkPtr

		mov	eax,[_OSTCBCur]
		mov	[eax],esp			; Stack pointer is ESP

	; Call OSTaskSwHook();

		call	_OSTaskSwHook

	; OSPrioCur = OSPrioHighRdy

		mov	al,[_OSPrioHighRdy] ; AL is OSPrioHighRdy
		mov	[_OSPrioCur],al

	; OSTCBCur = OSTCBHighRdy

		mov	eax,[_OSTCBHighRdy]	; EAX is OSTCBHighRdy
		mov	[_OSTCBCur],eax

	; Load the processor stack pointer with OSTCBHighRdy->OSTCBStkPtr
	; Note that EAX is still OSTCBHighRdy.

		mov	esp,[eax]			; ESP = OSTCBHighRdy->OSTCBStkPtr

	; Pop all the processor registers from the stack

		popad

	; Execute a Return from interrupt intruction;

		iretd

_OSCtxSw	ENDP

;-----------------------------------------------------------------------
; OSIntCtxSw
;-----------------------------------------------------------------------

PUBLIC	_OSIntCtxSw
EXTRN	_OSTCBCur:DWORD
EXTRN	_OSTaskSwHook:NEAR
EXTRN	_OSPrioHighRdy:BYTE
EXTRN	_OSPrioCur:BYTE
EXTRN	_OSTCBHighRdy:DWORD

_OSIntCtxSw PROC NEAR

	; Adjust the stack pointer to remove call to OsIntExit(), locals in 
	; OsIntExit() and the call to OSIntCtxSw();

;IFDEF _SAVE_INT_STATUS
		add	esp,12			; Ignore calls to OSIntExit, PUSHFD and OSIntCtxSw
;ELSE
;		add	esp,8			; Ignore calls to OSIntExit and OSIntCtxSw
;ENDIF

	; Save the stack pointer into OSTCBCur->OSTCBStkPtr

		mov	eax,[_OSTCBCur]
		mov	[eax],esp			; Stack pointer is ESP

	; Call OSTaskSwHook();

		call	_OSTaskSwHook

	; OSPrioCur = OSPrioHighRdy

		mov	al,[_OSPrioHighRdy] ; AL is OSPrioHighRdy
		mov	[_OSPrioCur],al

	; OSTCBCur = OSTCBHighRdy

		mov	eax,[_OSTCBHighRdy]	; EAX is OSTCBHighRdy
		mov	[_OSTCBCur],eax

	; Load the processor stack pointer with OSTCBHighRdy->OSTCBStkPtr
	; Note that EAX is still OSTCBHighRdy.

		mov	esp,[eax]			; ESP = OSTCBHighRdy->OSTCBStkPtr

	; Pop all the processor registers from the stack

		popad

	; Execute a Return from interrupt intruction;

		iretd

_OSIntCtxSw ENDP

;=======================================================================
; x86 Helper Functions.
;=======================================================================

;-----------------------------------------------------------------------
; void DefIntHandler();
;
; Default interrupt handler. It simply performs an interrupt return.
; It is required to initialize all interrupt entries in the IDT.
;-----------------------------------------------------------------------

PUBLIC		_DefIntHandler

_DefIntHandler	PROC NEAR

		iretd				; Simply return from interrupt.

_DefIntHandler	ENDP

;-----------------------------------------------------------------------
; void DumpStackHandler();
;
; This is usefull handler that dumps the last three DWORDS pushed
; on the stack. This is convenient in a fault handler to determine the
; source of the fault. The function never returns.
;
; _DEBUG must be defined for this code to be effective.
;-----------------------------------------------------------------------

IFDEF _DEBUG

PUBLIC		_DumpStackHandler
EXTERN		_ShowRegister:NEAR

_DumpStackHandler PROC NEAR

		mov	eax,[esp]		; EAX: last pushed DWORD
		push	eax				
		call	_ShowRegister		; Show it
		add	esp,4

		mov	eax,[esp+4]		; EAX: previous pushed DWORD
		push	eax
		call	_ShowRegister		; Show it
		add	esp,4

		mov	eax,[esp+8]		; EAX: 2nd previous pushed DWORD
		push	eax
		call	_ShowRegister
		add	esp,4

; Enter an infinite loop. It is likely that things went wrong and
; continuing could reset the PC, losing whatever is on the screen.

Here:
		jmp	Here

_DumpStackHandler ENDP

ENDIF

;-----------------------------------------------------------------------
; UBYTE inportb(UWORD PortNo);
;
; Reads a byte from the specified port. The byte is returned in AL,
; since Microsoft CL uses EAX for returned values.
;-----------------------------------------------------------------------

PUBLIC		_inportb

_inportb	PROC NEAR

		push	ebp
		mov	ebp,esp

		push	edx

		mov	edx,[ebp+8]		; EDX: Port No
		in	al,dx			; Input the value.

		pop	edx

		pop	ebp
		ret				; AL contains the value to return.

_inportb	ENDP

;-----------------------------------------------------------------------
; void outportb(UWORD PortNo, UBYTE Value);
;
; Write a value to a specified port.
;-----------------------------------------------------------------------

PUBLIC		_inportb

_outportb	PROC NEAR

		push	ebp
		mov	ebp,esp

		push	eax
		push	edx

		mov	dx,[ebp+8]		; Get the port.
		mov	al,[ebp+12]		; Get the value.
		out	dx,al			; Output the value to the port.

		pop	edx
		pop	eax

		pop	ebp
		ret

_outportb	ENDP

_TEXT		ENDS
		END

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久草热8精品视频在线观看| 国产很黄免费观看久久| 亚洲一级片在线观看| 亚洲视频狠狠干| 国产精品入口麻豆原神| 国产日韩精品一区| 国产亚洲女人久久久久毛片| 亚洲精品在线观| 欧美精品一区二区蜜臀亚洲| 精品少妇一区二区三区视频免付费| 91精品国产色综合久久ai换脸| 91麻豆精品国产| 日韩一二三四区| 亚洲午夜精品网| 亚洲美女视频在线观看| 亚洲免费高清视频在线| 一区二区三区波多野结衣在线观看| 亚洲精品免费电影| 亚洲成人自拍一区| 蓝色福利精品导航| 国产一区二区0| www..com久久爱| 91在线国产观看| 欧美调教femdomvk| 欧美一区二区三区播放老司机| 日韩欧美成人一区| 国产精品美女久久久久久| 亚洲欧美日韩久久| 丝袜脚交一区二区| 国产一区美女在线| eeuss鲁片一区二区三区在线观看| 99久久精品国产一区二区三区 | 欧美日韩在线三级| 欧美一区二区精品久久911| 精品国产一区二区三区av性色| 久久久精品人体av艺术| 亚洲色图欧洲色图| 青青草成人在线观看| 国产精品自拍一区| 91福利精品第一导航| 欧美一区二区在线播放| 久久精品日产第一区二区三区高清版| 日韩美女视频一区二区| 亚洲bt欧美bt精品| 成人一二三区视频| 欧美剧情电影在线观看完整版免费励志电影 | 91丨国产丨九色丨pron| 欧美精选在线播放| 久久亚洲精品国产精品紫薇| 国产精品传媒视频| 麻豆成人免费电影| 一本大道综合伊人精品热热| 日韩欧美中文字幕一区| 亚洲丝袜另类动漫二区| 麻豆精品精品国产自在97香蕉| 成人精品亚洲人成在线| 538prom精品视频线放| 国产精品久久久久久户外露出 | 天堂久久一区二区三区| 国产成人综合网| 欧美日韩中字一区| 亚洲国产高清在线| 日日夜夜精品免费视频| av综合在线播放| 欧美精品一区二区三区视频| 亚洲综合久久久久| 国产成人av一区二区三区在线| 欧美性一区二区| 国产精品欧美一级免费| 捆绑变态av一区二区三区| 日本精品视频一区二区| 久久久99精品免费观看不卡| 视频一区二区中文字幕| 91香蕉视频mp4| 久久久国产午夜精品| 日韩精品成人一区二区三区| 97久久超碰国产精品电影| 久久在线观看免费| 日韩av不卡一区二区| 91色九色蝌蚪| 国产精品天天看| 狠狠久久亚洲欧美| 91精品在线观看入口| 一区二区免费视频| 成人av在线影院| 国产欧美日韩精品一区| 精品一区二区三区影院在线午夜| 欧美日韩色综合| 亚洲一区影音先锋| 91丝袜美腿高跟国产极品老师 | 国产亚洲精品bt天堂精选| 免费在线观看一区| 欧美日韩国产综合草草| 伊人婷婷欧美激情| 91色乱码一区二区三区| 亚洲天堂免费看| av电影在线观看完整版一区二区| 国产偷国产偷精品高清尤物| 精品制服美女丁香| 欧美不卡激情三级在线观看| 日韩精品电影一区亚洲| 制服丝袜中文字幕亚洲| 日韩va亚洲va欧美va久久| 欧美私人免费视频| 亚洲国产精品一区二区久久恐怖片| 91麻豆国产精品久久| 国产精品成人午夜| 91老司机福利 在线| 最新日韩av在线| 91免费看`日韩一区二区| 国产精品福利一区二区| www.欧美日韩| 日韩一区在线看| 91丝袜高跟美女视频| 亚洲精品视频自拍| 欧洲生活片亚洲生活在线观看| 亚洲欧美日韩国产中文在线| 欧美在线观看一二区| 亚洲www啪成人一区二区麻豆| 欧美日韩在线一区二区| 日本vs亚洲vs韩国一区三区二区| 日韩欧美一级片| 国产精品888| 中文字幕第一区综合| 色菇凉天天综合网| 石原莉奈在线亚洲三区| 欧美草草影院在线视频| 高清久久久久久| 亚洲免费观看高清完整版在线| 欧美性受xxxx黑人xyx| 日韩成人精品在线| 国产欧美日本一区视频| 在线一区二区视频| 日本亚洲最大的色成网站www| 精品国产123| proumb性欧美在线观看| 亚洲第一福利一区| 久久婷婷国产综合精品青草| av男人天堂一区| 日韩影视精彩在线| 国产婷婷色一区二区三区四区| 北条麻妃一区二区三区| 亚洲二区视频在线| 26uuu成人网一区二区三区| 波多野结衣的一区二区三区| 午夜精品一区二区三区电影天堂| www久久精品| 91官网在线观看| 国产精品一级片| 亚洲图片欧美色图| 久久综合久久综合九色| 色视频一区二区| 精品一区二区三区在线观看国产| 亚洲视频电影在线| 26uuu亚洲综合色| 欧美怡红院视频| 国产一区二区久久| 亚洲国产欧美日韩另类综合| 久久综合九色综合97婷婷女人 | 欧美日韩成人综合| 国产一区999| 亚洲一区二区偷拍精品| 国产亚洲午夜高清国产拍精品| 欧美性猛交xxxxxx富婆| 国产精品综合网| 日韩综合一区二区| 国产精品乱人伦中文| 日韩欧美你懂的| 欧美在线啊v一区| 国产99一区视频免费| 日本在线不卡一区| 亚洲精品欧美专区| 欧美国产日韩亚洲一区| 欧美丰满少妇xxxxx高潮对白 | 国产精品欧美久久久久无广告| 欧美裸体bbwbbwbbw| jvid福利写真一区二区三区| 精品一区二区三区香蕉蜜桃| 水蜜桃久久夜色精品一区的特点 | 青青草成人在线观看| 亚洲靠逼com| 国产精品日产欧美久久久久| 欧美一区二区三区男人的天堂| 色婷婷综合久久久久中文 | 久久夜色精品国产欧美乱极品| 欧美在线观看禁18| 99久久久国产精品免费蜜臀| 国产精品77777| 久久99精品久久久久久国产越南| 日精品一区二区| 首页综合国产亚洲丝袜| 亚洲一区在线观看免费| 亚洲免费av观看| 国产精品久久久久四虎| 久久精品亚洲精品国产欧美 | 一区二区三区丝袜| 国产精品高潮呻吟久久| 国产日本欧美一区二区| 久久久国产午夜精品| 26uuu国产电影一区二区|