[PATCH 00/23] tracehook

From: Roland McGrath
Date: Thu Jul 17 2008 - 03:26:30 EST


This patch series introduces the "tracehook" interface layer of inlines
in <linux/tracehook.h>. There are more details in the log entry for
patch 01/23 and in the header file comments inside that patch.
Most of these changes move code around with little or no change,
and they should not break anything or change any behavior.

This sets a new standard for uniform arch support to enable clean
arch-independent implementations of new debugging and tracing stuff,
denoted by CONFIG_HAVE_ARCH_TRACEHOOK. Patch 20/23 adds that symbol to
arch/Kconfig, with comments listing everything an arch has to do before
setting "select HAVE_ARCH_TRACEHOOK". These are elaborted a bit at:
http://sourceware.org/systemtap/wiki/utrace/arch/HowTo
The new inlines that arch code must define or call have detailed
kerneldoc comments in the generic header files that say what is required.

No arch is obligated to do any work, and no arch's build should be
broken by these changes. There are several steps that each arch should
take so it can set HAVE_ARCH_TRACEHOOK. Most of these are simple.
Providing this support will let new things people add for doing
debugging and tracing of user-level threads "just work" for your arch
in the future. For an arch that does not provide HAVE_ARCH_TRACEHOOK,
some new options for such features will not be available for config.

I have done some arch work and will submit this to the arch maintainers
after the generic tracehook series settles in. For now, that work is
available in my GIT repositories, and in patch and mbox-of-patches form
at http://people.redhat.com/roland/utrace/2.6-current/

This paves the way for my "utrace" work, to be submitted later. But it
is not innately tied to that. I hope that the tracehook series can go
in soon regardless of what eventually does or doesn't go on top of it.
For anyone implementing any kind of new tracing/debugging plan, or just
understanding all the context of the existing ptrace implementation,
having tracehook.h makes things much easier to find and understand.

This series must be applied after the "ptrace & wait cleanup" series,
but only because of patch conflicts. They can be reviewed separately.

This series of patches is also available in GIT at the URL below, and in a
mail folder of patch messages (use git-am or formail -s patch -p1) at:
http://people.redhat.com/roland/utrace/2.6-current/tracehook.mbox

The following changes since commit 666f164f4fbfa78bd00fb4b74788b42a39842c64:
Roland McGrath (1):
fix dangling zombie when new parent ignores children

are available in the git repository at:

git://git.kernel.org/pub/scm/linux/kernel/git/frob/linux-2.6-utrace.git tracehook

Roland McGrath (23):
tracehook: add linux/tracehook.h
tracehook: exec
tracehook: unexport ptrace_notify
tracehook: exit
tracehook: clone
tracehook: vfork-done
tracehook: release_task
tracehook: tracehook_tracer_task
tracehook: tracehook_expect_breakpoints
tracehook: tracehook_signal_handler
tracehook: tracehook_consider_ignored_signal
tracehook: tracehook_consider_fatal_signal
tracehook: syscall
tracehook: get_signal_to_deliver
tracehook: job control
tracehook: death
tracehook: force signal_pending()
tracehook: TIF_NOTIFY_RESUME
tracehook: asm/syscall.h
tracehook: CONFIG_HAVE_ARCH_TRACEHOOK
tracehook: wait_task_inactive
task_current_syscall
/proc/PID/syscall

arch/Kconfig | 18 ++
arch/ia64/kernel/perfmon.c | 4 +-
arch/x86/ia32/ia32_aout.c | 6 -
fs/binfmt_aout.c | 6 -
fs/binfmt_elf.c | 6 -
fs/binfmt_elf_fdpic.c | 7 -
fs/binfmt_flat.c | 3 -
fs/binfmt_som.c | 2 -
fs/exec.c | 12 +-
fs/proc/array.c | 9 +-
fs/proc/base.c | 39 +++-
include/asm-generic/syscall.h | 141 ++++++++++
include/linux/ptrace.h | 72 +++++
include/linux/sched.h | 10 +-
include/linux/tracehook.h | 575 +++++++++++++++++++++++++++++++++++++++++
kernel/exit.c | 53 ++---
kernel/fork.c | 74 ++----
kernel/kthread.c | 2 +-
kernel/ptrace.c | 2 +-
kernel/sched.c | 29 ++-
kernel/signal.c | 99 +++++---
lib/Makefile | 2 +
lib/syscall.c | 75 ++++++
mm/nommu.c | 4 +-
security/selinux/hooks.c | 22 +--
25 files changed, 1084 insertions(+), 188 deletions(-)
create mode 100644 include/asm-generic/syscall.h
create mode 100644 include/linux/tracehook.h
create mode 100644 lib/syscall.c


Thanks,
Roland
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/