Received: by 2002:a05:6a10:16a7:0:0:0:0 with SMTP id gp39csp3044114pxb; Mon, 16 Nov 2020 04:27:16 -0800 (PST) X-Google-Smtp-Source: ABdhPJytv3ffj6O5sEfOISJil2DwxE0eP7icqDxlFADqZc82+YZPZQE+kLSDlsup+05VVrGVSk5V X-Received: by 2002:a17:906:8485:: with SMTP id m5mr14952275ejx.205.1605529636357; Mon, 16 Nov 2020 04:27:16 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1605529636; cv=none; d=google.com; s=arc-20160816; b=SPSoz/If9Y5qt8BhdixjRnnh79klcI5/zC27fmuFIJSTvGYkvGWKOKMkcRdv42weun u1HXsXk4uYvjZKexdmDafo64tOECsPJ/OCdm+2+1R7ReV+eEcCs9vUx371foJYCLt9xy 4gEcORmxLcBoqQNGl1GKrzgD38fExMPfu9ruN/t/ptg4zmG8CIJ0AY4Pm0dCqxbZeSkp 48CNhTbY2WRl6C6Wmb356IfeBalUkbPbQ9o4Oo89RrhsiD2M/vD96dCcV40wJPO28WUJ dToBMs6IEKUtdUrkjbCarLacR1CdgXz7nsBb8OMMtvqv/Rnu8Ed+H/pP2tPLnQMUNgbt 6OlA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:organization :references:cc:to:from:subject:ironport-sdr:ironport-sdr; bh=4hEgFbsfzU/9FwMIqanNmkbNRlNugY7DoEVH4WYkWpg=; b=czNfXdRs97DKxmJrwT/r7QcbCTEX+L16yPXu5LOgp9/PGcPLowBBSIspgsc8aDTFwB SFLS6Of+HpmIt5h60oR31/CxHv2THhqx55Dpotog7Tn4pi0+GSPV7g2Lilobv0Pb1Wgy 05STkItjfBOOfO9lF2+vyWyrgi+gjMbJPZ+4afQlgrnJaqOkGssYYdbqOTBHpb3mmWS1 C9bGsrsdznTM/dH0YvX+Xx9g0iU/iS8sE6AgOlcpf07upOjlS4kAPuSqeYZbxeAzK9Tc mXLespoISmf4Fe6WyEeC6tmZmzgiqvOGFKZhMWRBpdptKRfLEzwCOqGPIeVr4QGkx9Pj 9lSA== 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 y4si11570691ejj.723.2020.11.16.04.26.53; Mon, 16 Nov 2020 04:27:16 -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; 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 S1730059AbgKPMVS (ORCPT + 99 others); Mon, 16 Nov 2020 07:21:18 -0500 Received: from mga01.intel.com ([192.55.52.88]:15868 "EHLO mga01.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729506AbgKPMVR (ORCPT ); Mon, 16 Nov 2020 07:21:17 -0500 IronPort-SDR: zQMFAy69+CmWvBx7/YQVHGCxPHRKb1XP1PrhifYY33EZUJRK99KAGsqva0kjO837E9ELOMa2Vg dy4AdbecWBBQ== X-IronPort-AV: E=McAfee;i="6000,8403,9806"; a="188780520" X-IronPort-AV: E=Sophos;i="5.77,482,1596524400"; d="scan'208";a="188780520" X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga005.jf.intel.com ([10.7.209.41]) by fmsmga101.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 16 Nov 2020 04:21:17 -0800 IronPort-SDR: uVcHQfgxQdSlYOtQK6jJZe4vXIoneWzOufwZozx+HNJ1R+6Na2QsPWsui8zgegpBWonEwio3vs XKFFXSAXxGCw== X-IronPort-AV: E=Sophos;i="5.77,482,1596524400"; d="scan'208";a="543584069" Received: from abudanko-mobl.ccr.corp.intel.com (HELO [10.249.228.209]) ([10.249.228.209]) by orsmga005-auth.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 16 Nov 2020 04:21:13 -0800 Subject: [PATCH v3 09/12] perf record: document parallel data streaming mode From: Alexey Budankov To: Arnaldo Carvalho de Melo Cc: Jiri Olsa , Namhyung Kim , Alexander Shishkin , Peter Zijlstra , Ingo Molnar , linux-kernel , Andi Kleen , Adrian Hunter , Alexey Bayduraev , Alexander Antonov References: <7d197a2d-56e2-896d-bf96-6de0a4db1fb8@linux.intel.com> Organization: Intel Corp. Message-ID: <91205d78-fbc3-29ab-c067-dfb7b075676e@linux.intel.com> Date: Mon, 16 Nov 2020 15:21:11 +0300 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:78.0) Gecko/20100101 Thunderbird/78.4.3 MIME-Version: 1.0 In-Reply-To: <7d197a2d-56e2-896d-bf96-6de0a4db1fb8@linux.intel.com> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Document --threads option syntax and parallel data streaming modes in Documentation/perf-record.txt. Implement compatibility checks for other modes and related command line options: asynchronous(--aio) trace streaming and affinity (--affinity) modes, pipe mode, AUX area tracing --snapshot and --aux-sample options, --switch-output, --switch-output-event, --switch-max-files and --timestamp-filename options. Parallel data streaming is compatible with Zstd compression (--compression-level) and external control commands (--control). Cpu mask provided via -C option filters --threads specification masks. Signed-off-by: Alexey Budankov --- tools/perf/Documentation/perf-record.txt | 18 ++++++++++ tools/perf/builtin-record.c | 43 ++++++++++++++++++++++-- 2 files changed, 58 insertions(+), 3 deletions(-) diff --git a/tools/perf/Documentation/perf-record.txt b/tools/perf/Documentation/perf-record.txt index 768888b9326a..baf9428856e6 100644 --- a/tools/perf/Documentation/perf-record.txt +++ b/tools/perf/Documentation/perf-record.txt @@ -671,6 +671,24 @@ Example of bash shell script to enable and disable events during measurements: wait -n ${perf_pid} exit $? +--threads=:: +Write collected trace data into several data files using parallel threads. + value can be user defined list of masks. Masks separated by colon +define cpus to be monitored by a thread and affinity mask of that thread +is separated by slash. For example user specification like the following: +/:/ specifies +parallel threads layout that consists of two threads with corresponding +assigned cpus to be monitored. value can also be a string meaning +predefined parallel threads layout: + cpu - create new data streaming thread for every monitored cpu + core - create new thread to monitor cpus grouped by a core + socket - create new thread to monitor cpus grouped by a socket + numa - create new threed to monitor cpus grouped by a numa domain +Predefined layouts can be used on systems with large number of cpus in +order not to spawn multiple per-cpu streaming threads but still avoid LOST +events in data directory files. Option specified with no or empty value +defaults to cpu layout. Masks defined or provided by the option value are +filtered through the mask provided by -C option. SEE ALSO -------- diff --git a/tools/perf/builtin-record.c b/tools/perf/builtin-record.c index fd0587d636b2..9ea70dfa17d4 100644 --- a/tools/perf/builtin-record.c +++ b/tools/perf/builtin-record.c @@ -798,6 +798,12 @@ static int record__auxtrace_init(struct record *rec) { int err; + if ((rec->opts.auxtrace_snapshot_opts || rec->opts.auxtrace_sample_opts) + && record__threads_enabled(rec)) { + pr_err("AUX area tracing options are not available in parallel streaming mode.\n"); + return -EINVAL; + } + if (!rec->itr) { rec->itr = auxtrace_record__init(rec->evlist, &err); if (err) @@ -2107,6 +2113,11 @@ static int __cmd_record(struct record *rec, int argc, const char **argv) return PTR_ERR(session); } + if (record__threads_enabled(rec) && perf_data__is_pipe(&rec->data)) { + pr_err("Parallel trace streaming is not available in pipe mode.\n"); + return -1; + } + fd = perf_data__fd(data); rec->session = session; @@ -2853,12 +2864,22 @@ static int switch_output_setup(struct record *rec) * --switch-output=signal, as we'll send a SIGUSR2 from the side band * thread to its parent. */ - if (rec->switch_output_event_set) + if (rec->switch_output_event_set) { + if (record__threads_enabled(rec)) { + pr_warning("WARNING: --switch-output-event option is not available in parallel streaming mode.\n"); + return 0; + } goto do_signal; + } if (!s->set) return 0; + if (record__threads_enabled(rec)) { + pr_warning("WARNING: --switch-output option is not available in parallel streaming mode.\n"); + return 0; + } + if (!strcmp(s->str, "signal")) { do_signal: s->signal = true; @@ -3137,8 +3158,8 @@ static struct option __record_options[] = { "Set affinity mask of trace reading thread to NUMA node cpu mask or cpu of processed mmap buffer", record__parse_affinity), #ifdef HAVE_ZSTD_SUPPORT - OPT_CALLBACK_OPTARG('z', "compression-level", &record.opts, &comp_level_default, - "n", "Compressed records using specified level (default: 1 - fastest compression, 22 - greatest compression)", + OPT_CALLBACK_OPTARG('z', "compression-level", &record.opts, &comp_level_default, "n", + "Compress records using specified level (default: 1 - fastest compression, 22 - greatest compression)", record__parse_comp_level), #endif OPT_CALLBACK(0, "max-size", &record.output_max_size, @@ -3510,6 +3531,17 @@ int cmd_record(int argc, const char **argv) if (rec->opts.kcore || record__threads_enabled(rec)) rec->data.is_dir = true; + if (record__threads_enabled(rec)) { + if (rec->opts.affinity != PERF_AFFINITY_SYS) { + pr_err("--affinity option is mutually exclusive to parallel streaming mode.\n"); + goto out_opts; + } + if (record__aio_enabled(rec)) { + pr_err("Asynchronous streaming mode (--aio) is mutually exclusive to parallel streaming mode.\n"); + goto out_opts; + } + } + if (rec->opts.comp_level != 0) { pr_debug("Compression enabled, disabling build id collection at the end of the session.\n"); rec->no_buildid = true; @@ -3543,6 +3575,11 @@ int cmd_record(int argc, const char **argv) } } + if (rec->timestamp_filename && record__threads_enabled(rec)) { + rec->timestamp_filename = false; + pr_warning("WARNING: --timestamp-filename option is not available in parallel streaming mode.\n"); + } + /* * Allow aliases to facilitate the lookup of symbols for address * filters. Refer to auxtrace_parse_filters(). -- 2.24.1