Received: by 2002:a25:868d:0:0:0:0:0 with SMTP id z13csp630203ybk; Wed, 20 May 2020 08:07:38 -0700 (PDT) X-Google-Smtp-Source: ABdhPJx8wD5uwZ24Nmh56EYYQwMcMmH2IpNd3/YzZ+U4ghTr804FpIEZPbKf4d3QIHvpyrUEaZOu X-Received: by 2002:a17:907:447e:: with SMTP id oo22mr51444ejb.37.1589987257865; Wed, 20 May 2020 08:07:37 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1589987257; cv=none; d=google.com; s=arc-20160816; b=cB3bay8rrTYzBm4U09YHJB98fOHMgawXM7fyYBkKdvAcbs8Slfm6LI1xWIaOnTDO6P Fz0HO4mD49ohxpdh80JOBMy1wo7n5lV41P4uWXPRx3xouhSrf1QaAvvpJ9WugdkesD7u 7VBHqBek8TKauaJ8w0yivi6qc4dLt2j8uewcRWN7+i/Ig02gMt0kIc65WGPL8aYaHh8D aL79oa1xhIRzvPbtdGdMNDfnxJ2k3RBjb3fHSZHtFvRenjs2e7H1cVjDyb1eDWzaLYrN 2Kb9orHlqkz4+5Wf/HdkpJH3gYU4z2nSo9PBGwaqJ2EvlH3lKJTw/XAmwQlQGYlseLvD hIyw== 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 :content-language:in-reply-to:mime-version:user-agent:date :message-id:organization:from:references:cc:to:subject:ironport-sdr :ironport-sdr; bh=b2F6M2qZs37WtzhamltuSCoEYQrS9EBmr3GOqH3KwGY=; b=FJfGpUZvWlq37xAUDURs2A7zOAuv1LTHHKohPflRS6oxHgNM6XPxmWKRt9YfEz9UEB wYCGg9CjQ9FdX9QteoBPUmUtlwA8TYVG7It1blwzv2UeB0DItvQt45fNJwhJ4grnbb11 dgO79K39Be6/parzpyWGh+ixqHrQpnuQL6fk4KDm/7XI+9zUHo6zgrMkcG2+ZmCQTBQ/ nswaFjiEFRK1+xSVLBRV6czCRf5WsC5qAndxlRtoZBrdWpFNXv1n0EJkRhtEXT9tWQkA 6TATLX/5/hit70jRvuPcjZX7h9xpejUCinoB+NOSYllIEdILSLvlOZ269a3M7WgoSdaj /9rg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id m6si1566776edv.283.2020.05.20.08.07.06; Wed, 20 May 2020 08:07:37 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726697AbgETPFh (ORCPT + 99 others); Wed, 20 May 2020 11:05:37 -0400 Received: from mga14.intel.com ([192.55.52.115]:28224 "EHLO mga14.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726545AbgETPFh (ORCPT ); Wed, 20 May 2020 11:05:37 -0400 IronPort-SDR: 6q+v6PHB1NxjTvtEybu5Kv1UF6gWFnkRKNe1YNuiFP4joUWAQ5gN3sT1H5yS7V+Rrv//VRtMwE Ul/21l3yYHRw== X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga003.jf.intel.com ([10.7.209.27]) by fmsmga103.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 20 May 2020 08:05:36 -0700 IronPort-SDR: 8YdepVrVeMetoOFxmVGKO/3+DexPOg8DJ9/k6EODfGDXpbR5TAMfIYdoSEeUrlps1Uczv2asS1 mdv69UiZTquA== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.73,414,1583222400"; d="scan'208";a="264712940" Received: from linux.intel.com ([10.54.29.200]) by orsmga003.jf.intel.com with ESMTP; 20 May 2020 08:05:36 -0700 Received: from [10.249.231.6] (abudanko-mobl.ccr.corp.intel.com [10.249.231.6]) by linux.intel.com (Postfix) with ESMTP id 2087C580613; Wed, 20 May 2020 08:05:33 -0700 (PDT) Subject: Re: [PATCH v3 6/9] perf stat: introduce --ctl-fd[-ack] options To: Jiri Olsa Cc: Arnaldo Carvalho de Melo , Namhyung Kim , Alexander Shishkin , Peter Zijlstra , Ingo Molnar , Andi Kleen , linux-kernel References: <6b8f7e1f-f89c-2c96-95ac-2a128b365a81@linux.intel.com> <20200520123819.GE157452@krava> From: Alexey Budankov Organization: Intel Corp. Message-ID: <7dcbbca7-b99e-025e-91b4-71c45e746a7b@linux.intel.com> Date: Wed, 20 May 2020 18:05:33 +0300 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:68.0) Gecko/20100101 Thunderbird/68.8.0 MIME-Version: 1.0 In-Reply-To: <20200520123819.GE157452@krava> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 20.05.2020 15:38, Jiri Olsa wrote: > On Wed, May 13, 2020 at 11:03:03AM +0300, Alexey Budankov wrote: >> >> Introduce --ctl-fd[-ack] options to pass open file descriptors numbers >> from command line. Extend perf-stat.txt file with --ctl-fd[-ack] options >> description. Document possible usage model introduced by --ctl-fd[-ack] >> options by providing example bash shell script. >> >> Signed-off-by: Alexey Budankov >> --- >> tools/perf/Documentation/perf-stat.txt | 40 ++++++++++++++++++++++++++ >> tools/perf/builtin-stat.c | 10 +++++++ >> tools/perf/util/stat.h | 2 ++ >> 3 files changed, 52 insertions(+) >> >> diff --git a/tools/perf/Documentation/perf-stat.txt b/tools/perf/Documentation/perf-stat.txt >> index 3b91b30d7672..7f7a0019fbfc 100644 >> --- a/tools/perf/Documentation/perf-stat.txt >> +++ b/tools/perf/Documentation/perf-stat.txt >> @@ -164,6 +164,46 @@ with it. --append may be used here. Examples: >> 3>results perf stat --log-fd 3 -- $cmd >> 3>>results perf stat --log-fd 3 --append -- $cmd >> >> +--ctl-fd:: >> +--ctl-fd-ack:: >> + >> +Listen on ctl-fd descriptor for command to control measurement ('enable': enable events, >> +'disable': disable events). Optionally send control command completion ('ack') to fd-ack >> +descriptor to synchronize with the controlling process. Example of bash shell script >> +to enable and disable events during measurements: >> + >> +#!/bin/bash >> + >> +ctl_dir=/tmp/ >> + >> +ctl_fifo=${ctl_dir}perf_ctl.fifo >> +test -p ${ctl_fifo} && unlink ${ctl_fifo} >> +mkfifo ${ctl_fifo} >> +exec {ctl_fd}<>${ctl_fifo} >> + >> +ctl_ack_fifo=${ctl_dir}perf_ctl_ack.fifo >> +test -p ${ctl_ack_fifo} && unlink ${ctl_ack_fifo} >> +mkfifo ${ctl_ack_fifo} >> +exec {ctl_fd_ack}<>${ctl_ack_fifo} >> + >> +perf stat -D -1 -e cpu-cycles -a -I 1000 \ >> + --ctl-fd ${ctl_fd} --ctl-fd-ack ${ctl_fd_ack} \ >> + -- sleep 30 & >> +perf_pid=$! >> + >> +sleep 5 && echo 'enable' >&${ctl_fd} && read -u ${ctl_fd_ack} e1 && echo "enabled(${e1})" >> +sleep 10 && echo 'disable' >&${ctl_fd} && read -u ${ctl_fd_ack} d1 && echo "disabled(${d1})" >> + >> +exec {ctl_fd_ack}>&- >> +unlink ${ctl_ack_fifo} >> + >> +exec {ctl_fd}>&- >> +unlink ${ctl_fifo} >> + >> +wait -n ${perf_pid} >> +exit $? >> + >> + >> --pre:: >> --post:: >> Pre and post measurement hooks, e.g.: >> diff --git a/tools/perf/builtin-stat.c b/tools/perf/builtin-stat.c >> index abea82a1ba24..88055aaf670f 100644 >> --- a/tools/perf/builtin-stat.c >> +++ b/tools/perf/builtin-stat.c >> @@ -187,6 +187,8 @@ static struct perf_stat_config stat_config = { >> .metric_only_len = METRIC_ONLY_LEN, >> .walltime_nsecs_stats = &walltime_nsecs_stats, >> .big_num = true, >> + .ctl_fd = -1, >> + .ctl_fd_ack = -1 >> }; >> >> static inline void diff_timespec(struct timespec *r, struct timespec *a, >> @@ -984,6 +986,10 @@ static struct option stat_options[] = { >> "Use with 'percore' event qualifier to show the event " >> "counts of one hardware thread by sum up total hardware " >> "threads of same physical core"), >> + OPT_INTEGER(0, "ctl-fd", &stat_config.ctl_fd, >> + "Listen on fd descriptor for command to control measurement ('enable': enable events, 'disable': disable events)"), >> + OPT_INTEGER(0, "ctl-fd-ack", &stat_config.ctl_fd_ack, >> + "Send control command completion ('ack') to fd ack descriptor"), >> OPT_END() >> }; >> >> @@ -2180,6 +2186,8 @@ int cmd_stat(int argc, const char **argv) >> signal(SIGALRM, skip_signal); >> signal(SIGABRT, skip_signal); >> >> + evlist__initialize_ctlfd(evsel_list, stat_config.ctl_fd, stat_config.ctl_fd_ack); > > please check the return value Accepted in v4. ~Alexey