Received: by 2002:a25:7ec1:0:0:0:0:0 with SMTP id z184csp2540105ybc; Wed, 20 Nov 2019 16:17:09 -0800 (PST) X-Google-Smtp-Source: APXvYqyzaO1mP4o90Ol8AVf/OG6XsLAtn6d7sLGipQz9dP0LTNBrq5Xvn4y8TvdZxk7DYqg0YG/T X-Received: by 2002:a17:906:fac7:: with SMTP id lu7mr9351059ejb.5.1574295429035; Wed, 20 Nov 2019 16:17:09 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1574295429; cv=none; d=google.com; s=arc-20160816; b=LPAFrOmjdWKb495Q2nu3U+SS5A2LLNAlL2gL2XPAdiz+UYZuBYfFE65d9DtQGaHcs7 DW0t9+Tw3HBPrc/VfSV9D0p1QfwoQZ4pQKCdo++RZQegL+7WqXaqmkmRWXIU8FmWo6rt Nf9gQd02waJP4iM5FaIamCA2kCoud0sxungsKzUmSJyyZssGYeW0bRjNHjranfacMgD2 RNUwoxUikY3xXUSbqvS/2upgX0l+Zrd1ZAJM+5yAEqBnBSjqbnD1Tig+XlfESpriC03M TXRm+9c4ixKMQWS4lzLhhTcVRCZGEzy/Mbzk/vGNRC59i7vXfrr995ntoL5Zdmnt2e4/ oj8g== 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=q0PQvM44jh2G+l6JQo1kKJHmTx0JqluCS6mqVjgLvA/DZLTjeogQNbkMH1FmfEOSU2 EgK+6xDlWwzQkmBsQbk24oPLREaGSk/7kPFHJHuIwRDArGdy1oMP8Ms/oD76+dmEqdNH 1YZkcH6hbF8lSzD5cyzggRD3buA/IU5AtkBnbS30ydzDrc0mww/iC+Z+Bm8w2euqAuL4 x8rn0ecDc4zKg98WwaSn+llgqTlMC+D66FSAdAylk3hO8xRQCtkY7oEWMCBzlcnBEO/x BiZgaanFCmMZI1n/Sx9BDCdslTVzGxoPHKjT6Y1xC0kmyPtnMTw/rA5VKRJiiQq46GNV fE5A== 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 f2si595246ejf.231.2019.11.20.16.16.45; Wed, 20 Nov 2019 16:17:09 -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 S1727099AbfKUAPg (ORCPT + 99 others); Wed, 20 Nov 2019 19:15:36 -0500 Received: from mga06.intel.com ([134.134.136.31]:58451 "EHLO mga06.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727031AbfKUAPg (ORCPT ); Wed, 20 Nov 2019 19:15:36 -0500 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga005.jf.intel.com ([10.7.209.41]) by orsmga104.jf.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 20 Nov 2019 16:15:34 -0800 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.69,223,1571727600"; d="scan'208";a="381553876" Received: from tassilo.jf.intel.com (HELO tassilo.localdomain) ([10.7.201.21]) by orsmga005.jf.intel.com with ESMTP; 20 Nov 2019 16:15:34 -0800 Received: by tassilo.localdomain (Postfix, from userid 1000) id A42E8300D85; Wed, 20 Nov 2019 16:15:34 -0800 (PST) From: Andi Kleen To: acme@kernel.org Cc: jolsa@kernel.org, linux-kernel@vger.kernel.org, Andi Kleen Subject: [PATCH 07/12] perf stat: Use affinity for closing file descriptors Date: Wed, 20 Nov 2019 16:15:17 -0800 Message-Id: <20191121001522.180827-8-andi@firstfloor.org> X-Mailer: git-send-email 2.23.0 In-Reply-To: <20191121001522.180827-1-andi@firstfloor.org> References: <20191121001522.180827-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