Received: by 2002:a05:7412:f589:b0:e2:908c:2ebd with SMTP id eh9csp191270rdb; Tue, 31 Oct 2023 05:06:07 -0700 (PDT) X-Google-Smtp-Source: AGHT+IGlEhh2RrnO9Vr5xKDRuxHBBE1KR9phRSHWDID1cprZJoQWegMYdDXWs1aqFqXdjwFtOWtM X-Received: by 2002:a17:902:ecc5:b0:1cc:54cc:2fc1 with SMTP id a5-20020a170902ecc500b001cc54cc2fc1mr3385576plh.65.1698753966990; Tue, 31 Oct 2023 05:06:06 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1698753966; cv=none; d=google.com; s=arc-20160816; b=DycU/eJyVlh9mPW4ICbns2EKGTAG18zbBdhDRMlzRfveo9M0goTZl8085Z5IRNzM/w OFZe+twIy5LFXOG8+mqeK8Sa9NzRjHyRPBe9mYehWXToAMTBy19+dh7XTokpto0m7pen 1LRQ4+iQTy27SAcKh4y0X22k9kq2XaH6Jaqq1umXtGsQ/1CvTvomZckbQ/h8LcMIZ49I NYG0MOpf4CC2m6l6DgLQjUUkP1f2ZaRFgaLHXgqq6Tj4px9K0M15mkPIqM332q+FQVGk Sc9PI8dnAReiMrlaxPOPkl3+MB2lIdZywxiUk3Yn+cjFWfYTHAlpBm9ub8YFVCIueMxv jxGA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from; bh=IqXxlomYcWKX0hQKUgJt4SwcyuWHy79jBpPSbjSdYIQ=; fh=Dk4XfLMM0bGHqAzAqXdX1dBFvMRKfVJ5S146XXkq5QM=; b=T1zyfngMFbZNqLU07GsFNSXklueu+cHysOoyOwyW2vIfswYVcVjKCsb14fgOJOGQjP TXo+umxMIKPTuE2KIPdO1wYso57KBdQTXih+Xwhw8noA0PxLgWOW9kAQk0OLnIeCg3rJ IFf+5vOecYyz67NhPWHQDcEaEQEgwy07099H9Y2xIw2OrH4UMptgGW5JT9bJmSUdY/D3 zlCE5NQU101OlUs6FnsRQyeJr0C0yzJ3pyvvyTCbNrCuaILciPejO/9nGqNwkFiRiXDn SxLTTLuOzZR0WIdjiUskf3VFSuricA7CRpMWmHybUVxm4fqYMS3ATQxE/LfUsIUTIZYv b1xA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:6 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 pete.vger.email (pete.vger.email. [2620:137:e000::3:6]) by mx.google.com with ESMTPS id q12-20020a17090311cc00b001b9dda4e1e7si932784plh.154.2023.10.31.05.06.06 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 31 Oct 2023 05:06:06 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:6 as permitted sender) client-ip=2620:137:e000::3:6; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:6 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 out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by pete.vger.email (Postfix) with ESMTP id E9C7280B3B66; Tue, 31 Oct 2023 05:06:02 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at pete.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1344192AbjJaMFv (ORCPT + 99 others); Tue, 31 Oct 2023 08:05:51 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:50650 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1344163AbjJaMFs (ORCPT ); Tue, 31 Oct 2023 08:05:48 -0400 Received: from foss.arm.com (foss.arm.com [217.140.110.172]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id BC5155595; Tue, 31 Oct 2023 05:05:44 -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 1F8A3DA7; Tue, 31 Oct 2023 05:06:26 -0700 (PDT) Received: from dsg-hive-n1sdp-01.. (dsg-hive-n1sdp-01.cambridge.arm.com [10.2.2.18]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPA id DA45E3F738; Tue, 31 Oct 2023 05:05:42 -0700 (PDT) From: Nick Forrington To: linux-kernel@vger.kernel.org, linux-perf-users@vger.kernel.org Cc: Nick Forrington , stable@kernel.org, Mark Rutland , Alexander Shishkin , Jiri Olsa , Namhyung Kim , Ian Rogers , Adrian Hunter , Arnaldo Carvalho de Melo Subject: [PATCH 1/2] perf lock report: Restore aggregation by caller by default Date: Tue, 31 Oct 2023 12:05:24 +0000 Message-ID: <20231031120526.11502-2-nick.forrington@arm.com> X-Mailer: git-send-email 2.42.0 In-Reply-To: <20231031120526.11502-1-nick.forrington@arm.com> References: <20231031120526.11502-1-nick.forrington@arm.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-0.8 required=5.0 tests=HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,SPF_HELO_NONE,SPF_PASS,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 pete.vger.email Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (pete.vger.email [0.0.0.0]); Tue, 31 Oct 2023 05:06:03 -0700 (PDT) This change restores the previous default behaviour for "perf lock report", making the current aggregate-by-address behaviour available via the new "--lock-addr" command line parameter. This makes the behaviour consistent with "perf lock contention" (which also aggregates by caller by default, or by address when "--lock-addr" is specified). Commit 688d2e8de231 ("perf lock contention: Add -l/--lock-addr option") introduced aggregation modes for "perf lock contention" and (potentially inadvertently) changed the behaviour of "perf lock report" from aggregate-by-caller to aggregate-by-address (making the prior behaviour inaccessible). Example aggregate-by-address output: $ perf lock report -F acquired Name acquired event_mutex 34 21 1 Example aggregate-by-caller output: $ perf lock report -F acquired Name acquired perf_trace_init+... 34 lock_mm_and_find... 20 inherit_event.co... 1 do_madvise+0x1f8 1 Cc: stable@kernel.org Fixes: 688d2e8de231 ("perf lock contention: Add -l/--lock-addr option") Signed-off-by: Nick Forrington --- tools/perf/Documentation/perf-lock.txt | 4 ++++ tools/perf/builtin-lock.c | 24 +++++++++++++++++++++--- 2 files changed, 25 insertions(+), 3 deletions(-) diff --git a/tools/perf/Documentation/perf-lock.txt b/tools/perf/Documentation/perf-lock.txt index 503abcba1438..349333acbbfc 100644 --- a/tools/perf/Documentation/perf-lock.txt +++ b/tools/perf/Documentation/perf-lock.txt @@ -80,6 +80,10 @@ REPORT OPTIONS --combine-locks:: Merge lock instances in the same class (based on name). +-l:: +--lock-addr:: + Show lock contention stat by address + -t:: --threads:: The -t option is to show per-thread lock stat like below: diff --git a/tools/perf/builtin-lock.c b/tools/perf/builtin-lock.c index fa7419978353..3aa8ba5ad928 100644 --- a/tools/perf/builtin-lock.c +++ b/tools/perf/builtin-lock.c @@ -78,7 +78,7 @@ struct callstack_filter { static struct lock_filter filters; -static enum lock_aggr_mode aggr_mode = LOCK_AGGR_ADDR; +static enum lock_aggr_mode aggr_mode = LOCK_AGGR_CALLER; static bool needs_callstack(void) { @@ -1983,8 +1983,8 @@ static int __cmd_report(bool display_info) if (select_key(false)) goto out_delete; - if (show_thread_stats) - aggr_mode = LOCK_AGGR_TASK; + aggr_mode = show_thread_stats ? LOCK_AGGR_TASK : + show_lock_addrs ? LOCK_AGGR_ADDR : LOCK_AGGR_CALLER; err = perf_session__process_events(session); if (err) @@ -2008,6 +2008,19 @@ static void sighandler(int sig __maybe_unused) { } +static int check_lock_report_options(const struct option *options, + const char * const *usage) +{ + if (show_thread_stats && show_lock_addrs) { + pr_err("Cannot use thread and addr mode together\n"); + parse_options_usage(usage, options, "threads", 0); + parse_options_usage(NULL, options, "lock-addr", 0); + return -1; + } + + return 0; +} + static int check_lock_contention_options(const struct option *options, const char * const *usage) @@ -2589,6 +2602,7 @@ int cmd_lock(int argc, const char **argv) /* TODO: type */ OPT_BOOLEAN('c', "combine-locks", &combine_locks, "combine locks in the same class"), + OPT_BOOLEAN('l', "lock-addr", &show_lock_addrs, "show lock stats by address"), OPT_BOOLEAN('t', "threads", &show_thread_stats, "show per-thread lock stats"), OPT_INTEGER('E', "entries", &print_nr_entries, "display this many functions"), @@ -2680,6 +2694,10 @@ int cmd_lock(int argc, const char **argv) if (argc) usage_with_options(report_usage, report_options); } + + if (check_lock_report_options(report_options, report_usage) < 0) + return -1; + rc = __cmd_report(false); } else if (!strcmp(argv[0], "script")) { /* Aliased to 'perf script' */ -- 2.42.0