Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp645324ybt; Wed, 8 Jul 2020 08:20:37 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzz3SI2c7PJchJPFm+wvaPhJZvpiqurz2NDT9PPFji0+6AyeHfyjCrdVJI93GovHBwso/i2 X-Received: by 2002:a17:906:4a45:: with SMTP id a5mr50968427ejv.384.1594221636936; Wed, 08 Jul 2020 08:20:36 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1594221636; cv=none; d=google.com; s=arc-20160816; b=FuqlbthFMMMLtd8ntWW/ZxErvQGChWAyzVqTMvhoWOKvA7Mzl1X+r0XVjzlwsz2oQM fH6oa1qoXk1q7qmfUeEtqMqWNvk1nHQmQIWBX6KnDWXjRou8gGw/Fgbp4FpDRpAf6ghA BQ6GK3hEnPMJ4aUbHn9cuJ2x1kqrv1tLkyYPAifFoO7uFbjja+6relYofIUYZqOyC+te gL1fzwD8ABg6Am1Ng8yx/vt3OTX/Z2Jr4+ov3XU/GCXsomIvd1qooL5nitDNmwtEL2nX 3Dj2BBTXM/+oLV122BXsSvKHU0K5naWuYX3qBnoomTbeG29ipjs57CAJqD2iMXdxAUOm WQrA== 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 :message-id:date:subject:cc:to:from:ironport-sdr:ironport-sdr; bh=oF9pd4DI3qvB81pKn2+D7oyvvY7IhptEgnUy4NPo1Os=; b=RVd7KY2Iq8rGgUqL2GNJKT9onqxbw+ZN+Z6K0FvO/l1PD/49CM597A/9Q0t8X6hkpt uE3xXnxUJPQ/AbynlWuqaFx2BlwEZshPxxj+tHDESj8l6YljwgKmlmF7GrfWJPAEz/zr AXQsN8zNSbR87ss9snrZH1xTFnv4HBOPTsw0W0alarAAa7GOBgvPlO/sEg0mdJ9MOib6 Il8Oou/tcMkisLL73ckj6cIM3q75aolEI86f9apBBTLaF0Sw1bWr0viKQJi1x3KGjORv MI9YkjOKkOYP2QJAyyFrjXmdvM1wxizRvo4emX1ulV2PsryQR2ON9gUvXRRIvqXC4bCw IJ4g== 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 ga5si54160ejb.567.2020.07.08.08.20.14; Wed, 08 Jul 2020 08:20:36 -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 S1730119AbgGHPTK (ORCPT + 99 others); Wed, 8 Jul 2020 11:19:10 -0400 Received: from mga01.intel.com ([192.55.52.88]:64868 "EHLO mga01.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729022AbgGHPTK (ORCPT ); Wed, 8 Jul 2020 11:19:10 -0400 IronPort-SDR: p3ImO6w58ENSzBMFnnAnXZH4a5mNXb4vNl4XDQD+fQMb8hB2Zm8eCpu7ZkbKO8DDaboDdUg7pT 9hKjG6qKksNA== X-IronPort-AV: E=McAfee;i="6000,8403,9676"; a="165929567" X-IronPort-AV: E=Sophos;i="5.75,327,1589266800"; d="scan'208";a="165929567" X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga006.jf.intel.com ([10.7.209.51]) by fmsmga101.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 08 Jul 2020 08:16:50 -0700 IronPort-SDR: Vy40RHloS8edlXSM86Rp+AIdeOqWAJP89X+nfG35v0MbQSs1SV6Mjar8ACAx9b6OoUGnkxJ4Xc CRPI+uUu3STg== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.75,327,1589266800"; d="scan'208";a="283827370" Received: from black.fi.intel.com (HELO black.fi.intel.com.) ([10.237.72.28]) by orsmga006.jf.intel.com with ESMTP; 08 Jul 2020 08:16:47 -0700 From: Alexander Shishkin To: Peter Zijlstra , Arnaldo Carvalho de Melo Cc: Ingo Molnar , linux-kernel@vger.kernel.org, Jiri Olsa , alexey.budankov@linux.intel.com, adrian.hunter@intel.com, Alexander Shishkin Subject: [PATCH 0/2] perf: Allow closing siblings' file descriptors Date: Wed, 8 Jul 2020 18:16:33 +0300 Message-Id: <20200708151635.81239-1-alexander.shishkin@linux.intel.com> X-Mailer: git-send-email 2.27.0 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 Hi guys, I've been looking at reducing the number of open file descriptors per perf session. If we retain one descriptor per event, in a large group they add up. At the same time, we're not actually using them for anything after the SET_OUTPUT and maybe SET_FILTER ioctls. So, this series is a stab at that. So, I added a new flag to the perf_event_open() that tells perf to keep the event around after its file descriptor gets closed, for as long as its group leader is alive. Since this is a new behavior, the flag is an opt-in. I also hacked this into the perf tool (mostly perf record, but I'll hack stat as well if this general approach is agreeable). Alexander Shishkin (2): perf: Add closing sibling events' file descriptors perf record: Support closing siblings' file descriptors include/linux/perf_event.h | 7 ++ include/uapi/linux/perf_event.h | 1 + kernel/events/core.c | 149 +++++++++++++++++------- tools/include/uapi/linux/perf_event.h | 1 + tools/lib/perf/evlist.c | 30 ++++- tools/lib/perf/evsel.c | 21 ++++ tools/lib/perf/include/internal/evsel.h | 4 + tools/perf/builtin-record.c | 48 ++++++-- tools/perf/util/cpumap.c | 4 + tools/perf/util/evlist.c | 4 +- tools/perf/util/evsel.c | 17 ++- tools/perf/util/evsel.h | 3 + 12 files changed, 234 insertions(+), 55 deletions(-) -- 2.27.0