Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp13335950ybl; Sun, 29 Dec 2019 09:33:52 -0800 (PST) X-Google-Smtp-Source: APXvYqxOqcns4ZLBNRPfpXW0L9IIWcVMKThZUkbxK/qxqduGd2wtpWCcva+3WBdkaegfm0kQvPPl X-Received: by 2002:a9d:8f1:: with SMTP id 104mr64572765otf.107.1577640832219; Sun, 29 Dec 2019 09:33:52 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1577640832; cv=none; d=google.com; s=arc-20160816; b=ZQTyPPm6nNauU56KKwQ5fFOwmArtM9MwWDXXzVfYVVB7zUrPUavqBMd+lWUVvLiorV ga1Jk6P7rBmhcPrjWfg+ZsUa0SMhzmKfxGRPZu+Vi7/oGjzmSTJ+sxWMeOUGRfQpbBmB fmDTA4hV5MWoyRdcLo4rJSeOWPhC7D16ULMjaulZpQ4I8knrX6Rves1ZiE1K3isCjQYR +co/+qwm0v1WPGEratucawe28fd6Zf7l86vT6KHKXghK6VGSAyqORfrmk8ueWYWoT+Z2 omd0YQ+6dNzPVNTvH26h2VQ1c60a0Tc8bgxtVL+4ryenEWuT3+uceeHOiRDcz2RTGaVB Kx2g== 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:dkim-signature; bh=0RU+gleZmL8WyxVdMPHDA7BRi7C4SKo1lie5O7mtd20=; b=lZ+oBCc/6gXGqtk0WPfMKyeTxzaBgZd16rtpACA4Ez40MSfqM31zhO0cIZiwKIf2Je PQ1P/U2nSYxNqDTENhP6JRpsaX8OMIrofxdLXNjqcAbXt/Ud72QaMx2mHluuvmUb36Ks KbzvlEivPvG7Jq8pewM9glTy0cdEVyhyVplGhijfojhCt2tWQhfw8bVugRW4ChqsQoTT j5jIN1/8AhgWALwdmZHd6+wUTmdmt/GbzR4b8DeMt8ANrrabvsJf9v82Qw+JcHNBqO29 /UzOhrTOcjk6RgsJkYTGgulfyuhrP5fZ8+RBcE4yIi7G9//n/mOuFJ8NEwtqB+sc/Lu0 QtPA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=ho03pRLE; 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 b1si17636184otl.302.2019.12.29.09.33.40; Sun, 29 Dec 2019 09:33:52 -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; dkim=pass header.i=@kernel.org header.s=default header.b=ho03pRLE; 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 S1729108AbfL2Rcg (ORCPT + 99 others); Sun, 29 Dec 2019 12:32:36 -0500 Received: from mail.kernel.org ([198.145.29.99]:33040 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729326AbfL2Rcd (ORCPT ); Sun, 29 Dec 2019 12:32:33 -0500 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (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 5C19320722; Sun, 29 Dec 2019 17:32:32 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1577640752; bh=VUcrl4OB6rj/SHxAv0HapGuF6dJJ1MkXr4RMNlhxhYA=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=ho03pRLEJuroBxdtViVfODZ4iCd0IuGPgboz9R8edW7tN/6bUrs78aZsVAPiMV7Aq ujGqNUCwvdhQwCVediqWrCnArkv0lKgluaZk/pJSBl2SKyCYw/Z5sNN1vEo/ql6StT WG92JpO4dVfYFP2VcRWq3SP3yHR7kI9U+iDQvf0I= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Masami Hiramatsu , Jiri Olsa , Namhyung Kim , Arnaldo Carvalho de Melo , Sasha Levin Subject: [PATCH 4.19 123/219] perf probe: Fix to find range-only function instance Date: Sun, 29 Dec 2019 18:18:45 +0100 Message-Id: <20191229162527.029548698@linuxfoundation.org> X-Mailer: git-send-email 2.24.1 In-Reply-To: <20191229162508.458551679@linuxfoundation.org> References: <20191229162508.458551679@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Masami Hiramatsu [ Upstream commit b77afa1f810f37bd8a36cb1318178dfe2d7af6b6 ] Fix die_is_func_instance() to find range-only function instance. In some case, a function instance can be made without any low PC or entry PC, but only with address ranges by optimization. (e.g. cold text partially in "text.unlikely" section) To find such function instance, we have to check the range attribute too. Fixes: e1ecbbc3fa83 ("perf probe: Fix to handle optimized not-inlined functions") Signed-off-by: Masami Hiramatsu Cc: Jiri Olsa Cc: Namhyung Kim Link: http://lore.kernel.org/lkml/157190835669.1859.8368628035930950596.stgit@devnote2 Signed-off-by: Arnaldo Carvalho de Melo Signed-off-by: Sasha Levin --- tools/perf/util/dwarf-aux.c | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/tools/perf/util/dwarf-aux.c b/tools/perf/util/dwarf-aux.c index 7eb7de5aee44..5bbb87f63ecb 100644 --- a/tools/perf/util/dwarf-aux.c +++ b/tools/perf/util/dwarf-aux.c @@ -331,10 +331,14 @@ bool die_is_func_def(Dwarf_Die *dw_die) bool die_is_func_instance(Dwarf_Die *dw_die) { Dwarf_Addr tmp; + Dwarf_Attribute attr_mem; /* Actually gcc optimizes non-inline as like as inlined */ - return !dwarf_func_inline(dw_die) && dwarf_entrypc(dw_die, &tmp) == 0; + return !dwarf_func_inline(dw_die) && + (dwarf_entrypc(dw_die, &tmp) == 0 || + dwarf_attr(dw_die, DW_AT_ranges, &attr_mem) != NULL); } + /** * die_get_data_member_location - Get the data-member offset * @mb_die: a DIE of a member of a data structure -- 2.20.1