Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753841AbbFAQdE (ORCPT ); Mon, 1 Jun 2015 12:33:04 -0400 Received: from collab.rosalab.ru ([195.19.76.181]:38386 "EHLO collab.rosalab.ru" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753725AbbFAQc4 (ORCPT ); Mon, 1 Jun 2015 12:32:56 -0400 From: Eugene Shatokhin To: Masami Hiramatsu , Ingo Molnar Cc: Andy Lutomirski , Ingo Molnar , LKML Subject: [PATCH 0/2] kprobes/x86: Allow "boost" for 10- and 11-byte instructions Date: Mon, 1 Jun 2015 19:32:09 +0300 Message-Id: <1433176331-479-1-git-send-email-eugene.shatokhin@rosalab.ru> X-Mailer: git-send-email 2.3.2 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1488 Lines: 24 Kprobes' "boost" feature allows to avoid single-stepping in some cases, along with its overhead. It is useful for the Kprobes that cannot be optimized for some reason. Currently, "boost" cannot be applied to the instructions of 10 and 11 bytes in size, including some rather commonly used kinds of MOV. The first of the two patches in this series fixes the code that checks if the jump needed for the boost fits in the insn slot (the conditional is too strict). This allows to apply "boost" to 10-byte instructions. As a side effect of commit 91e5ed49fca0 ("x86/asm/decoder: Fix and enforce max instruction size in the insn decoder"), the size of the instruction slot became 1 byte smaller, 15 bytes VS 16 bytes before that change. The second patch makes the size of each insn slot 16 bytes again (while keeping MAX_INSN_SIZE as 15). This allows to apply "boost" to 11-byte instructions as well. I have checked that "boost" does happen for at least "movq $0x1,0x100(%rbx)" (48 c7 83 00 01 00 00 01 00 00 00) in the kernel 4.1-rc6 after these changes. arch/x86/include/asm/kprobes.h | 1 + arch/x86/kernel/kprobes/core.c | 2 +- kernel/kprobes.c | 8 ++++++-- 3 files changed, 8 insertions(+), 3 deletions(-) Regards, Eugene -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/