Received: by 10.223.176.46 with SMTP id f43csp1870972wra; Thu, 25 Jan 2018 01:11:25 -0800 (PST) X-Google-Smtp-Source: AH8x224BRNdixGmXG+tCSfuRHeohAm1qoJYfdDMTPZdyDpAOd2rcQViYzBnoCqhgdDlzES0QaeQZ X-Received: by 2002:a17:902:43:: with SMTP id 61-v6mr10634950pla.73.1516871484992; Thu, 25 Jan 2018 01:11:24 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1516871484; cv=none; d=google.com; s=arc-20160816; b=tvsiRRurwaNtpKzUwCZohQix//E3i+5jujP94smczt1jc+73dpdDoSLxcOEw4ang/5 mro8uixJmS9XWkw3TlKSI1KfchU1ElPvpQTBEa7eUoAGELoOp85+NXV7k61b4vpnVT5D nTE3xTW3B/7FrmboSZxL3Rly2t5nJm+RLHGBOrR7wpG8W0e44wQWnb6JPWy1+U8nG4Y0 FONgujeOABQxvqvP4hjcsSIUTLZx5Wj+hYm1MnevFVrz7wopMelTntsyi3OnbH8c3RR5 ATxPjjZJCu/7Yo3juZXjA/oskBgjFW3MQeM4oKomaIBF7gXsDy8kAMYvmpD8lrZSMlG+ hRkA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:dkim-signature:arc-authentication-results; bh=Y62JrSYloy/rJh1To9Oi1P0hFQsUd+qdbODWR/Birq0=; b=K39hhCuwYhXxGs3TIwt78gP1QG6OP261Bmh69iOh5lB7MzNhwBvJCQgndOHXqFWhim j0khowSy2vZW7VYhBKsw1YyAIi/dbgBlQJa0RJlinWe9MKB71avCzY0pHVcGbCJktReA NHHqpOvHToOoRj8ide6qfLj7430zsYDggFLqBZtY7tXRpJTrME597NmP/ZW4CcUZWtt6 WLIblhXZ2lqYJytRnGbwf3JqwDBAPLg+pOwqZn9g8AoSvdr9P16K7jeV1KM9tcOyPNkO UbdDPzpYxjh4bgbDyUbRniYo7RjQBx6oI/4UCxWfumQK+WUDpXYwk3Jf9Elvpw+J+bhb mwQw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=Kw3MsUV/; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id i1-v6si1673830pld.42.2018.01.25.01.11.11; Thu, 25 Jan 2018 01:11:24 -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=@gmail.com header.s=20161025 header.b=Kw3MsUV/; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751478AbeAYJKg (ORCPT + 99 others); Thu, 25 Jan 2018 04:10:36 -0500 Received: from mail-io0-f193.google.com ([209.85.223.193]:46887 "EHLO mail-io0-f193.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751380AbeAYJK2 (ORCPT ); Thu, 25 Jan 2018 04:10:28 -0500 Received: by mail-io0-f193.google.com with SMTP id f34so7897976ioi.13; Thu, 25 Jan 2018 01:10:27 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:in-reply-to:references; bh=Y62JrSYloy/rJh1To9Oi1P0hFQsUd+qdbODWR/Birq0=; b=Kw3MsUV/rS9N6+EXBIPYIEsIIxR+0JHUNHBeJKpEaoKu/viNvbZcllBamt+8KaHOYE 6RZwsqy6BpGL8smpfCGE6qrw1lQh/wlb3WAeQhf836OOTsk+NPMzzImDTyXxN46XQ9jt DH1a21bfKZUVMIw4G/bpQiwdjYJLAwYx15+AtWi2hWXq3d825hO07lNZHb1jSC6o9KyU AyJpMxERhSdCpbNgJUBefJ4TPSqpQGcCiEU5FA8fI1Tz1e1eTEKRys9eWfG77/ShTvLw EYkfGtW/hRivAIdV1vAxLfo93BHjgvrUvD8A4p4/zXKPxWCB25N9zUWCF1ItDWTkSpAh hLjQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references; bh=Y62JrSYloy/rJh1To9Oi1P0hFQsUd+qdbODWR/Birq0=; b=YoG0X6rRHoB1QXDS44wxi894Yvn+V1Ouzd1VCKCHbymXjindGvX+SwtCcTbarQY++L 6xBiORjiwpQj77XEHHz6V8DqH5kMoFwsUCiwthmYylZTpefADsuqN9+rPtSXpZMz3LQh eSyFH9NG5icN186PYAXgCJ/7qJ6Mp0az5xiH/yCc1Syqyca+RFpmrL46COfsH8rJikWm BZG/qhvA4WFoqHadFfrct2h3w4O5/v/FaAeO1DWFGMZuHMd3dnOjob8WQ+Yo7B13+Js7 62nsaMpKXHGGP0h6GLEn0bUyyhZR4x/tlKRSEmDwTYU9Oy9FLjKBHhE+l7Fdf8iyvWEg CnDw== X-Gm-Message-State: AKwxyte606RrVDOpJu6jv7YpIId0DZh4KfOjlufJipKBQ7fTrl5YaliZ 0HGYjWd3jzalqdAaYRjvHzI= X-Received: by 10.107.13.143 with SMTP id 137mr11447584ion.265.1516871427178; Thu, 25 Jan 2018 01:10:27 -0800 (PST) Received: from node3.didichuxing.com ([203.100.54.194]) by smtp.gmail.com with ESMTPSA id n95sm1693917ioo.12.2018.01.25.01.10.22 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Thu, 25 Jan 2018 01:10:26 -0800 (PST) From: ufo19890607 To: peterz@infradead.org, mingo@redhat.com, alexander.shishkin@linux.intel.com, jolsa@kernel.org, dsahern@gmail.com, namhyung@kernel.org, milian.wolff@kdab.com, arnaldo.melo@gmail.com, yuzhoujian@didichuxing.com, adrian.hunter@intel.com, wangnan0@huawei.com Cc: linux-perf-users@vger.kernel.org, linux-kernel@vger.kernel.org, acme@redhat.com Subject: [PATCH v2 1/2] perf stat: Add support to print counts for fixed times Date: Thu, 25 Jan 2018 10:10:03 +0100 Message-Id: <1516871404-31920-2-git-send-email-ufo19890607@gmail.com> X-Mailer: git-send-email 1.8.3.1 In-Reply-To: <1516871404-31920-1-git-send-email-ufo19890607@gmail.com> References: <1516871404-31920-1-git-send-email-ufo19890607@gmail.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: yuzhoujian Introduce a new option to print counts for fixed number of times and update perf-stat documentation accordingly. Show below is the output of the new option for perf stat. $ perf stat -I 1000 --interval-count 2 -e cycles -a # time counts unit events 1.002827089 93,884,870 cycles 2.004231506 56,573,446 cycles We can just print the counts for several times with this newly introduced option. The usage of it is a little like vmstat. $ vmstat -n 1 2 procs -----------memory---------- ---swap-- -----io---- -system-- ------cpu----- r b swpd free buff cache si so bi bo in cs us sy id wa st 0 0 0 78270544 547484 51732076 0 0 0 20 1 1 1 0 99 0 0 0 0 0 78270512 547484 51732080 0 0 0 16 477 1555 0 0 100 0 0 Changes since v1: - change the name of the new option "times-print" to "interval-count". - keep the new option interval specifically. Signed-off-by: yuzhoujian --- tools/perf/Documentation/perf-stat.txt | 5 +++++ tools/perf/builtin-stat.c | 26 +++++++++++++++++++++++++- tools/perf/util/stat.h | 1 + 3 files changed, 31 insertions(+), 1 deletion(-) diff --git a/tools/perf/Documentation/perf-stat.txt b/tools/perf/Documentation/perf-stat.txt index 823fce7674bb..47a21645f60c 100644 --- a/tools/perf/Documentation/perf-stat.txt +++ b/tools/perf/Documentation/perf-stat.txt @@ -146,6 +146,11 @@ Print count deltas every N milliseconds (minimum: 10ms) The overhead percentage could be high in some cases, for instance with small, sub 100ms intervals. Use with caution. example: 'perf stat -I 1000 -e cycles -a sleep 5' +--interval-count times:: +Print count deltas for fixed number of times. +This option should be used together with "-I" option. + example: 'perf stat -I 1000 --interval-count 2 -e cycles -a' + --metric-only:: Only print computed metrics. Print them in a single line. Don't show any raw values. Not supported with --per-thread. diff --git a/tools/perf/builtin-stat.c b/tools/perf/builtin-stat.c index 98bf9d32f222..406f546ad74c 100644 --- a/tools/perf/builtin-stat.c +++ b/tools/perf/builtin-stat.c @@ -168,6 +168,7 @@ static struct timespec ref_time; static struct cpu_map *aggr_map; static aggr_get_id_t aggr_get_id; static bool append_file; +static bool interval_count; static const char *output_name; static int output_fd; static int print_free_counters_hint; @@ -571,6 +572,7 @@ static struct perf_evsel *perf_evsel__reset_weak_group(struct perf_evsel *evsel) static int __run_perf_stat(int argc, const char **argv) { int interval = stat_config.interval; + int times = stat_config.times; char msg[BUFSIZ]; unsigned long long t0, t1; struct perf_evsel *counter; @@ -700,6 +702,10 @@ static int __run_perf_stat(int argc, const char **argv) while (!waitpid(child_pid, &status, WNOHANG)) { nanosleep(&ts, NULL); process_interval(); + if (interval_count == true) { + if (--times == 0) + break; + } } } waitpid(child_pid, &status, 0); @@ -716,8 +722,13 @@ static int __run_perf_stat(int argc, const char **argv) enable_counters(); while (!done) { nanosleep(&ts, NULL); - if (interval) + if (interval) { process_interval(); + if (interval_count == true) { + if (--times == 0) + break; + } + } } } @@ -1891,6 +1902,8 @@ static const struct option stat_options[] = { "command to run after to the measured command"), OPT_UINTEGER('I', "interval-print", &stat_config.interval, "print counts at regular interval in ms (>= 10)"), + OPT_INTEGER(0, "interval-count", &stat_config.times, + "print counts for fixed number of times"), OPT_SET_UINT(0, "per-socket", &stat_config.aggr_mode, "aggregate counts per processor socket", AGGR_SOCKET), OPT_SET_UINT(0, "per-core", &stat_config.aggr_mode, @@ -2689,6 +2702,7 @@ int cmd_stat(int argc, const char **argv) const char *mode; FILE *output = stderr; unsigned int interval; + int times; const char * const stat_subcommands[] = { "record", "report" }; setlocale(LC_ALL, ""); @@ -2719,6 +2733,7 @@ int cmd_stat(int argc, const char **argv) return __cmd_report(argc, argv); interval = stat_config.interval; + times = stat_config.times; /* * For record command the -o is already taken care of. @@ -2870,6 +2885,15 @@ int cmd_stat(int argc, const char **argv) "The overhead percentage could be high in some cases. " "Please proceed with caution.\n"); } + if (times && interval) + interval_count = true; + else if (times && !interval) { + pr_err("interval-count option should be used together with " + "interval-print.\n"); + parse_options_usage(stat_usage, stat_options, "interval-count", 0); + parse_options_usage(stat_usage, stat_options, "I", 1); + goto out; + } if (perf_evlist__alloc_stats(evsel_list, interval)) goto out; diff --git a/tools/perf/util/stat.h b/tools/perf/util/stat.h index dbc6f7134f61..b2f8a347d358 100644 --- a/tools/perf/util/stat.h +++ b/tools/perf/util/stat.h @@ -90,6 +90,7 @@ struct perf_stat_config { bool scale; FILE *output; unsigned int interval; + int times; struct runtime_stat *stats; int stats_num; }; -- 2.14.1