Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp13559225ybl; Sun, 29 Dec 2019 15:01:13 -0800 (PST) X-Google-Smtp-Source: APXvYqwvthQQ685VFcsyu3V6WtVp2oyp5CKrBtq7B0m/27NBv7hs1ACrP/CsbUNciNCY9Lqn/QJI X-Received: by 2002:a9d:7757:: with SMTP id t23mr73960944otl.315.1577660473165; Sun, 29 Dec 2019 15:01:13 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1577660473; cv=none; d=google.com; s=arc-20160816; b=p0HZpjE4QHmwr+AID+hV10MSiYt1QMr7PHXGkCZU84cvrNfbckZHayPKvelvKTz+Yg 8Dq2Ld419rIlErRuygDwXG+Ph+MrhURt8lt4arclaqLHh0mEnlCWVf3pNHy51DrF3u9V tj64aa/+BQcO7kS9g0XHR6fwMvS/5t1BQ/VkkMqJWFjaDtG7KxKDB53hobSyG3mZ3NFr k05GDuiBrwzNdydkgaAMNGMRkFBoJFVHo6xmntmCH7Bj9ozQV3/Z5K86HGLzLirqPvnw 2Fuw2rOkotkyUaOAVLg2pqxXmR+5ZMhMfGnaNxJDYhgzNESaqJfquGpWSprV7DqWqSoO TwzA== 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 :content-language:in-reply-to:mime-version:date:message-id :references:cc:to:from:subject; bh=d6XxgKFHuaFqIsMmBdTbT2J+tfAk+1GgdrylAFN/Pf8=; b=IHtsEZWuxXQVNdFIWARS2W5BRbUWHckqArUzicO16Z6CB9ox6ssfgyOen3GlX9cRNH MEqjRjcmZQVJ+0AesmBoE1HnDzdgtiKLI36yJF9pS93RsTh1GRqweXIoJ8Gzo/7I/9Cq EmMRC8VLOZrI7zy5VrXvR8MT6Ncu61D/o7IBqi0OqKBkDQzxHfQmj0OMTYRDKQzu9DUG 11/vzJm/X/jyTtKQaIY14sD6VUKRSG6ZRA10yjEkuddrrtcFARe7EdI6hscloeNCqSfn BEDW2vSa/uhz7v9TLHgnCmuuWba/0zSG7pII6v97Kzgit1gSlC7TzgNI/HyfRT/7teJg F72Q== 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 u16si18410305oia.233.2019.12.29.15.01.00; Sun, 29 Dec 2019 15:01:13 -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 S1726628AbfL2XAS (ORCPT + 99 others); Sun, 29 Dec 2019 18:00:18 -0500 Received: from mx1.yrkesakademin.fi ([85.134.45.194]:25157 "EHLO mx1.yrkesakademin.fi" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726307AbfL2XAS (ORCPT ); Sun, 29 Dec 2019 18:00:18 -0500 Subject: Re: [PATCH 5.4 245/434] perf probe: Fix to list probe event with correct line number From: Thomas Backlund To: Greg Kroah-Hartman , CC: , Masami Hiramatsu , Arnaldo Carvalho de Melo , Jiri Olsa , Namhyung Kim , Sasha Levin References: <20191229172702.393141737@linuxfoundation.org> <20191229172718.158972713@linuxfoundation.org> <689591f8-0798-af22-9a04-4a1e6e894a55@mageia.org> Message-ID: Date: Mon, 30 Dec 2019 01:00:14 +0200 MIME-Version: 1.0 In-Reply-To: <689591f8-0798-af22-9a04-4a1e6e894a55@mageia.org> Content-Type: text/plain; charset="utf-8"; format=flowed Content-Language: en-US Content-Transfer-Encoding: 8bit X-WatchGuard-Spam-ID: str=0001.0A0C0201.5E093001.0029,ss=1,re=0.000,recu=0.000,reip=0.000,cl=1,cld=1,fgs=0 X-WatchGuard-Spam-Score: 0, clean; 0, virus threat unknown X-WatchGuard-Mail-Client-IP: 85.134.45.194 X-WatchGuard-Mail-From: tmb@mageia.org Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Den 29-12-2019 kl. 20:42, skrev Thomas Backlund: > Den 29-12-2019 kl. 19:24, skrev Greg Kroah-Hartman: >> From: Masami Hiramatsu >> >> [ Upstream commit 3895534dd78f0fd4d3f9e05ee52b9cdd444a743e ] >> >> Since debuginfo__find_probe_point() uses dwarf_entrypc() for finding the >> entry address of the function on which a probe is, it will fail when the >> function DIE has only ranges attribute. >> >> To fix this issue, use die_entrypc() instead of dwarf_entrypc(). >> >> Without this fix, perf probe -l shows incorrect offset: >> >>    # perf probe -l >>      probe:clear_tasks_mm_cpumask (on >> clear_tasks_mm_cpumask+18446744071579263632@work/linux/linux/kernel/cpu.c) >> >>      probe:clear_tasks_mm_cpumask_1 (on >> clear_tasks_mm_cpumask+18446744071579263752@work/linux/linux/kernel/cpu.c) >> >> >> With this: >> >>    # perf probe -l >>      probe:clear_tasks_mm_cpumask (on >> clear_tasks_mm_cpumask@work/linux/linux/kernel/cpu.c) >>      probe:clear_tasks_mm_cpumask_1 (on >> clear_tasks_mm_cpumask:21@work/linux/linux/kernel/cpu.c) >> >> Committer testing: >> >> Before: >> >>    [root@quaco ~]# perf probe -l >>      probe:clear_tasks_mm_cpumask (on >> clear_tasks_mm_cpumask+18446744071579765152@kernel/cpu.c) >>    [root@quaco ~]# >> >> After: >> >>    [root@quaco ~]# perf probe -l >>      probe:clear_tasks_mm_cpumask (on >> clear_tasks_mm_cpumask@kernel/cpu.c) >>    [root@quaco ~]# >> >> Fixes: 1d46ea2a6a40 ("perf probe: Fix listing incorrect line number >> with inline function") >> Signed-off-by: Masami Hiramatsu >> Tested-by: Arnaldo Carvalho de Melo >> Cc: Jiri Olsa >> Cc: Namhyung Kim >> Link: >> http://lore.kernel.org/lkml/157199321227.8075.14655572419136993015.stgit@devnote2 >> >> Signed-off-by: Arnaldo Carvalho de Melo >> Signed-off-by: Sasha Levin >> --- >>   tools/perf/util/probe-finder.c | 4 ++-- >>   1 file changed, 2 insertions(+), 2 deletions(-) >> >> diff --git a/tools/perf/util/probe-finder.c >> b/tools/perf/util/probe-finder.c >> index cd9f95e5044e..7c8d30fb2b99 100644 >> --- a/tools/perf/util/probe-finder.c >> +++ b/tools/perf/util/probe-finder.c >> @@ -1578,7 +1578,7 @@ int debuginfo__find_probe_point(struct debuginfo >> *dbg, unsigned long addr, >>           /* Get function entry information */ >>           func = basefunc = dwarf_diename(&spdie); >>           if (!func || >> -            dwarf_entrypc(&spdie, &baseaddr) != 0 || >> +            die_entrypc(&spdie, &baseaddr) != 0 || >>               dwarf_decl_line(&spdie, &baseline) != 0) { >>               lineno = 0; >>               goto post; >> @@ -1595,7 +1595,7 @@ int debuginfo__find_probe_point(struct debuginfo >> *dbg, unsigned long addr, >>           while (die_find_top_inlinefunc(&spdie, (Dwarf_Addr)addr, >>                           &indie)) { >>               /* There is an inline function */ >> -            if (dwarf_entrypc(&indie, &_addr) == 0 && >> +            if (die_entrypc(&indie, &_addr) == 0 && >>                   _addr == addr) { >>                   /* >>                    * addr is at an inline function entry. >> > > > still broken > > /usr/bin/ld: perf-in.o: in function `debuginfo__find_probe_point': > /work/rpmbuild/BUILD/kernel-x86_64/linux-5.4/tools/perf/util/probe-finder.c:1616: > undefined reference to `die_entrypc' > And the fix for the perf build errors I reported against: [PATCH 5.4 245/434] perf probe: Fix to list probe event with correct line number [PATCH 5.4 248/434] perf probe: Fix to probe an inline function which has no entry pc [PATCH 5.4 249/434] perf probe: Fix to show ranges of variables in functions without entry_pc [PATCH 5.4 250/434] perf probe: Fix to show inlined function callsite without entry_pc [PATCH 5.4 252/434] perf probe: Fix to probe a function which has no entry pc is to add the missing: From 91e2f539eeda26ab00bd03fae8dc434c128c85ed Mon Sep 17 00:00:00 2001 From: Masami Hiramatsu Date: Thu, 24 Oct 2019 18:12:54 +0900 Subject: [PATCH] perf probe: Fix to show function entry line as probe-able -- Thomas