131 lines
3.8 KiB
NASM
131 lines
3.8 KiB
NASM
; File:
|
|
; apisupt.asm
|
|
; Description:
|
|
; Assembly support routines for stack manipulation, etc.
|
|
;
|
|
; Copyright (c) 1995, 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.
|
|
;
|
|
; $Id: apisupt.asm 538 2003-03-12 22:43:53Z bartoldeman $
|
|
;
|
|
|
|
%include "segs.inc"
|
|
|
|
segment HMA_TEXT
|
|
%if 0
|
|
|
|
extern _api_sp:wrt DGROUP ; api stacks - for context
|
|
extern _api_ss:wrt DGROUP ; switching
|
|
extern _usr_sp:wrt DGROUP ; user stacks
|
|
extern _usr_ss:wrt DGROUP
|
|
|
|
global _set_stack
|
|
;
|
|
; void set_stack(void) -
|
|
; save current stack and setup our local stack
|
|
;
|
|
_set_stack:
|
|
|
|
; save foreground stack
|
|
|
|
; we need to get the return values from the stack
|
|
; since the current stack will change
|
|
pop ax ;get return offset
|
|
|
|
; Save the flags so that we can restore correct interrupt
|
|
; state later. We need to disable interrupts so that we
|
|
; don't trash memory with new sp-old ss combination
|
|
pushf
|
|
pop dx
|
|
cli
|
|
|
|
; save bp
|
|
push bp
|
|
|
|
mov cx, sp
|
|
neg cx
|
|
|
|
; save away foreground process' stack
|
|
push word [_usr_ss]
|
|
push word [_usr_sp]
|
|
|
|
mov word [_usr_ss],ss
|
|
mov word [_usr_sp],sp
|
|
|
|
; setup our local stack
|
|
mov ss,word [_api_ss]
|
|
mov sp,word [_api_sp]
|
|
|
|
add cx, sp
|
|
add bp, cx
|
|
|
|
; setup for ret
|
|
push ax
|
|
|
|
; now restore interrupt state
|
|
push dx
|
|
popf
|
|
|
|
ret
|
|
|
|
;
|
|
; void restore_stack(void) -
|
|
; restore foreground stack, throw ours away
|
|
;
|
|
global _restore_stack
|
|
_restore_stack:
|
|
|
|
; we need to get the return values from the stack
|
|
; since the current stack will change
|
|
pop cx ;get return offset
|
|
|
|
; Save the flags so that we can restore correct interrupt
|
|
; state later. We need to disable interrupts so that we
|
|
; don't trash memory with new sp-old ss combination
|
|
pushf
|
|
pop dx
|
|
cli
|
|
|
|
; save background stack
|
|
mov word [_api_ss],ss
|
|
mov word [_api_sp],sp
|
|
|
|
; restore foreground stack here
|
|
mov ss,word [_usr_ss]
|
|
mov sp,word [_usr_sp]
|
|
|
|
pop word [_usr_sp]
|
|
pop word [_usr_ss]
|
|
|
|
; make bp relative to our stack frame
|
|
pop bp
|
|
;mov bp,sp
|
|
|
|
; setup for ret
|
|
push cx
|
|
|
|
; now restore interrupt state
|
|
push dx
|
|
popf
|
|
|
|
ret
|
|
%endif
|