diff options
author | Miod Vallat <miod@cvs.openbsd.org> | 2002-05-16 07:37:45 +0000 |
---|---|---|
committer | Miod Vallat <miod@cvs.openbsd.org> | 2002-05-16 07:37:45 +0000 |
commit | 09a74b063a5e7e41d98144e1733220dfa3c98a2a (patch) | |
tree | 851840662a255ff227aea7a906d19f4721bb7938 /distrib/sets/lists/base/md.sun3 | |
parent | e6e8fb6cb88169c8a66b3a8cc5e2102460c6faf8 (diff) |
Fix a long standing problem on vax: on "arithmetic fault" exceptions,
we schedule a SIGFPE signal delivery to the faulting process.
However, arithmetic faults come in two flavors: "traps" that are "regular"
exceptions, and "faults" that are restartable exceptions.
In the "fault" case, the frame pc points to the faulting instruction, instead
of the next instruction, in case we could save the world by tweaking memory
and make the instruction not fault again when restarted.
In practice, this led to processes blocked in a SIGFPE loop madness.
To avoid this, add a skip_opcode() routine to compute the address of the
next opcode, effectively skipping the offending instruction ; this routine
is a very stripped-down db_disasm().
While there, enhance the ddb disassembler to correctly recognize and
disassemble two-byte opcodes.
ok hugh@, deraadt@
Diffstat (limited to 'distrib/sets/lists/base/md.sun3')
0 files changed, 0 insertions, 0 deletions