Received: by 2002:a6b:500f:0:0:0:0:0 with SMTP id e15csp483667iob; Wed, 18 May 2022 06:32:26 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxMSiVy41XVl78kqkfPzk/92WC04j1fKUrtL4F306+8SPDaXrHdfgmr6mc/VRyflfQppvKx X-Received: by 2002:a17:902:b18e:b0:15f:b2c:6ca with SMTP id s14-20020a170902b18e00b0015f0b2c06camr27329332plr.84.1652880746166; Wed, 18 May 2022 06:32:26 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1652880746; cv=none; d=google.com; s=arc-20160816; b=Qv7S4akQLG4PsAfy+d61W2Knwgtj1HjiKIssVtvgH3KGVybSotuM3td94JDBT9Ousn VSyVEkVhXcLayF0L53TESEkRv4U+xK3U8WoUVcAnr/RixeUwEjlv8l66XA2fyylwxjFq oQ04uih8HtRtPYLRe1yrs6ctxCwPB0M81v8m5t3f38m4znzRgvxCQZ2L9qPqezkEXvL2 jvAD1l30WgQzhAwVSSdXKlqfno9VY2OSZZoIK4eH31Ab5T8Cikj/R/DmGHdKXnDScBDm WGxAWgWzzdpxEKemCt2xU5AkFxpeTVuXZR61Y1Bcd9woZV+vwHcmpS8+ubs9VHdj3Fy4 nE3w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id; bh=2kcZoJYOZJpn/7k+FYcK6D6c1QM5BnaagswH+nHNUaU=; b=XcASXgK5FXYgwrAka1XJc0ngPivl/iQf1zDEiModMkLu4BpKc3/KGPBCggj3kLwhyU VZDNY6QeFa+VRx4XiovGVmEOfwH/68Q8uuJFZCQrEamJGIEXz6MyBwcSrTKX9Xtu6FDP FlzCdy30dB3rkXk29vbWRZIDkd6PWYD5WprPIPXVC+wb+DSZmfoDm+OKNyrww71EpJkS zij7nIEvQpYj2JYH0wTmW8tg2QO5UYwDScklemhOcAIzskxuovFFtCVroGdvjJShMHZ4 UGzPL7vcEgeYd6d/fvgReE3gWEVAgUEGl/IPtmM0cDyE4lvr15G2D4JoJRZNQmmUMYtl PMFw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Return-Path: Received: from lindbergh.monkeyblade.net (lindbergh.monkeyblade.net. [2620:137:e000::1:18]) by mx.google.com with ESMTPS id bt27-20020a056a00439b00b0050d80e4935fsi2875342pfb.256.2022.05.18.06.32.25 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 18 May 2022 06:32:26 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) client-ip=2620:137:e000::1:18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 000C21BE104; Wed, 18 May 2022 06:28:07 -0700 (PDT) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S237983AbiERN0H (ORCPT + 99 others); Wed, 18 May 2022 09:26:07 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:48270 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S237870AbiERNZq (ORCPT ); Wed, 18 May 2022 09:25:46 -0400 Received: from foss.arm.com (foss.arm.com [217.140.110.172]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 14D3D248F9; Wed, 18 May 2022 06:25:43 -0700 (PDT) Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id CB38223A; Wed, 18 May 2022 06:25:42 -0700 (PDT) Received: from [10.57.4.200] (unknown [10.57.4.200]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 6A3013F73D; Wed, 18 May 2022 06:25:40 -0700 (PDT) Message-ID: <8f48b4d3-b463-a858-c0fc-0d503eee42dd@arm.com> Date: Wed, 18 May 2022 14:25:38 +0100 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:91.0) Gecko/20100101 Thunderbird/91.8.1 Subject: Re: [PATCH v2 2/4] perf tools: Use dynamic register set for Dwarf unwind Content-Language: en-US To: Leo Yan Cc: linux-kernel@vger.kernel.org, linux-perf-users@vger.kernel.org, broonie@kernel.org, acme@kernel.org, german.gomez@arm.com, mathieu.poirier@linaro.org, john.garry@huawei.com, Will Deacon , Mike Leach , Peter Zijlstra , Ingo Molnar , Mark Rutland , Alexander Shishkin , Jiri Olsa , Namhyung Kim , linux-arm-kernel@lists.infradead.org References: <20220517102005.3022017-1-james.clark@arm.com> <20220517102005.3022017-3-james.clark@arm.com> <20220517110322.GC153558@leoy-ThinkPad-X240s> From: James Clark In-Reply-To: <20220517110322.GC153558@leoy-ThinkPad-X240s> Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-4.0 required=5.0 tests=BAYES_00, HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI,NICE_REPLY_A, RDNS_NONE,SPF_HELO_NONE,T_SCC_BODY_TEXT_LINE autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 17/05/2022 12:03, Leo Yan wrote: > On Tue, May 17, 2022 at 11:20:03AM +0100, James Clark wrote: >> Architectures can detect availability of extra registers at >> runtime so use this more complete set for unwinding. This >> will include the VG register on arm64 in a later commit. >> >> If the function isn't implemented then PERF_REGS_MASK is >> returned and there is no change. >> >> Signed-off-by: James Clark > > This patch looks good to me: > Reviewed-by: Leo Yan > > Just curious, do you think should update the test (e.g. > arch/arm64/tests/dwarf-unwind.c) to use arch__user_reg_mask()? I don't think so because the normal set of registers is manually loaded in tools/perf/arch/arm64/tests/regs_load.S so it wouldn't include this pseudo register. Also there is no SVE in the call chain of the test so it would never have an effect. I could add a new test for SVE, but it depends on getting the libunwind changes through first so will have to come later. Thanks, James > > Thanks, > Leo > >> --- >> tools/perf/util/evsel.c | 2 +- >> 1 file changed, 1 insertion(+), 1 deletion(-) >> >> diff --git a/tools/perf/util/evsel.c b/tools/perf/util/evsel.c >> index 5fd7924f8eb3..787bbcbcd2ae 100644 >> --- a/tools/perf/util/evsel.c >> +++ b/tools/perf/util/evsel.c >> @@ -896,7 +896,7 @@ static void __evsel__config_callchain(struct evsel *evsel, struct record_opts *o >> "specifying a subset with --user-regs may render DWARF unwinding unreliable, " >> "so the minimal registers set (IP, SP) is explicitly forced.\n"); >> } else { >> - attr->sample_regs_user |= PERF_REGS_MASK; >> + attr->sample_regs_user |= arch__user_reg_mask(); >> } >> attr->sample_stack_user = param->dump_size; >> attr->exclude_callchain_user = 1; >> -- >> 2.28.0 >>