Received: by 10.223.185.116 with SMTP id b49csp6060960wrg; Thu, 8 Mar 2018 00:51:48 -0800 (PST) X-Google-Smtp-Source: AG47ELsD3aUjpmUAA41FcjvnsHplSDqFkuQDdhIIU6ARWRb+30h+lZJMPPzLr9ejVt2hZH6kbxJ2 X-Received: by 10.101.90.140 with SMTP id c12mr20102285pgt.56.1520499107932; Thu, 08 Mar 2018 00:51:47 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1520499107; cv=none; d=google.com; s=arc-20160816; b=q0TZkeAtGyvO4LRFFyCTzGnaby/AwOHHimU1rJiSAJy/QFWEhgDXeC66XZgpkEqoN/ ZSZBtUvNe+gnPmrq7C0aHj9C33T49LIBoEQVIliL8e1xmmNj2qzPgAsV6xhzmo/XBZM+ gnAJBQrDQvZjRvm2wjZKi5t4D5muUaQbhA7o1ggboVAbRW35N/6qLFkhNRkJ4oG8umAM WWFXluD8DdPTQeBZfU7p1mluEKA6uNby/WFMMdjrs8W3rt0RNfXmHj2XLoW25tdlA0VV +6RPwRoEBCaLvYQD+dBzZ2Hy8+qtGQCE3+3qe6WM4+NWglYfvoAAD/oZAO2aImiEtjAD G4+A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dmarc-filter:arc-authentication-results; bh=sVc9CE+xPsnKZd88hd6LnzxvvhUmt1sMr9HCi5RIja0=; b=QEAmIo/+CgsBYVZdMN8ge/VVm/rJemujBmwDGoCYvp1eJv2iy7v/qoV0knheHk0X0N cuM+bxVg9f03y3xe9pL8UQpaLbRD79DV/OH82B5nQXmvIdWrD7S8gyzoktgq9wnZ6nDs gTEAmizzImrdcodXhMH5TzyiD/ESHAwmtjSjO5xjm864Yf7ShnEyR3wSuu/kwTyuzVzB iqjG8+7uAfg+c72y1joLMLLnk3vQwA9ynUdbLXphKhSYQIqtCLNursii/Qfw4WLkvZ4A qBsbYt0NGylhCpiE8sKXnwwysrQFhMlsmBgK2SHS5XCMkrW6fxBSVBYc1PnHXliBnqls cVgg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id c4si12579341pgn.347.2018.03.08.00.51.33; Thu, 08 Mar 2018 00:51:47 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S935662AbeCHIuT (ORCPT + 99 others); Thu, 8 Mar 2018 03:50:19 -0500 Received: from mail.kernel.org ([198.145.29.99]:50872 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1755300AbeCHIuR (ORCPT ); Thu, 8 Mar 2018 03:50:17 -0500 Received: from localhost.localdomain (NE2965lan1.rev.em-net.ne.jp [210.141.244.193]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 2DADE2133D; Thu, 8 Mar 2018 08:50:15 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org 2DADE2133D Authentication-Results: mail.kernel.org; dmarc=none (p=none dis=none) header.from=kernel.org Authentication-Results: mail.kernel.org; spf=none smtp.mailfrom=mhiramat@kernel.org From: Masami Hiramatsu To: Steven Rostedt , linux-kernel@vger.kernel.org Cc: mhiramat@kernel.org, Ingo Molnar , Namhyung Kim , Tom Zanussi , Arnaldo Carvalho de Melo , linux-trace-users@vger.kernel.org, linux-kselftest@vger.kernel.org, shuah@kernel.org Subject: [PATCH v5 14/19] x86: ptrace: Add function argument access API Date: Thu, 8 Mar 2018 17:49:53 +0900 Message-Id: <152049899313.7289.13604299638167618228.stgit@devbox> X-Mailer: git-send-email 2.13.6 In-Reply-To: <152049860385.7289.14079393589900496424.stgit@devbox> References: <152049860385.7289.14079393589900496424.stgit@devbox> User-Agent: StGit/0.17.1-dirty MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Add regs_get_argument() which returns N th argument of the function call. Note that this chooses most probably assignment, in some case it can be incorrect (e.g. passing data structure or floating point etc.) This is expected to be called from kprobes or ftrace with regs where the top of stack is the return address. Signed-off-by: Masami Hiramatsu --- arch/Kconfig | 7 +++++++ arch/x86/Kconfig | 1 + arch/x86/include/asm/ptrace.h | 38 ++++++++++++++++++++++++++++++++++++++ 3 files changed, 46 insertions(+) diff --git a/arch/Kconfig b/arch/Kconfig index 76c0b54443b1..4126ad4b122c 100644 --- a/arch/Kconfig +++ b/arch/Kconfig @@ -272,6 +272,13 @@ config HAVE_REGS_AND_STACK_ACCESS_API declared in asm/ptrace.h For example the kprobes-based event tracer needs this API. +config HAVE_FUNCTION_ARG_ACCESS_API + bool + help + This symbol should be selected by an architecure if it supports + the API needed to access function arguments from pt_regs, + declared in asm/ptrace.h + config HAVE_CLK bool help diff --git a/arch/x86/Kconfig b/arch/x86/Kconfig index 18233e459bff..5dde520da3b5 100644 --- a/arch/x86/Kconfig +++ b/arch/x86/Kconfig @@ -176,6 +176,7 @@ config X86 select HAVE_PERF_USER_STACK_DUMP select HAVE_RCU_TABLE_FREE select HAVE_REGS_AND_STACK_ACCESS_API + select HAVE_FUNCTION_ARG_ACCESS_API select HAVE_RELIABLE_STACKTRACE if X86_64 && UNWINDER_FRAME_POINTER && STACK_VALIDATION select HAVE_STACK_VALIDATION if X86_64 select HAVE_SYSCALL_TRACEPOINTS diff --git a/arch/x86/include/asm/ptrace.h b/arch/x86/include/asm/ptrace.h index 6de1fd3d0097..c2304b25e2fd 100644 --- a/arch/x86/include/asm/ptrace.h +++ b/arch/x86/include/asm/ptrace.h @@ -256,6 +256,44 @@ static inline unsigned long regs_get_kernel_stack_nth(struct pt_regs *regs, return 0; } +/** + * regs_get_kernel_argument() - get Nth function argument in kernel + * @regs: pt_regs of that context + * @n: function argument number (start from 0) + * + * regs_get_argument() returns @n th argument of the function call. + * Note that this chooses most probably assignment, in some case + * it can be incorrect. + * This is expected to be called from kprobes or ftrace with regs + * where the top of stack is the return address. + */ +static inline unsigned long regs_get_kernel_argument(struct pt_regs *regs, + unsigned int n) +{ + static const unsigned int argument_offs[] = { +#ifdef __i386__ + offsetof(struct pt_regs, ax), + offsetof(struct pt_regs, cx), + offsetof(struct pt_regs, dx), +#define NR_REG_ARGUMENTS 3 +#else + offsetof(struct pt_regs, di), + offsetof(struct pt_regs, si), + offsetof(struct pt_regs, dx), + offsetof(struct pt_regs, cx), + offsetof(struct pt_regs, r8), + offsetof(struct pt_regs, r9), +#define NR_REG_ARGUMENTS 6 +#endif + }; + + if (n >= NR_REG_ARGUMENTS) { + n -= NR_REG_ARGUMENTS - 1; + return regs_get_kernel_stack_nth(regs, n); + } else + return regs_get_register(regs, argument_offs[n]); +} + #define arch_has_single_step() (1) #ifdef CONFIG_X86_DEBUGCTLMSR #define arch_has_block_step() (1)