Windows2003-3790/base/mvdm/wow16/kernel31/stack.asm
2020-09-30 16:53:55 +02:00

110 lines
1.7 KiB
NASM

TITLE STACK - Kernel stack switching code
include kernel.inc
ifdef WOW
include vint.inc
endif
;------------------------------------------------------------------------
; T M P S T A C K S E G M E N T V A R I A B L E S
;------------------------------------------------------------------------
sBegin DATA
assumes CS,CODE
assumes DS,NOTHING
assumes ES,NOTHING
assumes SS,NOTHING
EVEN
if KDEBUG
externW gmove_stack_sig
endif
externW gmove_stack
externW prev_gmove_SP
externW prev_gmove_SS
externW ss_sel
sEnd DATA
;------------------------------------------------------------------------
sBegin CODE
assumes CS,CODE
assumes SS,NOTHING
assumes ds,nothing
assumes es,nothing
cProc Enter_gmove_stack,<PUBLIC,NEAR>
cBegin nogen
mov ax,ds
SetKernelDS
cmp prev_gmove_SS,0
jne gs_fail
FCLI
pop gmove_stack
mov prev_gmove_SS,cx
mov prev_gmove_SP,sp
if KDEBUG
mov gmove_stack_sig,STACK_SIGNATURE
endif
smov ss,ds
mov sp,dataOffset gmove_stack
FSTI
mov ds,ax
ret
cEnd nogen
gs_fail:
kerror ERR_GMEM,<gmove_stack usage error>,prev_gmove_SS,prev_gmove_SP
jmp gs_fail
assumes ds,nothing
assumes es,nothing
cProc Leave_gmove_stack,<PUBLIC,NEAR>
cBegin nogen
mov ax,ds
SetKernelDS
cmp prev_gmove_SS,0
je gs_fail
if KDEBUG
push ax
push cx
push es
push di
lea di, gmove_stack_sig
smov es, ss
mov ax, STACK_SIGNATURE
mov cx, 16
cld
repe scasw
pop di
pop es
pop cx
pop ax
jne gs_fail
cmp sp,dataOffset gmove_stack
jne gs_fail
endif
FCLI
mov ss,prev_gmove_SS
mov sp,prev_gmove_SP
push gmove_stack
mov prev_gmove_SS,0
FSTI
mov ds,ax
ret
cEnd nogen
sEND CODE
end