mirror of https://github.com/FDOS/kernel.git
Use the pascal calling convention for most intr.asm functions, and let
them pop the stack (smaller code than using bx). Tell Watcom which registers are clobbered; save some more registers for intr() -- especially for intr() this helps. git-svn-id: https://svn.code.sf.net/p/freedos/svn/kernel/trunk@849 6ac86273-5f31-0410-b378-82cca8765d1b
This commit is contained in:
parent
a7ca14c46c
commit
950078ad08
|
@ -44,6 +44,7 @@ extern struct _KernelConfig InitKernelConfig;
|
|||
#define strcpy init_strcpy
|
||||
#define strlen init_strlen
|
||||
#define fstrlen init_fstrlen
|
||||
#define open init_DosOpen
|
||||
|
||||
/* execrh.asm */
|
||||
WORD ASMPASCAL execrh(request FAR *, struct dhdr FAR *);
|
||||
|
@ -133,18 +134,32 @@ unsigned ebdasize(void);
|
|||
|
||||
/* intr.asm */
|
||||
|
||||
void ASMCFUNC init_call_intr(int nr, iregs * rp);
|
||||
UCOUNT ASMCFUNC read(int fd, void *buf, UCOUNT count);
|
||||
int ASMCFUNC open(const char *pathname, int flags);
|
||||
int ASMCFUNC close(int fd);
|
||||
int ASMCFUNC dup2(int oldfd, int newfd);
|
||||
int ASMCFUNC allocmem(UWORD size, seg * segp);
|
||||
VOID ASMCFUNC init_PSPSet(seg psp_seg);
|
||||
COUNT ASMCFUNC init_DosExec(COUNT mode, exec_blk * ep, BYTE * lp);
|
||||
int ASMCFUNC init_setdrive(int drive);
|
||||
int ASMCFUNC init_switchar(int chr);
|
||||
VOID ASMCFUNC keycheck(VOID);
|
||||
void ASMCFUNC set_DTA(void far *dta);
|
||||
unsigned ASMPASCAL init_call_intr(int nr, iregs * rp);
|
||||
unsigned ASMPASCAL read(int fd, void *buf, unsigned count);
|
||||
int ASMPASCAL open(const char *pathname, int flags);
|
||||
int ASMPASCAL close(int fd);
|
||||
int ASMPASCAL dup2(int oldfdk, int newfd);
|
||||
int ASMPASCAL allocmem(UWORD size, seg * segp);
|
||||
void ASMPASCAL init_PSPSet(seg psp_seg);
|
||||
int ASMPASCAL init_DosExec(int mode, exec_blk * ep, char * lp);
|
||||
int ASMPASCAL init_setdrive(int drive);
|
||||
int ASMPASCAL init_switchar(int chr);
|
||||
void ASMPASCAL keycheck(void);
|
||||
void ASMPASCAL set_DTA(void far *dta);
|
||||
#ifdef __WATCOMC__
|
||||
#pragma aux (pascal) init_call_intr modify exact [ax]
|
||||
#pragma aux (pascal) read modify exact [ax bx cx dx]
|
||||
#pragma aux (pascal) init_DosOpen modify exact [ax bx dx]
|
||||
#pragma aux (pascal) close modify exact [ax bx]
|
||||
#pragma aux (pascal) dup2 modify exact [ax bx cx]
|
||||
#pragma aux (pascal) allocmem modify exact [ax bx dx]
|
||||
#pragma aux (pascal) init_PSPSet modify exact [ax bx]
|
||||
#pragma aux (pascal) init_DosExec modify exact [ax bx dx es]
|
||||
#pragma aux (pascal) init_setdrive modify exact [ax bx dx]
|
||||
#pragma aux (pascal) init_switchar modify exact [ax bx dx]
|
||||
#pragma aux (pascal) keycheck modify exact [ax]
|
||||
#pragma aux (pascal) set_DTA modify exact [ax bx dx]
|
||||
#endif
|
||||
|
||||
/* irqstack.asm */
|
||||
VOID ASMCFUNC init_stacks(VOID FAR * stack_base, COUNT nStacks,
|
||||
|
|
213
kernel/intr.asm
213
kernel/intr.asm
|
@ -33,13 +33,18 @@
|
|||
mov bp,sp
|
||||
push si
|
||||
push di
|
||||
push ds
|
||||
%ifdef WATCOM
|
||||
push bx
|
||||
push cx
|
||||
push dx
|
||||
push es
|
||||
%endif
|
||||
push ds
|
||||
|
||||
mov ax, [bp+4] ; interrupt number
|
||||
mov ax, [bp+6] ; interrupt number
|
||||
mov [cs:%%intr_1-1], al
|
||||
jmp short %%intr_2 ; flush the instruction cache
|
||||
%%intr_2 mov bx, [bp+6] ; regpack structure
|
||||
%%intr_2 mov bx, [bp+4] ; regpack structure
|
||||
mov ax, [bx]
|
||||
mov cx, [bx+4]
|
||||
mov dx, [bx+6]
|
||||
|
@ -57,8 +62,12 @@
|
|||
push ds
|
||||
push bx
|
||||
mov bx, sp
|
||||
mov ds, [ss:bx+8]
|
||||
mov bx, [ss:bx+20] ; address of REGPACK
|
||||
mov ds, [ss:bx+6]
|
||||
%ifdef WATCOM
|
||||
mov bx, [ss:bx+24] ; address of REGPACK
|
||||
%else
|
||||
mov bx, [ss:bx+16] ; address of REGPACK
|
||||
%endif
|
||||
mov [bx], ax
|
||||
pop word [bx+2]
|
||||
mov [bx+4], cx
|
||||
|
@ -70,39 +79,46 @@
|
|||
mov [bx+16], es
|
||||
pop word [bx+22]
|
||||
|
||||
pop es
|
||||
pop ds
|
||||
%ifdef WATCOM
|
||||
pop es
|
||||
pop dx
|
||||
pop cx
|
||||
pop bx
|
||||
%endif
|
||||
pop di
|
||||
pop si
|
||||
pop bp
|
||||
ret
|
||||
ret 4
|
||||
%endmacro
|
||||
|
||||
segment HMA_TEXT
|
||||
|
||||
;; COUNT ASMCFUNC res_DosExec(COUNT mode, exec_blk * ep, BYTE * lp)
|
||||
global _res_DosExec
|
||||
_res_DosExec:
|
||||
;; COUNT ASMPASCAL res_DosExec(COUNT mode, exec_blk * ep, BYTE * lp)
|
||||
global RES_DOSEXEC
|
||||
RES_DOSEXEC:
|
||||
pop es ; ret address
|
||||
pop dx ; filename
|
||||
pop bx ; exec block
|
||||
pop ax ; mode
|
||||
push es ; ret address
|
||||
mov ah, 4bh
|
||||
mov bx, sp
|
||||
mov al, [bx+2]
|
||||
push ds
|
||||
pop es
|
||||
mov dx, [bx+6] ; filename
|
||||
mov bx, [bx+4] ; exec block
|
||||
push ds
|
||||
pop es ; es = ds
|
||||
int 21h
|
||||
jc short no_exec_error
|
||||
xor ax, ax
|
||||
no_exec_error:
|
||||
ret
|
||||
|
||||
;; UCOUNT ASMCFUNC res_read(int fd, void *buf, UCOUNT count);
|
||||
global _res_read
|
||||
_res_read:
|
||||
mov bx, sp
|
||||
mov cx, [bx+6]
|
||||
mov dx, [bx+4]
|
||||
mov bx, [bx+2]
|
||||
;; UCOUNT ASMPASCAL res_read(int fd, void *buf, UCOUNT count);
|
||||
global RES_READ
|
||||
RES_READ:
|
||||
pop ax ; ret address
|
||||
pop cx ; count
|
||||
pop dx ; buf
|
||||
pop bx ; fd
|
||||
push ax ; ret address
|
||||
mov ah, 3fh
|
||||
int 21h
|
||||
jnc no_read_error
|
||||
|
@ -116,8 +132,8 @@ segment INIT_TEXT
|
|||
; REG int nr
|
||||
; REG struct REGPACK *rp
|
||||
;
|
||||
global _init_call_intr
|
||||
_init_call_intr:
|
||||
global INIT_CALL_INTR
|
||||
INIT_CALL_INTR:
|
||||
INTR
|
||||
|
||||
;
|
||||
|
@ -161,25 +177,25 @@ detected:
|
|||
pop es
|
||||
ret
|
||||
|
||||
global _keycheck
|
||||
_keycheck:
|
||||
global KEYCHECK
|
||||
KEYCHECK:
|
||||
mov ah, 1
|
||||
int 16h
|
||||
ret
|
||||
|
||||
;; int open(const char *pathname, int flags);
|
||||
global _open
|
||||
_open:
|
||||
;; first implementation of init calling DOS through ints:
|
||||
mov bx, sp
|
||||
global INIT_DOSOPEN
|
||||
INIT_DOSOPEN:
|
||||
;; init calling DOS through ints:
|
||||
pop bx ; ret address
|
||||
pop ax ; flags
|
||||
pop dx ; pathname
|
||||
push bx ; ret address
|
||||
mov ah, 3dh
|
||||
;; we know that SS=DS during init stage.
|
||||
mov al, [bx+4]
|
||||
mov dx, [bx+2]
|
||||
int 21h
|
||||
;; AX has file handle
|
||||
;; AX will have the file handle
|
||||
|
||||
common_exit:
|
||||
common_int21:
|
||||
int 21h
|
||||
jnc common_no_error
|
||||
common_error:
|
||||
mov ax, -1
|
||||
|
@ -187,54 +203,56 @@ common_no_error:
|
|||
ret
|
||||
|
||||
;; int close(int fd);
|
||||
global _close
|
||||
_close:
|
||||
mov bx, sp
|
||||
mov bx, [bx+2]
|
||||
global CLOSE
|
||||
CLOSE:
|
||||
pop ax ; ret address
|
||||
pop bx ; fd
|
||||
push ax ; ret address
|
||||
mov ah, 3eh
|
||||
int 21h
|
||||
jmp short common_exit
|
||||
jmp short common_int21
|
||||
|
||||
;; UCOUNT read(int fd, void *buf, UCOUNT count);
|
||||
global _read
|
||||
_read:
|
||||
mov bx, sp
|
||||
mov cx, [bx+6]
|
||||
mov dx, [bx+4]
|
||||
mov bx, [bx+2]
|
||||
global READ
|
||||
READ:
|
||||
pop ax ; ret address
|
||||
pop cx ; count
|
||||
pop dx ; buf
|
||||
pop bx ; fd
|
||||
push ax ; ret address
|
||||
mov ah, 3fh
|
||||
int 21h
|
||||
jmp short common_exit
|
||||
jmp short common_int21
|
||||
|
||||
;; int dup2(int oldfd, int newfd);
|
||||
global _dup2
|
||||
_dup2:
|
||||
mov bx, sp
|
||||
mov cx, [bx+4]
|
||||
mov bx, [bx+2]
|
||||
global DUP2
|
||||
DUP2:
|
||||
pop ax ; ret address
|
||||
pop cx ; newfd
|
||||
pop bx ; oldfd
|
||||
push ax ; ret address
|
||||
mov ah, 46h
|
||||
int 21h
|
||||
jmp short common_exit
|
||||
jmp short common_int21
|
||||
|
||||
;; VOID init_PSPSet(seg psp_seg)
|
||||
global _init_PSPSet
|
||||
_init_PSPSet:
|
||||
global INIT_PSPSET
|
||||
INIT_PSPSET:
|
||||
pop ax ; ret address
|
||||
pop bx ; psp_seg
|
||||
push ax ; ret_address
|
||||
mov ah, 50h
|
||||
mov bx, sp
|
||||
mov bx, [bx+2]
|
||||
int 21h
|
||||
ret
|
||||
int 21h
|
||||
ret
|
||||
|
||||
;; COUNT init_DosExec(COUNT mode, exec_blk * ep, BYTE * lp)
|
||||
global _init_DosExec
|
||||
_init_DosExec:
|
||||
global INIT_DOSEXEC
|
||||
INIT_DOSEXEC:
|
||||
pop es ; ret address
|
||||
pop dx ; filename
|
||||
pop bx ; exec block
|
||||
pop ax ; mode
|
||||
push es ; ret address
|
||||
mov ah, 4bh
|
||||
mov bx, sp
|
||||
mov al, [bx+2]
|
||||
push ds
|
||||
pop es
|
||||
mov dx, [bx+6] ; filename
|
||||
mov bx, [bx+4] ; exec block
|
||||
push ds
|
||||
pop es ; es = ds
|
||||
int 21h
|
||||
jc short exec_no_error
|
||||
xor ax, ax
|
||||
|
@ -242,42 +260,47 @@ exec_no_error:
|
|||
ret
|
||||
|
||||
;; int init_setdrive(int drive)
|
||||
global _init_setdrive
|
||||
_init_setdrive:
|
||||
global INIT_SETDRIVE
|
||||
INIT_SETDRIVE:
|
||||
mov ah, 0x0e
|
||||
common_dl_int21:
|
||||
mov bx, sp
|
||||
mov dl, [bx+2]
|
||||
int 21h
|
||||
ret
|
||||
pop bx ; ret address
|
||||
pop dx ; drive/char
|
||||
push bx
|
||||
int 21h
|
||||
ret
|
||||
|
||||
;; int init_switchar(int char)
|
||||
global _init_switchar
|
||||
_init_switchar:
|
||||
global INIT_SWITCHAR
|
||||
INIT_SWITCHAR:
|
||||
mov ax, 0x3701
|
||||
jmp short common_dl_int21
|
||||
|
||||
;; int allocmem(UWORD size, seg *segp)
|
||||
global _allocmem
|
||||
_allocmem:
|
||||
global ALLOCMEM
|
||||
ALLOCMEM:
|
||||
pop ax ; ret address
|
||||
pop dx ; segp
|
||||
pop bx ; size
|
||||
push ax ; ret address
|
||||
mov ah, 48h
|
||||
mov bx, sp
|
||||
mov bx, [bx+2]
|
||||
int 21h
|
||||
jc short common_error
|
||||
mov bx, sp
|
||||
mov bx, [bx+4]
|
||||
mov bx, dx ; segp
|
||||
mov [bx], ax
|
||||
xor ax, ax
|
||||
ret
|
||||
|
||||
;; void set_DTA(void far *dta)
|
||||
global _set_DTA
|
||||
_set_DTA
|
||||
mov ah, 1ah
|
||||
mov bx, sp
|
||||
push ds
|
||||
lds dx, [bx+2]
|
||||
int 21h
|
||||
pop ds
|
||||
ret
|
||||
global SET_DTA
|
||||
SET_DTA:
|
||||
pop ax ; ret address
|
||||
pop bx ; seg(dta)
|
||||
pop dx ; off(dta)
|
||||
push ax ; ret address
|
||||
mov ah, 1ah
|
||||
push ds
|
||||
mov ds, bx
|
||||
int 21h
|
||||
pop ds
|
||||
ret
|
||||
|
|
|
@ -123,6 +123,9 @@ COUNT DosTruename(const char FAR * src, char FAR * dest);
|
|||
|
||||
/*dosidle.asm */
|
||||
VOID ASMCFUNC DosIdle_int(void);
|
||||
#ifdef __WATCOMC__
|
||||
#pragma aux (cdecl) DosIdle_int modify exact []
|
||||
#endif
|
||||
|
||||
/* dosnames.c */
|
||||
int ParseDosName(const char *, char *, BOOL);
|
||||
|
@ -222,8 +225,12 @@ void FcbCloseAll(void);
|
|||
UBYTE FcbFindFirstNext(xfcb FAR * lpXfcb, BOOL First);
|
||||
|
||||
/* intr.asm */
|
||||
COUNT ASMCFUNC res_DosExec(COUNT mode, exec_blk * ep, BYTE * lp);
|
||||
UCOUNT ASMCFUNC res_read(int fd, void *buf, UCOUNT count);
|
||||
COUNT ASMPASCAL res_DosExec(COUNT mode, exec_blk * ep, BYTE * lp);
|
||||
UCOUNT ASMPASCAL res_read(int fd, void *buf, UCOUNT count);
|
||||
#ifdef __WATCOMC__
|
||||
#pragma aux (pascal) res_DosExec modify exact [ax bx dx es]
|
||||
#pragma aux (pascal) res_read modify exact [ax bx cx dx]
|
||||
#endif
|
||||
|
||||
/* ioctl.c */
|
||||
COUNT DosDevIOctl(lregs * r);
|
||||
|
@ -398,6 +405,35 @@ COUNT ASMCFUNC remote_printredir(UCOUNT dx, UCOUNT ax);
|
|||
COUNT ASMCFUNC remote_commit(sft FAR * s);
|
||||
COUNT ASMCFUNC remote_close(sft FAR * s);
|
||||
COUNT ASMCFUNC QRemote_Fn(char FAR * d, const char FAR * s);
|
||||
#ifdef __WATCOMC__
|
||||
/* bx, cx, and es not used or clobbered for all remote functions,
|
||||
* except lock_unlock and process_end */
|
||||
#pragma aux cdecl_axdx "_*" parm caller [] modify exact [ax dx]
|
||||
#pragma aux (cdecl_axdx) remote_doredirect
|
||||
#pragma aux (cdecl_axdx) remote_printset
|
||||
#pragma aux (cdecl_axdx) remote_rename
|
||||
#pragma aux (cdecl_axdx) remote_delete
|
||||
#pragma aux (cdecl_axdx) remote_chdir
|
||||
#pragma aux (cdecl_axdx) remote_mkdir
|
||||
#pragma aux (cdecl_axdx) remote_rmdir
|
||||
#pragma aux (cdecl_axdx) remote_close_all
|
||||
#pragma aux (cdecl_axdx) remote_flushall
|
||||
#pragma aux (cdecl_axdx) remote_findfirst
|
||||
#pragma aux (cdecl_axdx) remote_findnext
|
||||
#pragma aux (cdecl_axdx) remote_getfattr
|
||||
#pragma aux (cdecl_axdx) remote_getfree
|
||||
#pragma aux (cdecl_axdx) remote_open
|
||||
#pragma aux (cdecl_axdx) remote_extopen
|
||||
#pragma aux (cdecl_axdx) remote_lseek
|
||||
#pragma aux (cdecl_axdx) remote_read
|
||||
#pragma aux (cdecl_axdx) remote_write
|
||||
#pragma aux (cdecl_axdx) remote_creat
|
||||
#pragma aux (cdecl_axdx) remote_setfattr
|
||||
#pragma aux (cdecl_axdx) remote_printredir
|
||||
#pragma aux (cdecl_axdx) remote_commit
|
||||
#pragma aux (cdecl_axdx) remote_close
|
||||
#pragma aux (cdecl_axdx) QRemote_Fn
|
||||
#endif
|
||||
|
||||
UWORD get_machine_name(BYTE FAR * netname);
|
||||
VOID set_machine_name(BYTE FAR * netname, UWORD name_num);
|
||||
|
|
Loading…
Reference in New Issue