diff options
author | Jason Downs <downsj@cvs.openbsd.org> | 1997-02-23 21:42:56 +0000 |
---|---|---|
committer | Jason Downs <downsj@cvs.openbsd.org> | 1997-02-23 21:42:56 +0000 |
commit | b5d84b14e4aa07dac44d1522848b7fbaf98bdeca (patch) | |
tree | 2de3f918ac0dc0694796d21bda299103305adc23 /sys/arch | |
parent | 48baaf1e3293dfd3aea03d1b2e387f85045c417b (diff) |
Give HPUX it's own signal trampoline and stop modifying the real one.
Diffstat (limited to 'sys/arch')
-rw-r--r-- | sys/arch/hp300/hp300/locore.s | 21 | ||||
-rw-r--r-- | sys/arch/hp300/hp300/machdep.c | 45 |
2 files changed, 30 insertions, 36 deletions
diff --git a/sys/arch/hp300/hp300/locore.s b/sys/arch/hp300/hp300/locore.s index 2b445ae9e97..befe5387c3c 100644 --- a/sys/arch/hp300/hp300/locore.s +++ b/sys/arch/hp300/hp300/locore.s @@ -1,4 +1,4 @@ -/* $OpenBSD: locore.s,v 1.11 1997/02/10 11:13:28 downsj Exp $ */ +/* $OpenBSD: locore.s,v 1.12 1997/02/23 21:42:54 downsj Exp $ */ /* $NetBSD: locore.s,v 1.63 1997/02/02 07:55:52 thorpej Exp $ */ /* @@ -1156,13 +1156,12 @@ _proc_trampoline: * . * scp+0-> beginning of signal context frame */ - .globl _sigcode, _esigcode, _sigcodetrap + .globl _sigcode, _esigcode .data _sigcode: movl sp@(12),a0 | signal handler addr (4 bytes) jsr a0@ | call signal handler (2 bytes) addql #4,sp | pop signo (2 bytes) -_sigcodetrap: trap #1 | special syscall entry (2 bytes) movl d0,sp@(4) | save errno (4 bytes) moveq #1,d0 | syscall == exit (2 bytes) @@ -1171,6 +1170,22 @@ _sigcodetrap: _esigcode: /* + * ..And HPUX versions of the above. Hardcoded to use trap 2. + */ + .globl _hpux_sigcode, _hpux_esigcode + .data +_hpux_sigcode: + movl sp@(12),a0 | signal handler addr (4 bytes) + jsr a0@ | call signal handler (2 bytes) + addql #4,sp | pop signo (2 bytes) + trap #2 | special syscall entry (2 bytes) + movl d0,sp@(4) | save errno (4 bytes) + moveq #1,d0 | syscall == exit (2 bytes) + trap #0 | exit(errno) (2 bytes) + .align 2 +_hpux_esigcode: + +/* * Primitives */ diff --git a/sys/arch/hp300/hp300/machdep.c b/sys/arch/hp300/hp300/machdep.c index db97744d548..caa1630b516 100644 --- a/sys/arch/hp300/hp300/machdep.c +++ b/sys/arch/hp300/hp300/machdep.c @@ -1,4 +1,4 @@ -/* $OpenBSD: machdep.c,v 1.18 1997/02/10 11:13:30 downsj Exp $ */ +/* $OpenBSD: machdep.c,v 1.19 1997/02/23 21:42:55 downsj Exp $ */ /* $NetBSD: machdep.c,v 1.80 1997/02/02 07:58:49 thorpej Exp $ */ /* @@ -477,41 +477,12 @@ setregs(p, pack, stack, retval) #else retval[1] = 0; /* no 68881 */ #endif - } - /* - * XXX This doesn't have much to do with setting registers but - * I didn't want to muck up kern_exec.c with this code, so I - * stuck it here. - * - * Ensure we perform the right action on traps type 1 and 2: - * If our parent is an HPUX process and we are being traced, turn - * on HPUX style interpretation. Else if we were using the HPUX - * style interpretation, revert to the BSD interpretation. - * - * Note that we do this by changing the trap instruction in the - * global "sigcode" array which then gets copied out to the user's - * sigcode in the stack. Since we are changing it in the global - * array we must always reset it, even for non-HPUX processes. - * - * Note also that implementing it in this way creates a potential - * race where we could have tweaked it for process A which then - * blocks in the copyout to the stack and process B comes along - * and untweaks it causing A to wind up with the wrong setting - * when the copyout continues. However, since we have already - * copied something out to this user stack page (thereby faulting - * it in), this scenerio is extremely unlikely. - */ - { - extern short sigcodetrap[]; - if ((p->p_pptr->p_emul == &emul_hpux) && - (p->p_flag & P_TRACED)) { + /* Make sure the trace bit is correct. Doesn't belong here. */ + if (p->p_flag & P_TRACED) p->p_md.md_flags |= MDP_HPUXTRACE; - *sigcodetrap = 0x4E42; - } else { + else p->p_md.md_flags &= ~MDP_HPUXTRACE; - *sigcodetrap = 0x4E41; - } } #endif } @@ -793,6 +764,9 @@ sendsig(catcher, sig, mask, code, type, val) register short ft; int oonstack, fsize; extern char sigcode[], esigcode[]; +#ifdef COMPAT_HPUX + extern char hpux_sigcode[], hpux_esigcode[]; +#endif frame = (struct frame *)p->p_md.md_regs; ft = frame->f_format; @@ -955,6 +929,11 @@ sendsig(catcher, sig, mask, code, type, val) /* * Signal trampoline code is at base of user stack. */ +#ifdef COMPAT_HPUX + if (p->p_emul == &emul_hpux) + frame->f_pc = (int)PS_STRINGS - (hpux_esigcode - hpux_sigcode); + else +#endif frame->f_pc = (int)PS_STRINGS - (esigcode - sigcode); #ifdef DEBUG if ((sigdebug & SDB_KSTACK) && p->p_pid == sigpid) |