diff options
author | Paul Mackerras <paulus@samba.org> | 2005-04-16 15:24:17 -0700 |
---|---|---|
committer | Linus Torvalds <torvalds@ppc970.osdl.org> | 2005-04-16 15:24:17 -0700 |
commit | 6c26e03b2db4b66d79bfb774628c1fc9b458b943 (patch) | |
tree | 1e50046a2daa30da849a88b3ec562a410ebe6f80 | |
parent | e378cc16b0d3c1610857c4444345907020e03ece (diff) | |
download | blackbird-op-linux-6c26e03b2db4b66d79bfb774628c1fc9b458b943.tar.gz blackbird-op-linux-6c26e03b2db4b66d79bfb774628c1fc9b458b943.zip |
[PATCH] ppc32: fix single-stepping of emulated instructions
On ppc, we emulate instructions that cause alignment exceptions. If we are
single-stepping an instruction and it causes an alignment exception, we
will currently do the next instruction as well before taking the
single-step exception. This patch fixes that, so we take the single-step
exception after emulating the instruction.
Signed-off-by: Paul Mackerras <paulus@samba.org>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
-rw-r--r-- | arch/ppc/kernel/traps.c | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/arch/ppc/kernel/traps.c b/arch/ppc/kernel/traps.c index aec225b402ae..002322a1f3ce 100644 --- a/arch/ppc/kernel/traps.c +++ b/arch/ppc/kernel/traps.c @@ -679,6 +679,7 @@ void AlignmentException(struct pt_regs *regs) fixed = fix_alignment(regs); if (fixed == 1) { regs->nip += 4; /* skip over emulated instruction */ + emulate_single_step(regs); return; } if (fixed == -EFAULT) { |