|
From: Masami H. <mhi...@re...> - 2010-05-12 00:38:43
|
Mathieu Desnoyers wrote: > * Masami Hiramatsu (mhi...@re...) wrote: >> Use text_poke_smp_batch() in optimization path for reducing >> the number of stop_machine() issues. >> >> Signed-off-by: Masami Hiramatsu <mhi...@re...> >> Cc: Ananth N Mavinakayanahalli <an...@in...> >> Cc: Ingo Molnar <mi...@el...> >> Cc: Jim Keniston <jke...@us...> >> Cc: Jason Baron <jb...@re...> >> Cc: Mathieu Desnoyers <mat...@ef...> >> --- >> >> arch/x86/kernel/kprobes.c | 37 ++++++++++++++++++++++++++++++------- >> include/linux/kprobes.h | 2 +- >> kernel/kprobes.c | 13 +------------ >> 3 files changed, 32 insertions(+), 20 deletions(-) >> >> diff --git a/arch/x86/kernel/kprobes.c b/arch/x86/kernel/kprobes.c >> index 345a4b1..63a5c24 100644 >> --- a/arch/x86/kernel/kprobes.c >> +++ b/arch/x86/kernel/kprobes.c >> @@ -1385,10 +1385,14 @@ int __kprobes arch_prepare_optimized_kprobe(struct optimized_kprobe *op) >> return 0; >> } >> >> -/* Replace a breakpoint (int3) with a relative jump. */ >> -int __kprobes arch_optimize_kprobe(struct optimized_kprobe *op) >> +#define MAX_OPTIMIZE_PROBES 256 > > So what kind of interrupt latency does a 256-probes batch generate on the > system ? Are we talking about a few milliseconds, a few seconds ? >From my experiment on kvm/4cpu, it took about 3 seconds in average. With this patch, it went down to 30ms. (x100 faster :)) Thank you, -- Masami Hiramatsu e-mail: mhi...@re... |