Received: by 10.213.65.68 with SMTP id h4csp164619imn; Mon, 19 Mar 2018 23:39:21 -0700 (PDT) X-Google-Smtp-Source: AG47ELtnKeA01gSFuh9f63qY6y+VK91esb/PN7icvxFJoEvUY/+NKmbycSPbTwAVtaGyLAFv+W6r X-Received: by 2002:a17:902:9898:: with SMTP id s24-v6mr15377130plp.382.1521527961384; Mon, 19 Mar 2018 23:39:21 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1521527961; cv=none; d=google.com; s=arc-20160816; b=MQ4Dzi5zlU8gPr7J31bOec50T5rIvmz8tVnCFmSVwvJ5/eg4AICTIm2D0XAgEaOjWO +GYI5xhJD77wO0rlKaH6+WnakmvD7CtIAAb+9bX3cxwZsj2bmR/t7eutoXcfad+Tqg1y HJkBLXpwfJ8Zz4ExJsP6tf7UohOH9g/x45u1DVdHd0kdwGzvnsCzGD0i534Bpv6ejFvg o9dpnmfQR2P2XA/vS94X5BSfYOKc+ZtefPcTcHA3Wz36xr91huzmWwrpwNn99pSab2Cm yva76Lsc3fvAgE+5Xi/cnp9NSr5YmkJz0MU+HKzbrtCxbTSJDn+gYNm1YUeJOFecGpOf kVKw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-disposition :content-transfer-encoding:mime-version:robot-unsubscribe:robot-id :git-commit-id:subject:to:references:in-reply-to:reply-to:cc :message-id:from:date:arc-authentication-results; bh=Hy+et/kemlQpQiiq3soZqbpOVJsT2oTkcc2cTOEoibc=; b=mh59/HaL7GRcv921/qU6hvztUgeJUWsBByXQu+Fk1Wxja+fA4eDaF6rcPO7CyPlNuk bC2KwA+1Bd3g4IpoHt9Etm3NxGn9FGoArdrkohoKDLdqxfvEM4N5b/5lAqk0va2B7O6I m9fJizfGEQvKMWVj/PZt+4XSM9uBgPbn+hjDAUrUJjmZ5OIfucMf8wAt5kPTLeL4CvGm oAd1s2jJkfCHJ+y+iL8CE9a6rivKY4jVaarWNdA2OvR/2V+di4oKbSnaaFwrvE3MDE1f eGyC5sxD5Oxz7L1rz0OgWgNZZ+duPdqKtSpyJOW144040ppXn9WqznFJQ1H+4SieNhtp YeSQ== 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 j91-v6si973847pld.202.2018.03.19.23.39.07; Mon, 19 Mar 2018 23:39:21 -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 S1752077AbeCTGgl (ORCPT + 99 others); Tue, 20 Mar 2018 02:36:41 -0400 Received: from terminus.zytor.com ([198.137.202.136]:56397 "EHLO terminus.zytor.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751450AbeCTGgh (ORCPT ); Tue, 20 Mar 2018 02:36:37 -0400 Received: from terminus.zytor.com (localhost [127.0.0.1]) by terminus.zytor.com (8.15.2/8.15.2) with ESMTP id w2K6aIrD032129; Mon, 19 Mar 2018 23:36:18 -0700 Received: (from tipbot@localhost) by terminus.zytor.com (8.15.2/8.15.2/Submit) id w2K6aHtG032126; Mon, 19 Mar 2018 23:36:17 -0700 Date: Mon, 19 Mar 2018 23:36:17 -0700 X-Authentication-Warning: terminus.zytor.com: tipbot set sender to tipbot@zytor.com using -f From: tip-bot for Masami Hiramatsu Message-ID: Cc: linux-kernel@vger.kernel.org, rostedt@goodmis.org, shuah@kernel.org, acme@redhat.com, mingo@kernel.org, mhiramat@kernel.org, ravi.bangoria@linux.vnet.ibm.com, tom.zanussi@linux.intel.com, hpa@zytor.com, tglx@linutronix.de, namhyung@kernel.org Reply-To: ravi.bangoria@linux.vnet.ibm.com, hpa@zytor.com, tom.zanussi@linux.intel.com, tglx@linutronix.de, namhyung@kernel.org, rostedt@goodmis.org, shuah@kernel.org, linux-kernel@vger.kernel.org, acme@redhat.com, mingo@kernel.org, mhiramat@kernel.org In-Reply-To: <152129114502.31874.2474068470011496356.stgit@devbox> References: <152129114502.31874.2474068470011496356.stgit@devbox> To: linux-tip-commits@vger.kernel.org Subject: [tip:perf/core] perf probe: Use right type to access array elements Git-Commit-ID: d0461794a1dcaf552b507e23788777f718b736a1 X-Mailer: tip-git-log-daemon Robot-ID: Robot-Unsubscribe: Contact to get blacklisted from these emails MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Content-Type: text/plain; charset=UTF-8 Content-Disposition: inline X-Spam-Status: No, score=-2.9 required=5.0 tests=ALL_TRUSTED,BAYES_00 autolearn=ham autolearn_force=no version=3.4.1 X-Spam-Checker-Version: SpamAssassin 3.4.1 (2015-04-28) on terminus.zytor.com Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Commit-ID: d0461794a1dcaf552b507e23788777f718b736a1 Gitweb: https://git.kernel.org/tip/d0461794a1dcaf552b507e23788777f718b736a1 Author: Masami Hiramatsu AuthorDate: Sat, 17 Mar 2018 21:52:25 +0900 Committer: Arnaldo Carvalho de Melo CommitDate: Mon, 19 Mar 2018 13:51:53 -0300 perf probe: Use right type to access array elements Current 'perf probe' converts the type of array-elements incorrectly. It always converts the types as a pointer of array. This passes the "array" type DIE to the type converter so that it can get correct "element of array" type DIE from it. E.g. ==== $ cat hello.c #include void foo(int a[]) { printf("%d\n", a[1]); } void main() { int a[3] = {4, 5, 6}; printf("%d\n", a[0]); foo(a); } $ gcc -g hello.c -o hello $ perf probe -x ./hello -D "foo a[1]" ==== Without this fix, above outputs ==== p:probe_hello/foo /tmp/hello:0x4d3 a=+4(-8(%bp)):u64 ==== The "u64" means "int *", but a[1] is "int". With this, ==== p:probe_hello/foo /tmp/hello:0x4d3 a=+4(-8(%bp)):s32 ==== So, "int" correctly converted to "s32" Signed-off-by: Masami Hiramatsu Tested-by: Arnaldo Carvalho de Melo Cc: Namhyung Kim Cc: Ravi Bangoria Cc: Shuah Khan Cc: Steven Rostedt Cc: Tom Zanussi Cc: linux-kselftest@vger.kernel.org Cc: linux-trace-users@vger.kernel.org Fixes: b2a3c12b7442 ("perf probe: Support tracing an entry of array") Link: http://lkml.kernel.org/r/152129114502.31874.2474068470011496356.stgit@devbox Signed-off-by: Arnaldo Carvalho de Melo --- tools/perf/util/probe-finder.c | 13 +++++-------- 1 file changed, 5 insertions(+), 8 deletions(-) diff --git a/tools/perf/util/probe-finder.c b/tools/perf/util/probe-finder.c index a5731de0e5eb..c37fbef1711d 100644 --- a/tools/perf/util/probe-finder.c +++ b/tools/perf/util/probe-finder.c @@ -423,20 +423,20 @@ static int convert_variable_fields(Dwarf_Die *vr_die, const char *varname, pr_warning("Failed to get the type of %s.\n", varname); return -ENOENT; } - pr_debug2("Var real type: (%x)\n", (unsigned)dwarf_dieoffset(&type)); + pr_debug2("Var real type: %s (%x)\n", dwarf_diename(&type), + (unsigned)dwarf_dieoffset(&type)); tag = dwarf_tag(&type); if (field->name[0] == '[' && (tag == DW_TAG_array_type || tag == DW_TAG_pointer_type)) { - if (field->next) - /* Save original type for next field */ - memcpy(die_mem, &type, sizeof(*die_mem)); + /* Save original type for next field or type */ + memcpy(die_mem, &type, sizeof(*die_mem)); /* Get the type of this array */ if (die_get_real_type(&type, &type) == NULL) { pr_warning("Failed to get the type of %s.\n", varname); return -ENOENT; } - pr_debug2("Array real type: (%x)\n", + pr_debug2("Array real type: %s (%x)\n", dwarf_diename(&type), (unsigned)dwarf_dieoffset(&type)); if (tag == DW_TAG_pointer_type) { ref = zalloc(sizeof(struct probe_trace_arg_ref)); @@ -448,9 +448,6 @@ static int convert_variable_fields(Dwarf_Die *vr_die, const char *varname, *ref_ptr = ref; } ref->offset += dwarf_bytesize(&type) * field->index; - if (!field->next) - /* Save vr_die for converting types */ - memcpy(die_mem, vr_die, sizeof(*die_mem)); goto next; } else if (tag == DW_TAG_pointer_type) { /* Check the pointer and dereference */