Received: by 2002:a25:1506:0:0:0:0:0 with SMTP id 6csp533581ybv; Wed, 5 Feb 2020 09:48:30 -0800 (PST) X-Google-Smtp-Source: APXvYqza9ZM1S/EDKU9VqQ7bCX60783IEuzFPcD7nCj0aCATAMj2IMSLvsn9lIT6DW0whJkTe0Bf X-Received: by 2002:aca:db43:: with SMTP id s64mr3625014oig.144.1580924910608; Wed, 05 Feb 2020 09:48:30 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1580924910; cv=none; d=google.com; s=arc-20160816; b=dLotgpbl5UWWuMhcWtIQgfYkNo3iCE4NIq97q0sFDEBGfT9vRGL6jizod7sAZBxMeV gaQXdHgyBS+Mv6iI482EYRO7tlVeAEVoeXITrBQCGrdRzfs6GhrW/GL7IMDWc1k9zp17 AF/5+0LrhsEKY0h51iQ+BvO+eqzZ83o2yTv7PCEaFqVwT7+F0kx+phEzXg6QiHe08sbx fqVNoylZUXuDXc/kxbrqQtrGXY3SWjyMUU/wnpv6po0t/+qmoc+LVqRDMFx5ggG00Qcc 76mG2fduPlZtBMZ/dHZKLnyOVhdEzJcSDymI8yOhBHOH2NYYvTlhhG+pwMkhPbJwTbX0 zFCw== 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 :content-language:in-reply-to:mime-version:user-agent:date :message-id:organization:references:cc:to:from:subject; bh=uDftm6MSyfGej+pxHVpXqxy5wKKFKo1lbL+1If/7uyk=; b=ALqiBRf6BriOGRHF1Q3L6yVg1NkTcQcrFzuOVtstt1sgjk8+tysuk1LgWqfLLQrrJH ZykCUIZaVmhTd6JzdPvOdgcIWWGhTJVfvx2aCEmBjq1Byk4EHubNT3bUib/CesrE/KaQ Dk/oeFLvZiOAHRMaBSDg1xaRpjNY2/9KwaT43e9jGDIx/W2Ehfz1GI8E5JD92XmaaXVb eyIX7FGX9J+QMmRGrW+lYCQYkOoeyuqh7n39cnDCt1Q8Tb37+hWeypIbjkTN5SQQSY0u F+Bmlmlg9ogiWqZARiDygt+t/WrcYTf3BfTs8vqNQdl62bujtQx1Zg6to9YwzhA4qQSA /aFw== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id u14si128514otg.10.2020.02.05.09.48.15; Wed, 05 Feb 2020 09:48:30 -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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727444AbgBERbE (ORCPT + 99 others); Wed, 5 Feb 2020 12:31:04 -0500 Received: from mga12.intel.com ([192.55.52.136]:41444 "EHLO mga12.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727305AbgBERbE (ORCPT ); Wed, 5 Feb 2020 12:31:04 -0500 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from fmsmga001.fm.intel.com ([10.253.24.23]) by fmsmga106.fm.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 05 Feb 2020 09:31:03 -0800 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.70,406,1574150400"; d="scan'208";a="343791237" Received: from linux.intel.com ([10.54.29.200]) by fmsmga001.fm.intel.com with ESMTP; 05 Feb 2020 09:31:03 -0800 Received: from [10.252.5.149] (abudanko-mobl.ccr.corp.intel.com [10.252.5.149]) by linux.intel.com (Postfix) with ESMTP id 863EC5803E3; Wed, 5 Feb 2020 09:30:56 -0800 (PST) Subject: [PATCH v6 02/10] perf/core: open access to the core for CAP_PERFMON privileged process From: Alexey Budankov To: James Morris , Serge Hallyn , Stephen Smalley , Peter Zijlstra , Arnaldo Carvalho de Melo , Ingo Molnar , "joonas.lahtinen@linux.intel.com" , Alexei Starovoitov , Will Deacon , Paul Mackerras , Michael Ellerman Cc: Andi Kleen , Thomas Gleixner , Stephane Eranian , Igor Lubashev , Jiri Olsa , linux-kernel , "intel-gfx@lists.freedesktop.org" , "linux-security-module@vger.kernel.org" , "selinux@vger.kernel.org" , linux-arm-kernel , "linuxppc-dev@lists.ozlabs.org" , "linux-parisc@vger.kernel.org" , oprofile-list@lists.sf.net References: <576a6141-36d4-14c0-b395-8d195892b916@linux.intel.com> Organization: Intel Corp. Message-ID: <0f35b211-b719-3c91-e067-2c63560c5af8@linux.intel.com> Date: Wed, 5 Feb 2020 20:30:55 +0300 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:68.0) Gecko/20100101 Thunderbird/68.4.2 MIME-Version: 1.0 In-Reply-To: <576a6141-36d4-14c0-b395-8d195892b916@linux.intel.com> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Open access to monitoring of kernel code, cpus, tracepoints and namespaces data for a CAP_PERFMON privileged process. Providing the access under CAP_PERFMON capability singly, without the rest of CAP_SYS_ADMIN credentials, excludes chances to misuse the credentials and makes operation more secure. CAP_PERFMON implements the principal of least privilege for performance monitoring and observability operations (POSIX IEEE 1003.1e 2.2.2.39 principle of least privilege: A security design principle that states that a process or program be granted only those privileges (e.g., capabilities) necessary to accomplish its legitimate function, and only for the time that such privileges are actually required) For backward compatibility reasons access to perf_events subsystem remains open for CAP_SYS_ADMIN privileged processes but CAP_SYS_ADMIN usage for secure perf_events monitoring is discouraged with respect to CAP_PERFMON capability. Signed-off-by: Alexey Budankov --- include/linux/perf_event.h | 6 +++--- kernel/events/core.c | 2 +- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/include/linux/perf_event.h b/include/linux/perf_event.h index 6d4c22aee384..730469babcc2 100644 --- a/include/linux/perf_event.h +++ b/include/linux/perf_event.h @@ -1285,7 +1285,7 @@ static inline int perf_is_paranoid(void) static inline int perf_allow_kernel(struct perf_event_attr *attr) { - if (sysctl_perf_event_paranoid > 1 && !capable(CAP_SYS_ADMIN)) + if (sysctl_perf_event_paranoid > 1 && !perfmon_capable()) return -EACCES; return security_perf_event_open(attr, PERF_SECURITY_KERNEL); @@ -1293,7 +1293,7 @@ static inline int perf_allow_kernel(struct perf_event_attr *attr) static inline int perf_allow_cpu(struct perf_event_attr *attr) { - if (sysctl_perf_event_paranoid > 0 && !capable(CAP_SYS_ADMIN)) + if (sysctl_perf_event_paranoid > 0 && !perfmon_capable()) return -EACCES; return security_perf_event_open(attr, PERF_SECURITY_CPU); @@ -1301,7 +1301,7 @@ static inline int perf_allow_cpu(struct perf_event_attr *attr) static inline int perf_allow_tracepoint(struct perf_event_attr *attr) { - if (sysctl_perf_event_paranoid > -1 && !capable(CAP_SYS_ADMIN)) + if (sysctl_perf_event_paranoid > -1 && !perfmon_capable()) return -EPERM; return security_perf_event_open(attr, PERF_SECURITY_TRACEPOINT); diff --git a/kernel/events/core.c b/kernel/events/core.c index 2173c23c25b4..d956c81bd310 100644 --- a/kernel/events/core.c +++ b/kernel/events/core.c @@ -11186,7 +11186,7 @@ SYSCALL_DEFINE5(perf_event_open, } if (attr.namespaces) { - if (!capable(CAP_SYS_ADMIN)) + if (!perfmon_capable()) return -EACCES; } -- 2.20.1