Added _syscall.s and _sigvec.c

This commit is contained in:
ceriel 1990-11-29 16:13:49 +00:00
parent 45b18b4fc9
commit ff60fa58c3
3 changed files with 52 additions and 0 deletions

View file

@ -138,6 +138,7 @@ sigsetmask.s
_sigsetmask.s _sigsetmask.s
sigstack.s sigstack.s
sigtramp.s sigtramp.s
_sigvec.c
sigvec.c sigvec.c
socket.s socket.s
socketpair.s socketpair.s
@ -147,6 +148,7 @@ statfs.s
swapon.s swapon.s
symlink.s symlink.s
sync.s sync.s
_syscall.s
syscall.s syscall.s
time.c time.c
times.c times.c

View file

@ -0,0 +1,36 @@
#include "syscall.h"
#include <errno.h>
struct sigvec { int (*handler)(); int mask,flags; };
int (*(_sigfunc[32]))();
extern int _sigtramp();
extern int errno;
_sigvec(sig,vec,ovec)
register struct sigvec *vec;
struct sigvec *ovec;
{
struct sigvec tmp;
int (*old)();
if ((unsigned) sig >= 32) {
errno = EINVAL;
return -1;
}
old = _sigfunc[sig];
if (vec) {
tmp = *vec;
vec = &tmp;
if (vec->handler && vec->handler != (int (*)()) 1) {
_sigfunc[sig] = vec->handler;
vec->handler = _sigtramp;
}
}
if (_syscall(SYS_sigvec,sig,vec,ovec) < 0) {
_sigfunc[sig] = old;
return -1;
}
if (ovec && ovec->handler == _sigtramp) {
ovec->handler = old;
}
return 0;
}

View file

@ -0,0 +1,14 @@
.sect .text
.define __syscall
__syscall:
move.l 4(sp),d0
move.l (sp),4(sp)
move.l d0,(sp)
trap #0
bcs 1f
move.l (sp),a0
jmp (a0)
1:
move.l (sp),a0
move.l a0,-(sp)
jmp cerror