290ba3aef5
Use the generic ptrace_resume code for PTRACE_SYSCALL, PTRACE_CONT, PTRACE_KILL and PTRACE_SINGLESTEP. This implies defining arch_has_single_step in <asm/ptrace.h> and implementing the user_enable_single_step and user_disable_single_step functions, which also causes the breakpoint information to be cleared on fork, which could be considered a bug fix. Also the TIF_SYSCALL_TRACE thread flag is now cleared on PTRACE_KILL which it previously wasn't which is consistent with all architectures using the modern ptrace code. The way breakpoints are disabled is entirely inconsistent currently, I tried to make some sense of it, but I suspect all of the content of ptrace_disable should be moved into user_disable_single_step, this defintively needs some revisting as the current patch changes behaviour in not quite designed ways. Signed-off-by: Christoph Hellwig <hch@lst.de> Cc: Oleg Nesterov <oleg@redhat.com> Cc: Roland McGrath <roland@redhat.com> Cc: Mikael Starvik <starvik@axis.com> Cc: Jesper Nilsson <jesper.nilsson@axis.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org> |
||
---|---|---|
.. | ||
hwregs | ||
atomic.h | ||
bitops.h | ||
bug.h | ||
cache.h | ||
checksum.h | ||
cryptocop.h | ||
delay.h | ||
dma.h | ||
elf.h | ||
intmem.h | ||
io.h | ||
irq.h | ||
Kbuild | ||
memmap.h | ||
mmu.h | ||
offset.h | ||
page.h | ||
pgtable.h | ||
processor.h | ||
ptrace.h | ||
spinlock.h | ||
swab.h | ||
system.h | ||
thread_info.h | ||
timex.h | ||
tlb.h | ||
uaccess.h | ||
unistd.h | ||
user.h |