diff options
-rw-r--r-- | sys/arch/sh/sh/trap.c | 12 |
1 files changed, 6 insertions, 6 deletions
diff --git a/sys/arch/sh/sh/trap.c b/sys/arch/sh/sh/trap.c index beb89c031ee..24e3dd76e04 100644 --- a/sys/arch/sh/sh/trap.c +++ b/sys/arch/sh/sh/trap.c @@ -1,4 +1,4 @@ -/* $OpenBSD: trap.c,v 1.13 2008/06/24 21:24:03 deraadt Exp $ */ +/* $OpenBSD: trap.c,v 1.14 2008/10/04 19:21:50 miod Exp $ */ /* $NetBSD: exception.c,v 1.32 2006/09/04 23:57:52 uwe Exp $ */ /* $NetBSD: syscall.c,v 1.6 2006/03/07 07:21:50 thorpej Exp $ */ @@ -571,7 +571,7 @@ syscall(struct proc *p, struct trapframe *tf) #ifdef DIAGNOSTIC if (argsize > sizeof args) { callp += p->p_emul->e_nosys - code; - goto bad; + argsize = callp->sy_argsize; } #endif @@ -620,9 +620,6 @@ syscall(struct proc *p, struct trapframe *tf) break; } - if (error) - goto bad; - #ifdef SYSCALL_DEBUG scdebug_call(p, code, args); #endif @@ -631,6 +628,9 @@ syscall(struct proc *p, struct trapframe *tf) ktrsyscall(p, code, callp->sy_argsize, args); #endif + if (error != 0) + goto bad; + rval[0] = 0; rval[1] = tf->tf_r1; #if NSYSTRACE > 0 @@ -640,6 +640,7 @@ syscall(struct proc *p, struct trapframe *tf) #endif error = (*callp->sy_call)(p, args, rval); +bad: switch (oerror = error) { case 0: tf->tf_r0 = rval[0]; @@ -654,7 +655,6 @@ syscall(struct proc *p, struct trapframe *tf) /* nothing to do */ break; default: -bad: if (p->p_emul->e_errno) error = p->p_emul->e_errno[error]; tf->tf_r0 = error; |