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
 |