]> git.baikalelectronics.ru Git - kernel.git/commit
kprobes/x86: Disable optimizing on the function jumps to indirect thunk
authorMasami Hiramatsu <mhiramat@kernel.org>
Thu, 18 Jan 2018 16:15:20 +0000 (01:15 +0900)
committerThomas Gleixner <tglx@linutronix.de>
Fri, 19 Jan 2018 15:31:29 +0000 (16:31 +0100)
commitf0f01c894fc9644ec41be727d0f5445da2eaab3b
tree2aef0f27035f4eb40311deb32d33ed167115a90e
parent4fe73a537d76e6526fdd45628713e3948800ab0c
kprobes/x86: Disable optimizing on the function jumps to indirect thunk

Since indirect jump instructions will be replaced by jump
to __x86_indirect_thunk_*, those jmp instruction must be
treated as an indirect jump. Since optprobe prohibits to
optimize probes in the function which uses an indirect jump,
it also needs to find out the function which jump to
__x86_indirect_thunk_* and disable optimization.

Add a check that the jump target address is between the
__indirect_thunk_start/end when optimizing kprobe.

Signed-off-by: Masami Hiramatsu <mhiramat@kernel.org>
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Acked-by: David Woodhouse <dwmw@amazon.co.uk>
Cc: Andi Kleen <ak@linux.intel.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Ananth N Mavinakayanahalli <ananth@linux.vnet.ibm.com>
Cc: Arjan van de Ven <arjan@linux.intel.com>
Cc: Greg Kroah-Hartman <gregkh@linux-foundation.org>
Cc: stable@vger.kernel.org
Link: https://lkml.kernel.org/r/151629212062.10241.6991266100233002273.stgit@devbox
arch/x86/kernel/kprobes/opt.c