Received: by 10.213.65.68 with SMTP id h4csp338384imn; Sat, 17 Mar 2018 05:54:37 -0700 (PDT) X-Google-Smtp-Source: AG47ELvnNj5driRY4kbUntu+dWKWQ6AMiTawOVyiMSZgTBkPd2RmPTRF7RlVybSqcLIUXYvRqz4S X-Received: by 2002:a17:902:6a17:: with SMTP id m23-v6mr5581322plk.342.1521291277543; Sat, 17 Mar 2018 05:54:37 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1521291277; cv=none; d=google.com; s=arc-20160816; b=qbuw3wFh8ym7d50fCBjoXkxK1gOYJH8PzwbLj+/KJbfHKHIj0bL6qm5OQO6iUoy+BD 7XBfYlK4J69YAqfDYtsPzXVF+G2pEVzlE0CZ7+2vKYIQMuM1elfx4fyAOdLwr7lQivn1 cDLHVSy9RpRenPqjfKRW6n7k+4asEypVQ4ket2le+PXe0cDKLj0JzxwT8WWyoGO6+Zxb ha6LTFe8Th1I3cOT4b7gt6r3EOqrQ5OHKCXEt/I7rR6JTJDCyVk+96g3Gl9b731W4E+c ssdcIvscdplpIPl+gb6mchdxkjs/LkALuVtv54UvavhsM1lS5YLRlpYa2DmwYmao46TZ qiRw== 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=8hGm8jBerqZY6eesimj5xHVQK+IWr3u/p1kfpa3PuJU=; b=XUqtL9g42nm4K6y/NAiG+XpclzsjKFdOEmaJ0pSJRcwybOBvWHTLS2vi5rlpqWd3Gv +opXOGYuhjxlk0bV72cMYNaTsVZQDqXDq2wlyHNlwbiAZamlR68bGMwBlHYAGGn30Gu7 rQcjWKktUlm0CVTWBXkprK2KSJ2KxFiJxl6865ia87TR8nzG1b0RqqWceLIS83IHs9ta O67RWOAw+KCht3OmFHba5C5xVFV9g6Nr518Ae2SJUAEWJsUwTTjaJ+fAFeRP2L5Vpcwm 2hSzCI0YedxzfrnuHBXYmz/+CPqefbE12NLbOU3YxZtMuDTWRJpn3kwfaTcGGmhqq6H0 5Ikg== 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 h7si3053611pgn.279.2018.03.17.05.54.23; Sat, 17 Mar 2018 05:54:37 -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 S1752888AbeCQMxK (ORCPT + 99 others); Sat, 17 Mar 2018 08:53:10 -0400 Received: from mail.kernel.org ([198.145.29.99]:52838 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752775AbeCQMxJ (ORCPT ); Sat, 17 Mar 2018 08:53:09 -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 095A621720; Sat, 17 Mar 2018 12:52:56 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org 095A621720 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 20/21] [RESEND] perf-probe: Fix to convert array type collectly Date: Sat, 17 Mar 2018 21:52:25 +0900 Message-Id: <152129114502.31874.2474068470011496356.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 Fix to convert array element type collectly. 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" Fixes: b2a3c12b7442 ("perf probe: Support tracing an entry of array") Signed-off-by: Masami Hiramatsu --- 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 */