Received: by 2002:a25:31c3:0:0:0:0:0 with SMTP id x186csp6896928ybx; Mon, 11 Nov 2019 17:00:52 -0800 (PST) X-Google-Smtp-Source: APXvYqxNNkBL952Iav3BST97XnEMKLzmIj5NmxvAizShuHqd14krWGHlQYnxLxcHBblA8tKShXz7 X-Received: by 2002:a17:906:1c59:: with SMTP id l25mr25367025ejg.98.1573520452826; Mon, 11 Nov 2019 17:00:52 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1573520452; cv=none; d=google.com; s=arc-20160816; b=QDsE3ZNiWFMHryj2ILwDwwfpxsebMBQdd04hvZ4Ef29Pduqy6+KrSt83U8uV7SI243 poXjT4/BP8shTrC8AiB85e4TyoCIBxrAAYt3A9iXDxLx0xHWvVRNRRBdNobR07Xxppxd TEmdEAMGGHLqvVv6q2zAvoIn0m+M/ckreGe275zqreu9oXIjcqBMoo4OWIdn9SAnSnn/ oTQty8t8zgtAXjjkLbwpOfrSNvrnSTtkv2NNVmiQOkp3vaHSwdGeF3TwUsITFzIJUr3/ WJJBho8XAHXRhQs5dQjnh5zz56FYBdk6AiBgEj812QlaVDLjNe6R+n0O6QrudOBGvMCR 36kw== 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:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from; bh=Qiyurf1k2z/VpMEwP1dAbF1QTp6xu27qvHDcw1LHq1g=; b=Y3mEZ4FdIAkOrfybtRq6vvNfw+3B3SrjJtu2bf44Hd5ZZtj+IEj+RY6kPK2zKFTMJF oaKA0pvzcM+rt2eMlAMppbGTqbgoP9U7vwS4mNwe6vdnAnEBVxIEkgwKKwiu1zINLMcm 717gFQh3CBXxO/5grMr4DPtwcJQxuuPxB+jax4BokPvqhALnT/BazS+g4mXLg6squqB2 i63C9WrrB06YzaAE+12RNLOzE5b5wG0yUvF4EFQOA5zrTfqcVhtS4VMF3GmxAGC8mGKO 18xXaNmC0OjdT+8rdcewtGIx77WGC2ch+CsD4AIAqRw1AzFJS/5qArpt3X1fGPhBs+Ul uwjQ== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id y26si11979660edb.360.2019.11.11.17.00.28; Mon, 11 Nov 2019 17:00:52 -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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727351AbfKLA7q (ORCPT + 99 others); Mon, 11 Nov 2019 19:59:46 -0500 Received: from mga14.intel.com ([192.55.52.115]:61337 "EHLO mga14.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726912AbfKLA7o (ORCPT ); Mon, 11 Nov 2019 19:59:44 -0500 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga002.jf.intel.com ([10.7.209.21]) by fmsmga103.fm.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 11 Nov 2019 16:59:43 -0800 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.68,294,1569308400"; d="scan'208";a="215864799" Received: from tassilo.jf.intel.com (HELO tassilo.localdomain) ([10.7.201.21]) by orsmga002.jf.intel.com with ESMTP; 11 Nov 2019 16:59:43 -0800 Received: by tassilo.localdomain (Postfix, from userid 1000) id 226F6301AFA; Mon, 11 Nov 2019 16:59:43 -0800 (PST) From: Andi Kleen To: jolsa@kernel.org Cc: acme@kernel.org, linux-kernel@vger.kernel.org, Andi Kleen Subject: [PATCH v6 07/12] perf stat: Use affinity for closing file descriptors Date: Mon, 11 Nov 2019 16:59:36 -0800 Message-Id: <20191112005941.649137-8-andi@firstfloor.org> X-Mailer: git-send-email 2.23.0 In-Reply-To: <20191112005941.649137-1-andi@firstfloor.org> References: <20191112005941.649137-1-andi@firstfloor.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Andi Kleen Closing a perf fd can also trigger an IPI to the target CPU. Use the same affinity technique as we use for reading/enabling events to closing to optimize the CPU transitions. Before on a large test case with 94 CPUs: % time seconds usecs/call calls errors syscall ------ ----------- ----------- --------- --------- ---------------- 32.56 3.085463 50 61483 close After: 10.54 0.735704 11 61485 close Signed-off-by: Andi Kleen --- v2: Use new iterator macros v3: Use new iterator macros Add missing affinity__cleanup v4: Update iterators again v5: Add comments --- tools/perf/util/evlist.c | 31 +++++++++++++++++++++++++++++-- 1 file changed, 29 insertions(+), 2 deletions(-) diff --git a/tools/perf/util/evlist.c b/tools/perf/util/evlist.c index dae6e846b2f8..7db49a0a0350 100644 --- a/tools/perf/util/evlist.c +++ b/tools/perf/util/evlist.c @@ -18,6 +18,7 @@ #include "debug.h" #include "units.h" #include // page_size +#include "affinity.h" #include "../perf.h" #include "asm/bug.h" #include "bpf-event.h" @@ -1169,9 +1170,35 @@ void perf_evlist__set_selected(struct evlist *evlist, void evlist__close(struct evlist *evlist) { struct evsel *evsel; + struct affinity affinity; + int cpu, i; - evlist__for_each_entry_reverse(evlist, evsel) - evsel__close(evsel); + /* + * With perf record core.cpus is usually NULL. + * Use the old method to handle this for now. + */ + if (!evlist->core.cpus) { + evlist__for_each_entry_reverse(evlist, evsel) + evsel__close(evsel); + return; + } + + if (affinity__setup(&affinity) < 0) + return; + evlist__for_each_cpu (evlist, i, cpu) { + affinity__set(&affinity, cpu); + + evlist__for_each_entry_reverse(evlist, evsel) { + if (evsel__cpu_iter_skip(evsel, cpu)) + continue; + perf_evsel__close_cpu(&evsel->core, evsel->cpu_iter - 1); + } + } + affinity__cleanup(&affinity); + evlist__for_each_entry_reverse(evlist, evsel) { + perf_evsel__free_fd(&evsel->core); + perf_evsel__free_id(&evsel->core); + } } static int perf_evlist__create_syswide_maps(struct evlist *evlist) -- 2.23.0