Received: by 2002:a05:6a10:f347:0:0:0:0 with SMTP id d7csp3449097pxu; Tue, 15 Dec 2020 07:18:35 -0800 (PST) X-Google-Smtp-Source: ABdhPJzALSFCk+jac4n3Y9iklcybaVKcqQf2yWelQXVbAeCFZvR9zXJqYoV9LW1DTCP1LtzmNrcy X-Received: by 2002:a50:fd10:: with SMTP id i16mr30282310eds.331.1608045514898; Tue, 15 Dec 2020 07:18:34 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1608045514; cv=none; d=google.com; s=arc-20160816; b=wAwyY1sj3Tg29BIhMK+PzbKcO7WRRU8prs0AGSa0dU2q6SmF7BhI6bqlf/ZbZK5pJz ThVVgTAMGraPZc9LME4wo+mwSLf0wIvd1OIZbevDszyElcL7yiNMwplRpNWtF/UEXV+4 TcjdC3rtEVpxLE4aWu36z8CjnopnO8vLsbFoR6TtOXzfKzze3xhxD9cjeVnFZXsKi7EK T47gGYnnEjajf8QobpnzY7SJRnOpFoXjmuX16RiqxABJFxwTgAHM7v7bOCLUlIvAb1FJ PiI94O9OhDA311CmjRFlPplQli6MIk9PLzAxa+5g1DfmVHGUrTMSFaLMzPIv+rAgnxHG G73w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:dkim-signature:date; bh=Bsru5BYXrJtD53XHRcC+LLBBzegQ9bAz2ge0Cumbf3A=; b=ZhQspNIEHiBigTxhZI/dz3t2Weosk/KsgEHMwxuv5ULkHAt6hvtYE5L5LtjUlSA5SK ZRfLsWyDefon6eKvZisPWiBm9JJTEDNdIy7wayB8ej2Wtu7Fv1uHhiTtwVgSVlc6buLF 3ju4xtLw5HesFK92VKj4kmhVwFmN9dGfZTMsaW7Dy/wxH5L99HpfBFLIeibQyvZ8IBOg nl0h8DbJnc3y9PiseyIoI5YfG9UrlO40mHcVYC51H8Ti+A4pq1U4HpEOSH8j5ZSXTmcf zC2l3F1gk+aN3c71FOSLz9ek1aqZVIylQ6TOsqfc0v46l0kFPAY8OZ4IzMxeJrCZtMcE M72g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=eqQwKUKV; 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=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id f11si1019453ejw.546.2020.12.15.07.18.09; Tue, 15 Dec 2020 07:18:34 -0800 (PST) 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; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=eqQwKUKV; 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=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729688AbgLOPOy (ORCPT + 99 others); Tue, 15 Dec 2020 10:14:54 -0500 Received: from mail.kernel.org ([198.145.29.99]:58812 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727833AbgLOPOm (ORCPT ); Tue, 15 Dec 2020 10:14:42 -0500 Date: Tue, 15 Dec 2020 12:14:13 -0300 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1608045241; bh=iMFOdnRzrnuIAvjgZ5mCkX2hD/Jc1MpHI3wlawSYZac=; h=From:To:Cc:Subject:References:In-Reply-To:From; b=eqQwKUKVBZiH//UFkaKnWoLTeV/YIrb12zg4BsWaRf31Im6BFMIP2k4P1BjfsMT2+ GvWTlxjCzD6PJAp3ao5BxecQpzFUQoWmCjm4w6eMO5lLLCZ+rjJ1JdysGpvS4YMqDZ PEGbaw+LiTkvjLP/Uj/tExAdmIGtEKECkE6HYWA7qIuK+M8WTYR0FEMF7kIzGOg5YA fN/3c/9YQ+mfuYd46yTQaVnuQRfAPlhCHxkabrRnmZR0j/tku1hpEA26jHwjU/zMMR xPcAoNtFf51dPQ3kctKZLSGkJjfcE1syPFS3lzgIZRn67E31nAs6fTkUbwGnCZqvFx IuwZKXy4VJXrQ== From: Arnaldo Carvalho de Melo To: Jiri Olsa Cc: Namhyung Kim , lkml , Peter Zijlstra , Ingo Molnar , Mark Rutland , Alexander Shishkin , Michael Petlan , Ian Rogers , Stephane Eranian , Alexei Budankov Subject: Re: [PATCH 2/3] perf tools: Allow to enable/disable events via control file Message-ID: <20201215151413.GE252952@kernel.org> References: <20201210204330.233864-1-jolsa@kernel.org> <20201210204330.233864-3-jolsa@kernel.org> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20201210204330.233864-3-jolsa@kernel.org> X-Url: http://acmel.wordpress.com Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Em Thu, Dec 10, 2020 at 09:43:29PM +0100, Jiri Olsa escreveu: > Adding new control events to enable/disable specific event. > The interface string for control file are: > > 'enable-' > 'disable-' Wwy do we have "enable-" as the "tag" for this? Also is it possible to use "enable sched:*" and have that match what is in the evlist and enable (or disable, if using "disable sched:*") what matches? This second suggestion can be done on top of this, i.e. as an enhancement, but mixing up the command (enable, disable) with its arguments looks strange. - Arnaldo > when received the command, perf will scan the current evlist > for and if found it's enabled/disabled. > > Example session: > > terminal 1: > # mkfifo control ack perf.pipe > # perf record --control=fifo:control,ack -D -1 --no-buffering -e 'sched:*' -o - > perf.pipe > Events disabled > > terminal 2: > # cat perf.pipe | ./perf --no-pager script -i - > > terminal 3: > # echo enable-sched:sched_process_fork > control > > terminal 1: > # mkfifo control ack perf.pipe > # perf record --control=fifo:control,ack -D -1 --no-buffering -e 'sched:*' -o - > perf.pipe > ... > event sched:sched_process_fork enabled > > terminal 2: > # cat perf.pipe | ./perf --no-pager script -i - > bash 33349 [034] 149587.674295: sched:sched_process_fork: comm=bash pid=33349 child_comm=bash child_pid=34056 > bash 33349 [034] 149588.239521: sched:sched_process_fork: comm=bash pid=33349 child_comm=bash child_pid=34057 > > terminal 3: > # echo enable-sched:sched_wakeup_new > control > > terminal 1: > # mkfifo control ack perf.pipe > # perf record --control=fifo:control,ack -D -1 --no-buffering -e 'sched:*' -o - > perf.pipe > ... > event sched:sched_wakeup_new enabled > > terminal 2: > # cat perf.pipe | ./perf --no-pager script -i - > ... > bash 33349 [034] 149632.228023: sched:sched_process_fork: comm=bash pid=33349 child_comm=bash child_pid=34059 > bash 33349 [034] 149632.228050: sched:sched_wakeup_new: bash:34059 [120] success=1 CPU:036 > bash 33349 [034] 149633.950005: sched:sched_process_fork: comm=bash pid=33349 child_comm=bash child_pid=34060 > bash 33349 [034] 149633.950030: sched:sched_wakeup_new: bash:34060 [120] success=1 CPU:036 > > Acked-by: Namhyung Kim > Signed-off-by: Jiri Olsa > --- > tools/perf/builtin-record.c | 2 ++ > tools/perf/builtin-stat.c | 2 ++ > tools/perf/util/evlist.c | 30 +++++++++++++++++++++++++++++- > tools/perf/util/evlist.h | 4 ++++ > 4 files changed, 37 insertions(+), 1 deletion(-) > > diff --git a/tools/perf/builtin-record.c b/tools/perf/builtin-record.c > index d832c108a1ca..582b8fba012c 100644 > --- a/tools/perf/builtin-record.c > +++ b/tools/perf/builtin-record.c > @@ -1949,6 +1949,8 @@ static int __cmd_record(struct record *rec, int argc, const char **argv) > break; > case EVLIST_CTL_CMD_ACK: > case EVLIST_CTL_CMD_UNSUPPORTED: > + case EVLIST_CTL_CMD_ENABLE_EVSEL: > + case EVLIST_CTL_CMD_DISABLE_EVSEL: > default: > break; > } > diff --git a/tools/perf/builtin-stat.c b/tools/perf/builtin-stat.c > index 89c32692f40c..6a21fb665008 100644 > --- a/tools/perf/builtin-stat.c > +++ b/tools/perf/builtin-stat.c > @@ -590,6 +590,8 @@ static void process_evlist(struct evlist *evlist, unsigned int interval) > case EVLIST_CTL_CMD_SNAPSHOT: > case EVLIST_CTL_CMD_ACK: > case EVLIST_CTL_CMD_UNSUPPORTED: > + case EVLIST_CTL_CMD_ENABLE_EVSEL: > + case EVLIST_CTL_CMD_DISABLE_EVSEL: > default: > break; > } > diff --git a/tools/perf/util/evlist.c b/tools/perf/util/evlist.c > index 70aff26612a9..729c98d10628 100644 > --- a/tools/perf/util/evlist.c > +++ b/tools/perf/util/evlist.c > @@ -1915,7 +1915,13 @@ static int evlist__ctlfd_recv(struct evlist *evlist, enum evlist_ctl_cmd *cmd, > bytes_read == data_size ? "" : c == '\n' ? "\\n" : "\\0"); > > if (bytes_read > 0) { > - if (!strncmp(cmd_data, EVLIST_CTL_CMD_ENABLE_TAG, > + if (!strncmp(cmd_data, EVLIST_CTL_CMD_ENABLE_EVSEL_TAG, > + (sizeof(EVLIST_CTL_CMD_ENABLE_EVSEL_TAG)-1))) { > + *cmd = EVLIST_CTL_CMD_ENABLE_EVSEL; > + } else if (!strncmp(cmd_data, EVLIST_CTL_CMD_DISABLE_EVSEL_TAG, > + (sizeof(EVLIST_CTL_CMD_DISABLE_EVSEL_TAG)-1))) { > + *cmd = EVLIST_CTL_CMD_DISABLE_EVSEL; > + } else if (!strncmp(cmd_data, EVLIST_CTL_CMD_ENABLE_TAG, > (sizeof(EVLIST_CTL_CMD_ENABLE_TAG)-1))) { > *cmd = EVLIST_CTL_CMD_ENABLE; > } else if (!strncmp(cmd_data, EVLIST_CTL_CMD_DISABLE_TAG, > @@ -1952,6 +1958,8 @@ int evlist__ctlfd_process(struct evlist *evlist, enum evlist_ctl_cmd *cmd) > char cmd_data[EVLIST_CTL_CMD_MAX_LEN]; > int ctlfd_pos = evlist->ctl_fd.pos; > struct pollfd *entries = evlist->core.pollfd.entries; > + struct evsel *evsel; > + char *evsel_name; > > if (!evlist__ctlfd_initialized(evlist) || !entries[ctlfd_pos].revents) > return 0; > @@ -1967,6 +1975,26 @@ int evlist__ctlfd_process(struct evlist *evlist, enum evlist_ctl_cmd *cmd) > case EVLIST_CTL_CMD_DISABLE: > evlist__disable(evlist); > break; > + case EVLIST_CTL_CMD_ENABLE_EVSEL: > + evsel_name = cmd_data + sizeof(EVLIST_CTL_CMD_ENABLE_EVSEL_TAG) - 1; > + evsel = evlist__find_evsel_by_str(evlist, evsel_name); > + if (evsel) { > + evlist__enable_evsel(evlist, evsel_name); > + pr_info("event %s enabled\n", evsel->name); > + } else { > + pr_info("failed: can't find '%s' event\n", evsel_name); > + } > + break; > + case EVLIST_CTL_CMD_DISABLE_EVSEL: > + evsel_name = cmd_data + sizeof(EVLIST_CTL_CMD_DISABLE_EVSEL_TAG) - 1; > + evsel = evlist__find_evsel_by_str(evlist, evsel_name); > + if (evsel) { > + evlist__disable_evsel(evlist, evsel_name); > + pr_info("event %s disabled\n", evsel->name); > + } else { > + pr_info("failed: can't find '%s' event\n", evsel_name); > + } > + break; > case EVLIST_CTL_CMD_SNAPSHOT: > break; > case EVLIST_CTL_CMD_ACK: > diff --git a/tools/perf/util/evlist.h b/tools/perf/util/evlist.h > index 1aae75895dea..e4e8ff8831a3 100644 > --- a/tools/perf/util/evlist.h > +++ b/tools/perf/util/evlist.h > @@ -330,6 +330,8 @@ struct evsel *evlist__reset_weak_group(struct evlist *evlist, struct evsel *evse > #define EVLIST_CTL_CMD_DISABLE_TAG "disable" > #define EVLIST_CTL_CMD_ACK_TAG "ack\n" > #define EVLIST_CTL_CMD_SNAPSHOT_TAG "snapshot" > +#define EVLIST_CTL_CMD_ENABLE_EVSEL_TAG "enable-" > +#define EVLIST_CTL_CMD_DISABLE_EVSEL_TAG "disable-" > > #define EVLIST_CTL_CMD_MAX_LEN 64 > > @@ -337,6 +339,8 @@ enum evlist_ctl_cmd { > EVLIST_CTL_CMD_UNSUPPORTED = 0, > EVLIST_CTL_CMD_ENABLE, > EVLIST_CTL_CMD_DISABLE, > + EVLIST_CTL_CMD_ENABLE_EVSEL, > + EVLIST_CTL_CMD_DISABLE_EVSEL, > EVLIST_CTL_CMD_ACK, > EVLIST_CTL_CMD_SNAPSHOT, > }; > -- > 2.26.2 > -- - Arnaldo