123 lines
2.9 KiB
Plaintext
123 lines
2.9 KiB
Plaintext
;++
|
|
;
|
|
; Copyright (c) 1989 - 1999, Microsoft Corporation
|
|
;
|
|
; Module Name:
|
|
;
|
|
; sysstubs.asm
|
|
;
|
|
; Abstract:
|
|
;
|
|
; This module implements the system service dispatch stub procedures.
|
|
;
|
|
; Author:
|
|
;
|
|
; Shie-Lin Tzong (shielint) 6-Feb-1990
|
|
;
|
|
; Environment:
|
|
;
|
|
; User or kernel mode.
|
|
;
|
|
; Revision History:
|
|
;
|
|
; Peter Johnston (peterj) 27-Nov-1999
|
|
; Use Fast System call mechanism.
|
|
;
|
|
;--
|
|
|
|
include ks386.inc
|
|
include callconv.inc
|
|
|
|
.386
|
|
|
|
STUBS_BEGIN1 macro t
|
|
TITLE t
|
|
endm
|
|
STUBS_BEGIN2 macro t
|
|
endm
|
|
STUBS_BEGIN3 macro t
|
|
_TEXT SEGMENT DWORD PUBLIC 'CODE'
|
|
ASSUME DS:FLAT, ES:FLAT, SS:NOTHING, FS:NOTHING, GS:NOTHING
|
|
endm
|
|
STUBS_BEGIN4 macro t
|
|
endm
|
|
STUBS_BEGIN5 macro t
|
|
align 4
|
|
endm
|
|
STUBS_BEGIN6 macro t
|
|
endm
|
|
STUBS_BEGIN7 macro t
|
|
endm
|
|
STUBS_BEGIN8 macro t
|
|
endm
|
|
|
|
STUBS_END macro t
|
|
_TEXT ENDS
|
|
end
|
|
endm
|
|
|
|
SYSSTUBS_ENTRY1 macro ServiceNumber, Name, NumArgs
|
|
cPublicProc _Zw&Name,NumArgs
|
|
.FPO ( 0, NumArgs, 0, 0, 0, 0 )
|
|
extrn _KiSystemService:PROC
|
|
mov eax, ServiceNumber ; (eax) = service number
|
|
lea edx, [esp]+4 ; (edx) -> arguments
|
|
pushfd ; EFLAGS to trap frame
|
|
push KGDT_R0_CODE ; CS to trap frame
|
|
call _KiSystemService ; EIP to trap frame and enter handler
|
|
stdRET _Zw&Name
|
|
stdENDP _Zw&Name
|
|
endm
|
|
|
|
SYSSTUBS_ENTRY2 macro ServiceNumber, Name, NumArgs
|
|
endm
|
|
SYSSTUBS_ENTRY3 macro ServiceNumber, Name, NumArgs
|
|
endm
|
|
SYSSTUBS_ENTRY4 macro ServiceNumber, Name, NumArgs
|
|
endm
|
|
SYSSTUBS_ENTRY5 macro ServiceNumber, Name, NumArgs
|
|
endm
|
|
SYSSTUBS_ENTRY6 macro ServiceNumber, Name, NumArgs
|
|
endm
|
|
SYSSTUBS_ENTRY7 macro ServiceNumber, Name, NumArgs
|
|
endm
|
|
SYSSTUBS_ENTRY8 macro ServiceNumber, Name, NumArgs
|
|
endm
|
|
|
|
|
|
USRSTUBS_ENTRY1 macro ServiceNumber, Name, NumArgs
|
|
cPublicProc _Zw&Name, NumArgs
|
|
PUBLICP _Nt&Name, NumArgs
|
|
LABELP _Nt&Name, NumArgs
|
|
.FPO ( 0, NumArgs, 0, 0, 0, 0 )
|
|
mov eax, ServiceNumber ; (eax) = service number
|
|
mov edx, MM_SHARED_USER_DATA_VA+UsSystemCall
|
|
call edx
|
|
stdRET _Zw&Name
|
|
stdENDP _Zw&Name
|
|
endm
|
|
|
|
USRSTUBS_ENTRY2 macro ServiceNumber, Name, NumArgs
|
|
endm
|
|
USRSTUBS_ENTRY3 macro ServiceNumber, Name, NumArgs
|
|
endm
|
|
USRSTUBS_ENTRY4 macro ServiceNumber, Name, NumArgs
|
|
endm
|
|
USRSTUBS_ENTRY5 macro ServiceNumber, Name, NumArgs
|
|
endm
|
|
USRSTUBS_ENTRY6 macro ServiceNumber, Name, NumArgs
|
|
endm
|
|
USRSTUBS_ENTRY7 macro ServiceNumber, Name, NumArgs
|
|
endm
|
|
USRSTUBS_ENTRY8 macro ServiceNumber, Name, NumArgs
|
|
endm
|
|
|
|
STUBS_BEGIN1 <"System Service Stub Procedures">
|
|
STUBS_BEGIN2 <"System Service Stub Procedures">
|
|
STUBS_BEGIN3 <"System Service Stub Procedures">
|
|
STUBS_BEGIN4 <"System Service Stub Procedures">
|
|
STUBS_BEGIN5 <"System Service Stub Procedures">
|
|
STUBS_BEGIN6 <"System Service Stub Procedures">
|
|
STUBS_BEGIN7 <"System Service Stub Procedures">
|
|
STUBS_BEGIN8 <"System Service Stub Procedures">
|