529 lines
7.9 KiB
Text
529 lines
7.9 KiB
Text
.sect .text
|
|
.sect .rom
|
|
.sect .data
|
|
.retaddr:
|
|
.data4 0
|
|
.sect .bss
|
|
.sect .text
|
|
!THIS FILE CONTAINS THE SYSTEM CALLS FOR PMDS-II AS SUBROUTINES FOR THE
|
|
!EM-INTERPRETER. a5 CONTAINS A POINTER TO THE RETURN AREA . EACH SUBROUTINE
|
|
!EXPECTS ITS DATA IN THE FORM EM PRODUCES AND GIVES ITS RESULTS AS EM
|
|
!REQUIRES.
|
|
!THE PMDS-II REQUIRES THE ARGUMENTS ON THE STACK AS 4 BYTE INTEGERS OR
|
|
!POINTERS , AND USES THE C-CALLING CONVENTION. THE 2 BYTE WORDS 4 BYTE
|
|
!POINTERS VERSION HAS TO DO SOME CONVERSION FIRST .
|
|
|
|
_Xexit: move.l (sp)+,.retaddr
|
|
#ifndef lword
|
|
bsr st241
|
|
#endif
|
|
jsr __exit
|
|
|
|
_Xfork: move.l (sp)+,.retaddr
|
|
jsr _fork
|
|
tst.l d0
|
|
blt 2f
|
|
bne 1f
|
|
jsr _getpid
|
|
mov d1,-(sp) !PID OF PARENT IN d1
|
|
mov #1,-(sp) !(PID OF CHILD IN D0),FLAG 1 IN CHILD
|
|
bra 0f
|
|
1: mov d0,-(sp) !PID OF CHILD IN d0
|
|
cl -(sp) !FLAG 0 IN PARENT
|
|
0: cl -(sp)
|
|
bra 3f
|
|
2: move.l _errno,d0
|
|
mov d0,-(sp)
|
|
mov d0,-(sp)
|
|
3: move.l .retaddr,a0
|
|
jmp (a0)
|
|
!_Xfork is special
|
|
|
|
_Xread: move.l (sp)+,.retaddr
|
|
#ifndef lword
|
|
bsr st241
|
|
#endif
|
|
jsr _read
|
|
sys0: lea 12(sp),sp
|
|
cmp.l #-1,d0
|
|
bne 1f
|
|
move.l _errno,d0
|
|
mov d0,-(sp)
|
|
mov d0,-(sp)
|
|
bra 2f
|
|
1: move.l d0,-(sp)
|
|
cl -(sp)
|
|
2: move.l .retaddr,a0
|
|
jmp (a0)
|
|
|
|
_Xwrite: move.l (sp)+,.retaddr
|
|
#ifndef lword
|
|
bsr st241
|
|
#endif
|
|
jsr _write
|
|
bra sys0
|
|
|
|
_Xopen: move.l (sp)+,.retaddr
|
|
#ifndef lword
|
|
bsr st243
|
|
#endif
|
|
jsr _open
|
|
sys1: lea 8(sp),sp
|
|
sys5: cmp.l #-1,d0
|
|
bne 1f
|
|
move.l _errno,d0
|
|
mov d0,-(sp)
|
|
mov d0,-(sp)
|
|
bra 2f
|
|
1: mov d0,-(sp)
|
|
cl -(sp)
|
|
2: move.l .retaddr,a0
|
|
jmp (a0)
|
|
|
|
_Xclose: move.l (sp)+,.retaddr
|
|
#ifndef lword
|
|
bsr st241
|
|
#endif
|
|
jsr _close
|
|
sys3: lea 4(sp),sp
|
|
sys4: cmp.l #-1,d0
|
|
bne 1f
|
|
move.l _errno,d0
|
|
mov d0,-(sp)
|
|
mov d0,-(sp)
|
|
bra 2f
|
|
1: cl -(sp)
|
|
2: move.l .retaddr,a0
|
|
jmp (a0)
|
|
|
|
_Xwait: move.l (sp)+,.retaddr
|
|
.sect .data
|
|
xxxx:
|
|
.data4 0
|
|
.sect .text
|
|
move.l #xxxx,-(sp)
|
|
jsr _wait
|
|
add.l #4,sp
|
|
sys6: cmp.l #-1,d0
|
|
bne 1f
|
|
move.l _errno,d0
|
|
mov d0,-(sp)
|
|
mov d0,-(sp)
|
|
bra 2f
|
|
1: mov d0,-(sp) ! ??
|
|
#ifdef lword
|
|
move.l xxxx,-(sp)
|
|
#else
|
|
move.w xxxx+2,-(sp)
|
|
#endif
|
|
cl -(sp)
|
|
2: move.l .retaddr,a0
|
|
jmp (a0)
|
|
|
|
_Xcreat: move.l (sp)+,.retaddr
|
|
#ifndef lword
|
|
bsr st243
|
|
#endif
|
|
jsr _creat
|
|
bra sys1
|
|
|
|
_Xlink: move.l (sp)+,.retaddr
|
|
jsr _link
|
|
lea 8(sp),sp
|
|
bra sys4
|
|
|
|
_Xunlink: move.l (sp)+,.retaddr
|
|
jsr _unlink
|
|
bra sys3
|
|
|
|
_Xchdir: move.l (sp)+,.retaddr
|
|
jsr _chdir
|
|
bra sys3
|
|
|
|
_Xmknod: move.l (sp)+,.retaddr
|
|
#ifndef lword
|
|
bsr st244
|
|
#endif
|
|
jsr _mknod
|
|
lea 12(sp),sp
|
|
bra sys4
|
|
|
|
_Xchmod: move.l (sp)+,.retaddr
|
|
#ifndef lword
|
|
bsr st243
|
|
#endif
|
|
jsr _chmod
|
|
lea 8(sp),sp
|
|
bra sys4
|
|
|
|
_Xchown: move.l (sp)+,.retaddr
|
|
#ifndef lword
|
|
bsr st244
|
|
#endif
|
|
jsr _chown
|
|
lea 12(sp),sp
|
|
bra sys4
|
|
|
|
_Xbreak: move.l (sp)+,.retaddr
|
|
jsr _brk
|
|
lea 4(sp),sp
|
|
cmp.l #-1,d0
|
|
bne 1f
|
|
move.l _errno,d0
|
|
mov d0,-(sp)
|
|
mov d0,-(sp)
|
|
bra 2f
|
|
1: move.l -4(sp),nd
|
|
cl -(sp)
|
|
2: move.l .retaddr,a0
|
|
jmp (a0)
|
|
|
|
.sect .data
|
|
nd: .data4 endbss
|
|
.sect .text
|
|
|
|
_Xstat: move.l (sp)+,.retaddr
|
|
jsr _stat
|
|
lea 8(sp),sp
|
|
bra sys4
|
|
|
|
_Xlseek: move.l (sp)+,.retaddr
|
|
#ifndef lword
|
|
bsr st245
|
|
#endif
|
|
jsr _lseek
|
|
lea 12(sp),sp
|
|
cmp.l #-1,d0
|
|
bne 1f
|
|
move.l _errno,d0
|
|
mov d0,-(sp)
|
|
mov d0,-(sp)
|
|
bra 2f
|
|
1: move.l d0,-(sp)
|
|
cl -(sp)
|
|
2: move.l .retaddr,a0
|
|
jmp (a0)
|
|
|
|
_Xgetpid: move.l (sp)+,.retaddr
|
|
jsr _getpid
|
|
mov d0,-(sp)
|
|
move.l .retaddr,a0
|
|
jmp (a0)
|
|
|
|
_Xmount: move.l (sp)+,.retaddr
|
|
#ifndef lword
|
|
bsr st246
|
|
#endif
|
|
jsr _mount
|
|
lea 12(sp),sp
|
|
bra sys4
|
|
|
|
_Xumount: move.l (sp)+,.retaddr
|
|
jsr _umount
|
|
bra sys3
|
|
|
|
_Xsetuid: move.l (sp)+,.retaddr
|
|
#ifndef lword
|
|
bsr st241
|
|
#endif
|
|
jsr _setuid
|
|
bra sys3
|
|
|
|
_Xgetuid: move.l (sp)+,.retaddr
|
|
jsr _getuid
|
|
sys7: mov d1,-(sp)
|
|
mov d0,-(sp)
|
|
move.l .retaddr,a0
|
|
jmp (a0)
|
|
|
|
_Xstime: move.l (sp)+,.retaddr
|
|
jsr _stime
|
|
bra sys3
|
|
|
|
_Xptrace: move.l (sp)+,.retaddr
|
|
#ifndef lword
|
|
bsr st247
|
|
#endif
|
|
jsr _ptrace
|
|
lea 16(sp),sp
|
|
bra sys5
|
|
|
|
_Xalarm: move.l (sp)+,.retaddr
|
|
#ifndef lword
|
|
sub.l #2,sp
|
|
clr.w (sp)
|
|
#endif
|
|
jsr _alarm
|
|
lea 4(sp),sp
|
|
mov d0,-(sp)
|
|
move.l .retaddr,a0
|
|
jmp (a0)
|
|
|
|
_Xfstat: move.l (sp)+,.retaddr
|
|
#ifndef lword
|
|
bsr st241
|
|
#endif
|
|
jsr _fstat
|
|
lea 8(sp),sp
|
|
bra sys4
|
|
|
|
_Xpause: jsr _pause
|
|
rts
|
|
|
|
_Xutime: move.l (sp)+,.retaddr
|
|
jsr _utime
|
|
lea 8(sp),sp
|
|
bra sys4
|
|
|
|
_Xaccess: move.l (sp)+,.retaddr
|
|
#ifndef lword
|
|
bsr st243
|
|
#endif
|
|
jsr _access
|
|
lea 8(sp),sp
|
|
bra sys4
|
|
|
|
_Xnice: move.l (sp)+,.retaddr
|
|
#ifndef lword
|
|
bsr 241
|
|
#endif
|
|
jsr _nice
|
|
move.l .retaddr,(sp)
|
|
rts
|
|
|
|
_Xftime: move.l (sp)+,.retaddr
|
|
jsr _ftime
|
|
bra sys3
|
|
|
|
_Xsync: jsr _sync
|
|
rts
|
|
|
|
_Xkill: move.l (sp)+,.retaddr
|
|
#ifndef lword
|
|
bsr st248
|
|
#endif
|
|
jsr _kill
|
|
lea 4(sp),sp
|
|
bra sys4
|
|
|
|
_Xdup: move.l (sp)+,.retaddr
|
|
#ifndef lword
|
|
bsr st248
|
|
#endif
|
|
jsr _dup
|
|
bra sys1
|
|
|
|
_Xpipe: move.l (sp)+,.retaddr
|
|
move.l #xxxx,-(sp)
|
|
jsr _pipe
|
|
add.l #4,sp
|
|
bra sys6
|
|
|
|
_Xtimes: move.l (sp)+,.retaddr
|
|
jsr _times
|
|
move.l .retaddr,a0
|
|
add.l #4,sp
|
|
jmp (a0)
|
|
|
|
_Xprofil: move.l (sp)+,.retaddr
|
|
jsr _profil
|
|
move.l .retaddr,a0
|
|
lea 16(sp),sp
|
|
jmp (a0)
|
|
|
|
_Xsetgid: move.l (sp)+,.retaddr
|
|
#ifndef lword
|
|
bsr st241
|
|
#endif
|
|
jsr _setgid
|
|
bra sys3
|
|
|
|
_Xgetgid: move.l (sp)+,.retaddr
|
|
jsr _getgid
|
|
bra sys7
|
|
|
|
_Xsignal: move.l (sp)+,.retaddr
|
|
mov (sp)+,d4
|
|
extend d4
|
|
move.l d4,-(sp)
|
|
jsr _signal
|
|
lea 8(sp),sp !remove arguments
|
|
cmp.l #-1,d0
|
|
bne 1f
|
|
move.l _errno,d0
|
|
mov d0,-(sp)
|
|
mov d0,-(sp)
|
|
bra 2f
|
|
1:
|
|
mov d0,-(sp)
|
|
cl -(sp)
|
|
2:
|
|
move.l .retaddr,a0
|
|
jmp (a0)
|
|
|
|
_Xacct: move.l (sp)+,.retaddr
|
|
jsr _acct
|
|
bra sys3
|
|
!_Xlock: move.l (sp)+,.retaddr
|
|
!#ifndef lword
|
|
! bsr st241
|
|
!#endif
|
|
! jsr _lock
|
|
! bra sys3
|
|
|
|
_Xioctl: move.l (sp)+,.retaddr
|
|
#ifndef lword
|
|
bsr st248
|
|
#endif
|
|
#ifdef __USG
|
|
! only support TIOCGETP and TIOCSETP
|
|
move.l 4(sp),d0
|
|
cmp.l #0x7408,d0 ! TIOCGETP
|
|
bne 1f
|
|
move.l (sp)+,d0
|
|
move.l d0,(sp)
|
|
jsr _gtty
|
|
lea 8(sp),sp
|
|
bra sys4
|
|
1:
|
|
cmp.l #0x7409,d0 ! TIOCSETP
|
|
bne 9f
|
|
move.l (sp)+,d0
|
|
move.l d0,(sp)
|
|
jsr _stty
|
|
lea 8(sp),sp
|
|
bra sys4
|
|
#endif
|
|
#ifdef __BSD4_2
|
|
.sect .data
|
|
XXmapping:
|
|
.data4 0x7408,0x40067408 ! TIOCGETP
|
|
.data4 0x7409,0x80067409 ! TIOCSETP
|
|
.data4 0x740a,0x8006740a ! TIOCSETN
|
|
.data4 0x740d,0x2000740d ! TIOCEXCL
|
|
.data4 0x740e,0x2000740e ! TIOCNXCL
|
|
.data4 0x7402,0x20007402 ! TIOCHPCL
|
|
.data4 0x7412,0x40067412 ! TIOCGETC
|
|
.data4 0x7411,0x40067411 ! TIOCSETC
|
|
.data4 0
|
|
.sect .text
|
|
lea XXmapping, a0
|
|
move.l 4(sp),d0
|
|
1:
|
|
tst.l (a0)
|
|
beq 9f
|
|
cmp.l (a0),d0
|
|
beq 1f
|
|
add.l #8,a0
|
|
bra 1b
|
|
1:
|
|
move.l 4(a0),d0
|
|
move.l d0,4(sp)
|
|
#endif
|
|
9:
|
|
jsr _ioctl
|
|
lea 12(sp),sp
|
|
bra sys4
|
|
|
|
!_Xmpxcall: move.l (sp)+,.retaddr
|
|
!#ifndef lword
|
|
! bsr st241
|
|
!#endif
|
|
! trap #0
|
|
! .data2 56
|
|
! lea 12(sp),sp
|
|
! bra sys4
|
|
|
|
_Xexece: move.l (sp)+,.retaddr
|
|
jsr _execve
|
|
lea 12(sp),sp
|
|
bra sys4
|
|
|
|
_Xumask: move.l (sp)+,.retaddr
|
|
#ifndef lword
|
|
bsr st241
|
|
#endif
|
|
jsr _umask
|
|
add.l #4,sp
|
|
mov d0,-(sp)
|
|
move.l .retaddr,a0
|
|
jmp (a0)
|
|
|
|
_Xchroot: move.l (sp)+,.retaddr
|
|
jsr _chroot
|
|
bra sys3
|
|
|
|
|
|
!----------------------------------------------------------------------------
|
|
! STACK ADJUSTMENT FOR THE TWO BYTE INTERPRETER
|
|
!-----------------------------------------------------------------------------
|
|
#ifndef lword
|
|
|
|
st241: sub.l #2,sp
|
|
move.l 2(sp),(sp)
|
|
move.w 6(sp),d0
|
|
ext.l d0
|
|
move.l d0,4(sp)
|
|
rts
|
|
|
|
st243: sub.l #2,sp
|
|
move.l 2(sp),(sp)
|
|
move.l 6(sp),4(sp)
|
|
move.w 10(sp),d0
|
|
ext.l d0
|
|
move.l d0,8(sp)
|
|
rts
|
|
|
|
st244: move.l (sp),-(sp)
|
|
move.l 8(sp),4(sp)
|
|
move.w 12(sp),d0
|
|
ext.l d0
|
|
move.l d0,8(sp)
|
|
move.w 16(sp),d0
|
|
ext.l d0
|
|
move.l d0,12(sp)
|
|
rts
|
|
|
|
st245: move.l (sp),-(sp)
|
|
move.w 8(sp),d0
|
|
ext.l d0
|
|
move.l d0,4(sp)
|
|
move.l 10(sp),8(sp)
|
|
move.w 14(sp),d0
|
|
ext.l d0
|
|
move.l d0,12(sp)
|
|
rts
|
|
|
|
st246: sub.l #2,sp
|
|
move.l 2(sp),(sp)
|
|
move.l 6(sp),4(sp)
|
|
move.l 10(sp),8(sp)
|
|
move.w 14(sp),d0
|
|
ext.l d0
|
|
move.l d0,12(sp)
|
|
rts
|
|
|
|
st247: sub.l #6,sp
|
|
move.l 6(sp),(sp)
|
|
move.w 10(sp),d0
|
|
ext.l d0
|
|
move.l d0,4(sp)
|
|
move.w 12(sp),d0
|
|
ext.l d0
|
|
move.l d0,8(sp)
|
|
move.l 14(sp),12(sp)
|
|
move.w 18(sp),d0
|
|
ext.l d0
|
|
move.l d0,16(sp)
|
|
rts
|
|
|
|
st248: move.l (sp),-(sp)
|
|
move.w 8(sp),d0
|
|
ext.l d0
|
|
move.l d0,4(sp)
|
|
move.w 10(sp),d0
|
|
ext.l d0
|
|
move.l d0,8(sp)
|
|
rts
|
|
|
|
#endif
|