Received: by 10.213.65.68 with SMTP id h4csp336534imn; Sat, 17 Mar 2018 05:49:56 -0700 (PDT) X-Google-Smtp-Source: AG47ELvK4OMmRbcrG+G5MkvpKewaO82bBdrZM+8lISXO23GmU6f68RR0Jumff5uTn4WeI40RpgXD X-Received: by 10.101.72.199 with SMTP id o7mr4293970pgs.303.1521290996021; Sat, 17 Mar 2018 05:49:56 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1521290995; cv=none; d=google.com; s=arc-20160816; b=wHJ3OPt44liKXsyCbyIZiXSAJjE4u18EN+ATmaivrxPYweqZ5KFggi0Qci2Z0OSVJl 1pa40ANenaaFAxxCc+pFsLOa4D77uMh6G38JyfHF7XW46ygwMB4yC0agr+o4hwe5tnqA LPhN81r1liRohFg06+hV/u4uUx8dks0aGqReoiaw4BtWt1QC26P0Q/LafshS1E51g+rt VoaKzaIqUbKoU3fFL4Y9UHUsCIRoVSSv53fqMutKbMqposPu/Nnhwql1D2cueLpskTP/ J5jxGXIPrz3gKZuxeJx7+sBMBtUW4364ulEXG+ewZ3zZD7jKqQuH6ZzCSEsWXRDKisvL E38A== 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=jtOlDTKTfLbVinPX5QDwcEwq7Q7diJ76SaSUZeEnIGI=; b=Xv4GOskp34gqRq8Vd9/YbA4rDavAtWQlTTF9qfG3RTLBVJAfLaP1arYoaEMQuhvfk9 r4byOrUuYE2v4DUlVsSpN1S15BvYLG5laqINBbJQG809YcKH45o7yAopAfClZOVdAk5u 5hxRm/0peDqWfA+h8eGbHp0E6FdTwUN7S7IXllcQY8g9/OoX7WI0tSD5Q+U0CCsw3yU/ gP4z2oCMun9+Wj8LK9uH1+T3q+fcyZG35o/P2UQHtBaWNnInoPq0fkUz47ipa4gq0BNy 8hdgG+NOcN3g61I/dVNWIPydCEvAFuzpxMJ7whSs57p2szxn8bvQQuL8Fkq24bGBF7gh XWLA== 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 99-v6si7942753plf.56.2018.03.17.05.49.41; Sat, 17 Mar 2018 05:49:55 -0700 (PDT) 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 S1753190AbeCQMsl (ORCPT + 99 others); Sat, 17 Mar 2018 08:48:41 -0400 Received: from mail.kernel.org ([198.145.29.99]:51972 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752723AbeCQMsj (ORCPT ); Sat, 17 Mar 2018 08:48:39 -0400 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 0DC81217D2; Sat, 17 Mar 2018 12:48:24 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org 0DC81217D2 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, Ravi Bangoria Subject: [PATCH v6 14/21] x86: ptrace: Add function argument access API Date: Sat, 17 Mar 2018 21:47:53 +0900 Message-Id: <152129087298.31874.16468026611863630807.stgit@devbox> X-Mailer: git-send-email 2.13.6 In-Reply-To: <152129024033.31874.15800253385376959274.stgit@devbox> References: <152129024033.31874.15800253385376959274.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 3b037bc589ab..1ac63d118224 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)