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

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

?? entry.asm

?? Free Dos 源代碼 操作系統 可以參照學習操作系統
?? ASM
字號:
;
; File:
;			   entry.asm
; Description:
;		       System call entry code
;
;			Copyright (c) 1998
;			Pasquale J. Villani
;			All Rights Reserved
;
; This file is part of DOS-C.
;
; DOS-C is free software; you can redistribute it and/or
; modify it under the terms of the GNU General public License
; as published by the Free Software Foundation; either version
; 2, or (at your option) any later version.
;
; DOS-C is distributed in the hope that it will be useful, but
; WITHOUT ANY WARRANTY; without even the implied warranty of
; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See
; the GNU General public License for more details.
;
; You should have received a copy of the GNU General public
; License along with DOS-C; see the file COPYING.  If not,
; write to the Free Software Foundation, 675 Mass Ave,
; Cambridge, MA 02139, USA.
;
; $Header:   C:/dos-c/src/kernel/entry.asv   1.0   07 Feb 1998 20:42:08   patv  $
;
; $Log:   C:/dos-c/src/kernel/entry.asv  $
;  
;     Rev 1.0   07 Feb 1998 20:42:08   patv
;  Modified stack fram to match DOS standard
; $EndLog$

		page	60,132
		title	System call entry code

IFDEF ??version
_TEXT		segment	byte public 'CODE'
DGROUP		group	_FIXED_DATA,_DATA,_BSS,_BSSEND	; small model
		assume	cs:_TEXT,ds:DGROUP,ss:DGROUP
_TEXT		ends

_FIXED_DATA	segment para public 'DATA'
_FIXED_DATA	ends

_DATA		segment word public 'DATA'
_DATA		ends

_BSS		segment word public 'BSS'
_BSS		ends

_BSSEND		segment byte public 'STACK'
_BSSEND		ends

ELSE
_TEXT		segment	byte public 'CODE'
_TEXT		ends

_FIXED_DATA	segment para public 'DATA'
_FIXED_DATA	ends

_DATA		segment word public 'DATA'
_DATA		ends

CONST		segment word public 'CONST'
CONST		ends

_BSS		segment word public 'BSS'
_BSS		ends

_BSSEND		segment byte public 'STACK'
_BSSEND		ends

DGROUP		group	CONST,_DATA,_BSS,_BSSEND	; small/tiny model
		assume	ds:DGROUP, ss:DGROUP
ENDIF

		include	stacks.inc

_TEXT		segment	byte public 'CODE'
		extrn	_int21_syscall:near
		extrn	_int25_handler:NEAR, _int26_handler:NEAR
		extrn	_set_stack:FAR
		extrn	_restore_stack:FAR
		extrn	_api_sp:WORD
		extrn	_api_ss:WORD
		extrn	_disk_api_tos:WORD
		public	_cpm_entry
		public	_int20_handler
		public	_int21_handler
		public	_low_int25_handler
		public	_low_int26_handler
		public	_int27_handler


;
; MS-DOS CP/M style entry point
;
;	VOID FAR 
;	cpm_entry(iregs UserRegs)
;
; This one is a strange one.  The call is to psp:0005h but it returns to the 
; function after the call.  What we do is convert it to a normal call and 
; fudge the stack to look like an int 21h call.
;
		assume	cs:_TEXT
_cpm_entry	proc	far
		; Stack is:
		;	return offset
		;	psp seg
		;	000ah
		;
		push	bp		; trash old return address
		mov	bp,sp
		xchg	bp,2[bp]
		pop	bp
		pushf			; start setting up int 21h stack
		;
		; now stack is
		;	return offset
		;	psp seg
		;	flags
		;
		push	bp
		mov	bp,sp		; set up reference frame
		;
		; reference frame stack is
		;	return offset		bp + 6
		;	psp seg			bp + 4
		;	flags			bp + 2
		;	bp		<---	bp
		;
		push	ax
		mov	ax,2[bp]	; get the flags
		xchg	ax,6[bp]	; swap with return address
		mov	2[bp],ax
		pop	ax		; restore working registers
		pop	bp
		;
		; Done. Stack is
		;	flags
		;	psp seg (alias .COM cs)
		;	return offset
		;
		cmp	cl,024h
		jbe	cpm_error
		mov	ah,cl		; get the call # from cl to ah
		jmp	short _int21_handler	; do the system call
cpm_error:	mov	al,0
		iret
_cpm_entry	endp


;
; Terminate the current process
;
;	VOID INRPT far 
;	int20_handler(iregs UserRegs)
;
		assume	cs:_TEXT
_int20_handler	proc	far
		mov	ah,0		; terminate through int 21h
_int20_handler	endp


;
; MS-DOS system call entry point
;
;	VOID INRPT far 
;	int21_handler(iregs UserRegs)
;
		assume	cs:_TEXT
_int21_handler	proc	far
		;
		; Create the stack frame for C call.  This is done to 
		; preserve machine state and provide a C structure for 
		; access to registers.
		;
		; Since this is an interrupt routine, CS, IP and flags were 
		; pushed onto the stack by the processor, completing the 
		; stack frame.
		;
		; NB: stack frame is MS-DOS dependent and not compatible
		; with compiler interrupt stack frames.
		;
		PUSH$ALL

		;
		; Create kernel refernce frame.
		;
		; NB: At this point, SS != DS and won't be set that way 
		; until later when which stack to run on is determined.
		;
		mov	bp,DGROUP
		mov	ds,bp
		mov	bp,sp
		;
		; Push the far pointer to the register frame for 
		; int21_syscall and remainder of kernel.
		;
		push	ss
		lea	ax,word ptr [bp]
		push	ax
		call	near ptr _int21_syscall
		;
		; Clean up stack.  It's int2_syscall responsibility to 
		; restore user stack.
		;
		pop	cx
		pop	cx
		;
		; Recover registers from system call.  Registers and flags 
		; were modified by the system call.
		;
		POP$ALL

		;
		; ... and return.
		;
		iret	
_int21_handler	endp



;
; Terminate the current process
;
;	VOID INRPT far 
;	int27_handler(iregs UserRegs)
;
		assume	cs:_TEXT
_int27_handler	proc	far
		;
		; First convert the memory to paragraphs
		;
		add	dx,0fh		; round up
		rcr	dx,1
		shr	dx,1
		shr	dx,1
		shr	dx,1
		;
		; ... then use the standard system call
		;
		mov	ax,3100h
		jmp	short _int21_handler	; terminate through int 21h
_int27_handler	endp

;
; I really do need to get rid of this because it's the only thing stopping 
; us from being ROMABLE.
;
stkframe        dd      ?

_low_int25_handler  proc far
		sti
		pushf
		push    ax
		push    cx
		push    dx
		push    bx
		push    sp
		push    bp
		push    si
		push    di
		push    ds
		push    es
		
		mov     word ptr cs:stkframe, sp     ; save stack frame
		mov     word ptr cs:stkframe+2, ss

		cld
		mov     ax, seg DGROUP
		mov     ds, ax

		mov     word ptr DGROUP:_api_sp, offset DGROUP:_disk_api_tos
		mov     word ptr DGROUP:_api_ss, ds

		call    far ptr _set_stack

		push    word ptr cs:stkframe+2
		push    word ptr cs:stkframe
		call    _int25_handler
		add     sp, 4

		call    far ptr _restore_stack

		pop     es
		pop     ds
		pop     di
		pop     si
		pop     bp
		pop     bx      ; pop off sp value
		pop     bx
		pop     dx
		pop     cx
		pop     ax
		popf
		retf            ; Bug-compatiblity with MS-DOS.
		                ; This function is supposed to leave the original
		                ; flag image on the stack.
_low_int25_handler  endp


_low_int26_handler  proc far
		sti
		pushf
		push    ax
		push    cx
		push    dx
		push    bx
		push    sp
		push    bp
		push    si
		push    di
		push    ds
		push    es
		
		mov     word ptr cs:stkframe, sp     ; save stack frame
		mov     word ptr cs:stkframe+2, ss

		cld
		mov     ax, seg DGROUP
		mov     ds, ax

		mov     word ptr DGROUP:_api_sp, offset DGROUP:_disk_api_tos
		mov     word ptr DGROUP:_api_ss, ds

		call    far ptr _set_stack

		push    word ptr cs:stkframe+2
		push    word ptr cs:stkframe
		call    _int26_handler
		add     sp, 4
		
		call    far ptr _restore_stack

		pop     es
		pop     ds
		pop     di
		pop     si
		pop     bp
		pop     bx      ; pop off sp value
		pop     bx
		pop     dx
		pop     cx
		pop     ax
		popf
		retf            
_low_int26_handler  endp

_TEXT		ends
		end

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品久久一二三区| 日韩精品1区2区3区| 亚洲一级二级三级在线免费观看| 亚洲成a人v欧美综合天堂下载| 国产在线精品一区二区夜色| 91视频国产观看| 国产亚洲综合性久久久影院| 一区二区三区在线免费播放| 国产传媒日韩欧美成人| 欧美久久久一区| 亚洲免费伊人电影| 国产精品自拍在线| 欧美放荡的少妇| 国产精品久久久久久妇女6080 | 国产一区二区精品久久99| 一本在线高清不卡dvd| 精品对白一区国产伦| 亚洲国产成人va在线观看天堂| 国产成人精品一区二| 日韩欧美一区二区在线视频| 亚洲成a人v欧美综合天堂下载| 99久久精品情趣| 国产精品色眯眯| 国产最新精品免费| 精品国内二区三区| 95精品视频在线| 久久九九久精品国产免费直播| 日本 国产 欧美色综合| 欧美在线三级电影| 亚洲精品少妇30p| 色婷婷综合中文久久一本| 亚洲色图欧美偷拍| 国产精品99久| 国产精品视频线看| kk眼镜猥琐国模调教系列一区二区| 久久午夜老司机| 国产美女精品人人做人人爽| 久久综合色天天久久综合图片| 日日噜噜夜夜狠狠视频欧美人| 欧美久久久影院| 久久国产三级精品| 欧美精品一区二区精品网| 精品在线播放免费| 国产亚洲欧美色| 亚洲欧美成人一区二区三区| 天堂在线亚洲视频| 777亚洲妇女| 免费观看成人鲁鲁鲁鲁鲁视频| 欧美日韩一区成人| 午夜久久久久久电影| 欧美一级日韩不卡播放免费| 蜜臀精品一区二区三区在线观看| 日韩欧美色电影| 国产成都精品91一区二区三| 亚洲国产成人私人影院tom| aaa欧美大片| 亚洲一区二区三区在线看| 3d成人h动漫网站入口| 精品一区二区三区视频在线观看| 久久噜噜亚洲综合| 一本大道久久精品懂色aⅴ| 亚洲一区国产视频| 日韩精品一区二区三区三区免费| 粗大黑人巨茎大战欧美成人| 一区二区在线观看免费| 日韩免费观看2025年上映的电影 | 国产一区二区女| 中文字幕一区二区三区四区| 欧美日韩中文字幕精品| 日本成人在线视频网站| 久久久91精品国产一区二区精品 | 在线观看日韩高清av| 麻豆国产一区二区| 国产精品久久久久久一区二区三区 | 欧美三级视频在线观看| 极品少妇xxxx偷拍精品少妇| 最好看的中文字幕久久| 欧美一级片在线看| 成人免费av网站| 日本成人在线一区| 樱桃视频在线观看一区| 精品国产污污免费网站入口 | 蜜臀久久久99精品久久久久久| 国产欧美日韩综合| 欧美影院一区二区三区| 韩国女主播成人在线观看| 亚洲一区二区成人在线观看| 久久久久99精品一区| 91麻豆精品国产91久久久久久 | 亚洲国产毛片aaaaa无费看| 亚洲精品在线免费观看视频| 欧美日精品一区视频| 成人av先锋影音| 毛片av中文字幕一区二区| 亚洲五月六月丁香激情| 国产精品美女久久久久高潮| 亚洲精品一区二区三区在线观看 | av成人老司机| 国产成人亚洲精品狼色在线| 日韩国产欧美三级| 亚洲福利一区二区三区| 亚洲欧美日韩在线播放| 中文字幕免费一区| 久久久久久久久伊人| 欧美大片拔萝卜| 日韩午夜精品视频| 91精品国产综合久久久久久久久久 | 不卡的看片网站| 国产在线精品不卡| 久久精品免费观看| 精品一区二区三区在线观看| 蜜桃av一区二区| 日韩国产高清在线| 亚洲电影一级黄| 天天综合色天天综合| 亚洲一级二级三级| 亚洲gay无套男同| 视频一区视频二区中文| 亚洲成av人**亚洲成av**| 亚洲观看高清完整版在线观看 | 国产欧美日韩在线看| 91精品国产综合久久久久久漫画| 欧美日韩在线播放三区四区| 欧美自拍偷拍一区| 欧美高清性hdvideosex| 日韩一区二区三区在线视频| 精品理论电影在线| 久久网站最新地址| 国产人妖乱国产精品人妖| 国产精品毛片无遮挡高清| 国产精品高潮呻吟| 亚洲精品国产一区二区精华液| 亚洲你懂的在线视频| 亚洲va韩国va欧美va精品| 免费成人结看片| 国产精品一区二区三区99| 成人网男人的天堂| 欧美性三三影院| 日韩午夜中文字幕| 国产欧美日韩中文久久| 亚洲激情成人在线| 美女网站色91| 成人免费高清视频在线观看| 欧美午夜电影一区| 久久色在线视频| 中文字幕一区二区三区视频| 亚洲大片在线观看| 久久机这里只有精品| av一区二区三区在线| 欧美日韩精品免费| 久久久综合精品| 亚洲国产毛片aaaaa无费看 | 欧美xxxxx牲另类人与| 国产精品网站在线观看| 亚洲综合在线观看视频| 麻豆精品蜜桃视频网站| av色综合久久天堂av综合| 欧美色涩在线第一页| 精品福利二区三区| 亚洲一区二区三区四区不卡| 国产在线麻豆精品观看| 色偷偷成人一区二区三区91| 精品国产一区二区精华| 一区二区三区国产豹纹内裤在线| 日韩av电影免费观看高清完整版 | 五月激情丁香一区二区三区| 国产麻豆精品一区二区| 欧美做爰猛烈大尺度电影无法无天| 亚洲精品一区二区三区四区高清 | 日韩欧美在线不卡| 亚洲欧美另类久久久精品| 黑人精品欧美一区二区蜜桃| 在线精品视频免费观看| 国产精品午夜电影| 精品一区免费av| 欧美日韩视频专区在线播放| 中文字幕一区二区三区在线播放| 精品中文av资源站在线观看| 欧美日高清视频| 夜夜操天天操亚洲| 99久久综合99久久综合网站| 精品国产免费视频| 奇米四色…亚洲| 欧美日韩一区二区欧美激情| 亚洲欧美一区二区不卡| 成人午夜精品在线| 久久精品亚洲精品国产欧美| 国内精品久久久久影院色| 制服.丝袜.亚洲.中文.综合| 亚洲一区二区三区在线播放| 97久久精品人人澡人人爽| 国产午夜久久久久| 国产精品一级片在线观看| 精品福利视频一区二区三区| 日本怡春院一区二区| 91麻豆精品久久久久蜜臀 | 欧美四级电影网| 一区二区三区不卡在线观看| 91在线丨porny丨国产| 亚洲欧美综合色|