Received: by 10.223.176.46 with SMTP id f43csp438727wra; Fri, 26 Jan 2018 01:08:11 -0800 (PST) X-Google-Smtp-Source: AH8x224oQwmRoaVGK3gSPesn32SBoEaNAxAsTU/0UzPbTcbZrxsyZjphadEm1UyQDTE0EL9WSSqB X-Received: by 10.101.80.69 with SMTP id k5mr4275191pgo.443.1516957691753; Fri, 26 Jan 2018 01:08:11 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1516957691; cv=none; d=google.com; s=arc-20160816; b=rtquXx6XLTUixQlePybh/FWgEnwJH5MtOaPzxmAWEsBl5WVze1gy6zcl0h2fb1PFYU /DmSw8WscxxQACyX6Yudfki88qVOSil+XYE3JmTWePs1+6gYXdmww9KwcOzqfn/FnxWv nUpLtz/9JZq22xjGc1V/eqz0uztfNghKYlrFInK8Ib3loTf49wlxuhGOs5BK4GWQPAvc nL7UZ54qgs2G9Utha9HYX9Fpzo/6N7dR5STtRkTkMh6lnHLBFpTBYr0O1Vu+r+NhErj3 NIUxAHhsHW2SYgLRZFVA3fB37yw2HJrUORwF0tIQo6zC/XK/r7gMakrkWkXOJZDuu6pC 1UWw== 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=57eT2t83fBV7Er/0l+3tp935dZXiXYjnMCGuSXgTAJU=; b=SJOfRiTr+cy7s9UrwP93JmuwIxHHmf4MuDv6t2AzW3wviUmJukf+SNM5CnMQlpkyAA oBStVE9WfVFHRZ55yC8jJXFUOl5bVylNB+eXTaNcEmICdtXAQs5bLmiwvTVno5f2qjXS CuMBgrToBLf9bZc9Vg1t8UBSimstJLAobxLoNcco97GeFTpQqPWg0g5LrVnO4zSgd1lD flc8FXQjQ7iIrgz1PLeqYSTsOvXnBeXAouLbwqEx78SouMouy5/PIUxoY9V5elZmsW1h Sxg1VIRnhp11TEUNZ4dh84GKo8dSNq9Gl7iSEQQ67XN/GCIGJOLgK5p25q2XKGuX2P+K siRg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=HVHl3RSU; 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 t11si2762268pgn.568.2018.01.26.01.07.57; Fri, 26 Jan 2018 01:08:11 -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=HVHl3RSU; 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 S1752746AbeAZJH1 (ORCPT + 99 others); Fri, 26 Jan 2018 04:07:27 -0500 Received: from mail-pf0-f193.google.com ([209.85.192.193]:36674 "EHLO mail-pf0-f193.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752490AbeAZJHR (ORCPT ); Fri, 26 Jan 2018 04:07:17 -0500 Received: by mail-pf0-f193.google.com with SMTP id 23so7906865pfp.3; Fri, 26 Jan 2018 01:07:16 -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=57eT2t83fBV7Er/0l+3tp935dZXiXYjnMCGuSXgTAJU=; b=HVHl3RSUShuAa/jGoinIKaUYH43oaLCCvy2EZCOC562skIxM4MWXXWTnZ8ZQWyTL+3 10hPUqSJBghJt0v+8E9kPptmKvV/nULjIP2XkKrcfLD3loSc/cNETFb8Ye5XeXAc1XnW Y8jhieUm0598vcu6LaSpzJ+9/s7xUW8xkGMPs9pkkE71UzelZN4ITtjG/gIT3MVibyj/ 6NuhrtfcJ9s7s9waLppl6TX2dj7bOxBd6H2RmQMx3sS2horfOv46W4K6aTo3WRaMFBuA uANRH6OWMxYER7e0duZ7mHx9mN49+1pnpm03HLI4nQte0AnhWs0qNKXolsAXpN53x3pk Vw4g== 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=57eT2t83fBV7Er/0l+3tp935dZXiXYjnMCGuSXgTAJU=; b=GsV3Kags5ze9qOZVzBrvkqkKLXHORz/UvBWZkzcV4DoGE7hZh1wins3ejECeYyNxIf 9zkFfBubpv4KGKBJUpk6S4fTaQJaK71XzJ1+ruGBGFo2bml4Ba/8KSZ2waham0noPZfL IUbFC++E3WBPoqovubmUhG7pFMdk8D+UslJOus8twVS0djhy6OHonkFE11Q7X4dgPynK QXbRUlQC5/NhBSKcPtqj4RthTG/329anlzNgxl2DG4gyXBRi5+3IvPmzWFiYNgDx6ptX kiF070ZkiNyK7N/jcgXo+4zCz7TgrDt43GT4JU27rI724l3CqFv0DvZ+IDTXR+/rfEDW wdbw== X-Gm-Message-State: AKwxytdZnu4zr7aI5R2zMM2JoRGcFozLmazUZC5SQ2B+soGT1sBP0zLJ XfYsqADLzQtigHNU5H/x3jk= X-Received: by 2002:a17:902:988b:: with SMTP id s11-v6mr13149031plp.99.1516957636432; Fri, 26 Jan 2018 01:07:16 -0800 (PST) Received: from node3.didichuxing.com ([203.100.54.194]) by smtp.gmail.com with ESMTPSA id f10sm7151902pgr.33.2018.01.26.01.07.12 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Fri, 26 Jan 2018 01:07:15 -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, Kan.liang@intel.com Cc: linux-perf-users@vger.kernel.org, linux-kernel@vger.kernel.org, acme@redhat.com Subject: [PATCH v3 1/2] perf stat: Add support to print counts for fixed times Date: Fri, 26 Jan 2018 10:06:56 +0100 Message-Id: <1516957617-23985-2-git-send-email-ufo19890607@gmail.com> X-Mailer: git-send-email 1.8.3.1 In-Reply-To: <1516957617-23985-1-git-send-email-ufo19890607@gmail.com> References: <1516957617-23985-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, and it should be used together with "-I" option. $ 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 v2: - none. 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