|
|
;++ ; ; Copyright (c) 1989 Microsoft Corporation ; ; Module Name: ; ; vdm.inc ; ; Abstract: ; ; This module contains the structure and constant definitions for ; the vdm component ; ; Author: ; ; Dave Hastings (daveh) 20-Feb-1992 ; ; Revision History ; Sudeepb (30-Nov-1992) ; Merged all the equates in one place ; ;-- .386p
TRUE equ 1 FALSE equ 0
; ; Macro's to only do locked memory operations on MP systems ;
IFDEF NT_UP MPLOCK equ <> ELSE MPLOCK equ <lock> ENDIF
page , 132 subttl "Macro to dispatch exception"
;++ ; ; Macro Description: ; ; This macro allocates exception record on stack, sets up exception ; record using specified parameters and finally sets up arguments ; and calls _KiDispatchException. ; ; Arguments: ; ; ExcepCode - Exception code to put into exception record ; ExceptFlags - Exception flags to put into exception record ; ExceptRecord - Associated exception record ; ExceptAddress - Addr of instruction which the hardware exception occurs ; NumParms - Number of additional parameters ; ParameterList - the additional parameter list ; ; Return Value: ; ; None. ; ;--
DISPATCH_EXCEPTION macro ExceptCode, ExceptFlags, ExceptRecord, ExceptAddress,\ NumParms, ParameterList local de10, de20
; Set up exception record for raising exception
?i = 0 sub esp, ExceptionRecordSize + NumParms * 4 ; allocate exception record mov dword ptr [esp]+ErExceptionCode, ExceptCode ; set up exception code mov dword ptr [esp]+ErExceptionFlags, ExceptFlags ; set exception flags mov dword ptr [esp]+ErExceptionRecord, ExceptRecord ; set associated exception record mov dword ptr [esp]+ErExceptionAddress, ExceptAddress mov dword ptr [esp]+ErNumberParameters, NumParms ; set number of parameters IRP z, <ParameterList> mov dword ptr [esp]+(ErExceptionInformation+?i*4), z ?i = ?i + 1 ENDM
; set up arguments and call _KiDispatchException
mov ecx, esp ; (ecx)->exception record
test dword ptr [ebp]+TsEFlags,EFLAGS_V86_MASK jz de10
mov eax,0FFFFh jmp de20
de10: mov eax,[ebp]+TsSegCs de20: and eax,MODE_MASK
; 1 - set first chance TRUE ; eax - PreviousMode ; ebp - trap frame addr ; 0 - Null exception frame ; ecx - exception record addr
; dispatchexception as appropriate stdCall _KiDispatchException, <ecx, 0, ebp, eax, 1> IFDEF STD_CALL add esp,ExceptionRecordSize + NumParms*4 ELSE add esp,20 + ExceptionRecordSize + NumParms*4 ENDIF
ENDM
; ; Prefix Flags ;
PREFIX_ES equ 00000100h PREFIX_CS equ 00000200h PREFIX_SS equ 00000400h PREFIX_DS equ 00000800h PREFIX_FS equ 00001000h PREFIX_GS equ 00002000h PREFIX_OPER32 equ 00004000h PREFIX_ADDR32 equ 00008000h PREFIX_LOCK equ 00010000h PREFIX_REPNE equ 00020000h PREFIX_REP equ 00040000h PREFIX_SEG_ALL equ 00003f00h
NUM_OPCODE equ 255 ; ; Reginfo structure ;
RegInfo struc RiSegSs dd 0 RiEsp dd 0 RiEFlags dd 0 RiSegCs dd 0 RiEip dd 0 RiTrapFrame dd 0 RiCsLimit dd 0 RiCsBase dd 0 RiCsFlags dd 0 RiSsLimit dd 0 RiSsBase dd 0 RiSsFlags dd 0 RiPrefixFlags dd 0 RiOperand dd 0 RegInfo ends REGINFOSIZE EQU 56
MAX_VDM_ADDR EQU 0FFFFFFH
DR7_GLOBAL EQU 002AAH
; ;Fast Read/Write Defines ;
SVC_DEMFASTREAD equ 42h SVC_DEMFASTWRITE equ 43h DOS_BOP equ 50h
; ; ; Size of Exception Record ;
ExceptionRecordSize = (ErNumberParameters + 4 + 3) AND 0fffffffcH ;
; ; Magic value ;
OPCODE_MAGIC equ 00f5ah
;++ ; diBEGIN - BEGIN index table ; ; ENTRY name = name of di table ; badindex = local label for unspecified entries ; ; EXIT ?sindex = specific entry index ; ?badindex = default index for unspecified entries ;--
diBEGIN macro name,badindex ;; Beginning of dispatch table ?sopc = 0 ?badindex = badindex name label byte ;; Start of dispatch table endm
;++ ; dtI - SPECIFIC index table entry ; ; ENTRY opc = opcode value ; index = INDEX_ value corresponding to opcode ; ?badindex = unspecified entry index ; ?sopc = specific entry index ; ; EXIT Unspecified entries prior to "index" filled in; ; Specified entry filled in. ; ?sopc = next index to fill in; ;--
dtI macro opc,index ;; Specific entry in dispatch table if ?sopc gt opc %out dtI: opcode out of order .err else if ?sopc lt opc ;; Fill unspecified entries rept opc - ?sopc db ?badindex endm endif db index ;; Specified entry ?sopc = opc+1 ;; Set new start index endif endm
;++ ; diEND - END index table ; ; ENTRY index = highest entry in table ; ?sopc = specific entry index ; ; EXIT rest of the table filled in ;--
diEND macro index ;; End of dispatch table if ?sopc lt index ;; Fill in rest of table rept index - ?sopc db ?badindex endm db ?badindex ;; fill in last entry of table! endif endm
;++ ; dtBEGIN - BEGIN dispatch table ; ; ENTRY name = name of dt table ; badaddr = local label for unspecified entries ; ; EXIT ?sindex = specific entry index ; ?badaddr = default handler for unspecified entries ;--
dtBEGIN macro name,badaddr ;; Beginning of dispatch table ?sindex = 0 ?badaddr = badaddr name label dword ;; Start of dispatch table endm
;++ ; dtS - SPECIFIC dispatch table entry ; ; ENTRY index = index of entry ; addr = address of handler ; ?badaddr = unspecified entry handler ; ?sindex = specific entry index ; ; EXIT Unspecified entries prior to "index" filled in; ; Specified entry filled in. ; ?sindex = next index to fill in; ;--
dtS macro index,addr ;; Specific entry in dispatch table if ?sindex gt index %out dtS: index out of order .err else if ?sindex lt index ;; Fill unspecified entries rept index - ?sindex dd offset FLAT:?badaddr endm endif dd offset FLAT:addr ;; Specified entry ?sindex = index+1 ;; Set new start index endif endm
;++ ; dtEND - END dispatch table ; ; ENTRY index = highest entry in table ; ?sindex = specific entry index ; ; EXIT rest of the table filled in ;--
dtEND macro index ;; End of dispatch table if ?sindex lt index ;; Fill in rest of table rept index - ?sindex dd offset FLAT:?badaddr endm dd offset FLAT:?badaddr ;; fill in last entry of table! endif endm
;++ ; CsToLinearPM ; ;--
CsToLinearPM macro sel, erraddr lea eax,[esi].RiCsLimit push eax lea eax,[esi].RiCsBase push eax lea eax,[esi].RiCsFlags push eax push sel
IFDEF STD_CALL call _Ki386GetSelectorParameters@16 ELSE call _Ki386GetSelectorParameters add esp,10h ENDIF or al,al jz erraddr
test [esi].RiCsFlags,SEL_TYPE_EXECUTE jz erraddr
test [esi].RiCsFlags,SEL_TYPE_2GIG jz @f
; Correct limit value for granularity shl [esi].RiCsLimit,12 or [esi].RiCsLimit,0FFFh @@: endm
;++ ; CsToLinearV86 ; ;--
CsToLinearV86 macro movzx eax,word ptr [esi].RiSegCs shl eax,4 mov [esi].RiCsBase,eax mov [esi].RiCsLimit,0FFFFh mov [esi].RiCsFlags,0 endm
|