Source code of Windows XP (NT5)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

126 lines
1.9 KiB

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
;;;if PMODE
;;; mov ss_sel,ss
;;;endif
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
;;;if PMODE
;;;externNP get_physical_address
;;;externNP set_physical_address
;;; push ax
;;; push dx
;;; cCall get_physical_address,<prev_gmove_SS>
;;; cCall set_physical_address,<ss_sel>
;;; pop dx
;;; pop ax
;;; FCLI
;;; mov ss,ss_sel
;;;else
FCLI
mov ss,prev_gmove_SS
;;;endif
mov sp,prev_gmove_SP
push gmove_stack
mov prev_gmove_SS,0
FSTI
mov ds,ax
ret
cEnd nogen
sEND CODE
end