Received: by 10.192.165.148 with SMTP id m20csp203567imm; Thu, 3 May 2018 18:11:04 -0700 (PDT) X-Google-Smtp-Source: AB8JxZqqYjiwd6NX41BnjxmHV2xt793uqHVfbaVZrLDlxbsi2FNoxoJaG0/aqvJpWw3tGc2Wg3Jc X-Received: by 10.98.251.20 with SMTP id x20mr25023468pfm.48.1525396264680; Thu, 03 May 2018 18:11:04 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1525396264; cv=none; d=google.com; s=arc-20160816; b=dxM5wVLzHzf+1Xa0X5UvFDhWFNBKPxpXQZG4R/NXgg/M3f5VQ1q88d1CYzyMeId2Mw XynMqYHhgyTCCNbhrodGRMdjNwPtZGZ4pgq25LFPJkacsCTbZnuzOekUZZqw565CX4en bYNw6SDt33yY8qD06n6Fo/ECXNANER2MSH1KSp3vfIaaL81dUAoxKoOG1DHFxHRLQ/zR zdLqtgLj9it3sT6VqoWHpjq93rQ2XuddnCy+fYQpCqR4t2N3jqc2rtwiHQ0uxsxJAgtl CX82QX/jVw+Yi1TE3DQpYiN4njQhLwlv2pwGLyIOQ/QtQ14ejCOqT1sPdG53MLzYl+33 hgsg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:arc-authentication-results; bh=lqTlYlQm9bNz/MCEPbQsTDxv4J4GRd7A5u1Wd3N9uvM=; b=SsvmmZQ+4N7OjjKyeVq3H78FyNlrq76kV4sk3QpFKWJ26TqGPUL31BVkCrTNaXicIT Osl5yHRp3TIVlcRmSoiRJyTIy6XfcQrcDNTOFYvwjyNgxqOCTIkLJZVzUiZBIxKHmryh HxnpvN65BFva6TAqvCdp+UZbsSmWzQ5dlJ/jJGvwAq2VVsc5nade24WRCjW+CRtO3Kqo 4dpIJ23T7vmeJnA9rNDQuzMhvi5lQH4LBaxCk48eqJlIS75jpKsk7IAZgh2pRxK5e818 0kXeCPLzbKpZXRZL5Slae59Q8TFWKgaX2LhI96aH+5xywSBqXsbeoewQ8PT+jIkDqvxC mozQ== 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=canonical.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id i15si3271952pfk.146.2018.05.03.18.10.38; Thu, 03 May 2018 18:11:04 -0700 (PDT) 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=canonical.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751445AbeEDBKY (ORCPT + 99 others); Thu, 3 May 2018 21:10:24 -0400 Received: from youngberry.canonical.com ([91.189.89.112]:52119 "EHLO youngberry.canonical.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751411AbeEDBKV (ORCPT ); Thu, 3 May 2018 21:10:21 -0400 Received: from 2.general.tyhicks.us.vpn ([10.172.64.53] helo=sec.ubuntu-ci) by youngberry.canonical.com with esmtpsa (TLS1.0:RSA_AES_128_CBC_SHA1:16) (Exim 4.76) (envelope-from ) id 1fEPDo-0008Hm-QW; Fri, 04 May 2018 01:09:17 +0000 From: Tyler Hicks To: linux-kernel@vger.kernel.org Cc: Kees Cook , Andy Lutomirski , Will Drewry , Paul Moore , Eric Paris , Steve Grubb , Jonathan Corbet , linux-audit@redhat.com, linux-security-module@vger.kernel.org, linux-doc@vger.kernel.org Subject: [PATCH v3 1/4] seccomp: Separate read and write code for actions_logged sysctl Date: Fri, 4 May 2018 01:08:12 +0000 Message-Id: <1525396095-27737-2-git-send-email-tyhicks@canonical.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1525396095-27737-1-git-send-email-tyhicks@canonical.com> References: <1525396095-27737-1-git-send-email-tyhicks@canonical.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Break the read and write paths of the kernel.seccomp.actions_logged sysctl into separate functions to maintain readability. An upcoming change will need to audit writes, but not reads, of this sysctl which would introduce too many conditional code paths on whether or not the 'write' parameter evaluates to true. Signed-off-by: Tyler Hicks --- kernel/seccomp.c | 60 +++++++++++++++++++++++++++++++++++--------------------- 1 file changed, 38 insertions(+), 22 deletions(-) diff --git a/kernel/seccomp.c b/kernel/seccomp.c index dc77548..f4afe67 100644 --- a/kernel/seccomp.c +++ b/kernel/seccomp.c @@ -1199,48 +1199,64 @@ static bool seccomp_actions_logged_from_names(u32 *actions_logged, char *names) return true; } -static int seccomp_actions_logged_handler(struct ctl_table *ro_table, int write, - void __user *buffer, size_t *lenp, - loff_t *ppos) +static int read_actions_logged(struct ctl_table *ro_table, void __user *buffer, + size_t *lenp, loff_t *ppos) { char names[sizeof(seccomp_actions_avail)]; struct ctl_table table; + + memset(names, 0, sizeof(names)); + + if (!seccomp_names_from_actions_logged(names, sizeof(names), + seccomp_actions_logged)) + return -EINVAL; + + table = *ro_table; + table.data = names; + table.maxlen = sizeof(names); + return proc_dostring(&table, 0, buffer, lenp, ppos); +} + +static int write_actions_logged(struct ctl_table *ro_table, void __user *buffer, + size_t *lenp, loff_t *ppos) +{ + char names[sizeof(seccomp_actions_avail)]; + struct ctl_table table; + u32 actions_logged; int ret; - if (write && !capable(CAP_SYS_ADMIN)) + if (!capable(CAP_SYS_ADMIN)) return -EPERM; memset(names, 0, sizeof(names)); - if (!write) { - if (!seccomp_names_from_actions_logged(names, sizeof(names), - seccomp_actions_logged)) - return -EINVAL; - } - table = *ro_table; table.data = names; table.maxlen = sizeof(names); - ret = proc_dostring(&table, write, buffer, lenp, ppos); + ret = proc_dostring(&table, 1, buffer, lenp, ppos); if (ret) return ret; - if (write) { - u32 actions_logged; - - if (!seccomp_actions_logged_from_names(&actions_logged, - table.data)) - return -EINVAL; - - if (actions_logged & SECCOMP_LOG_ALLOW) - return -EINVAL; + if (!seccomp_actions_logged_from_names(&actions_logged, table.data)) + return -EINVAL; - seccomp_actions_logged = actions_logged; - } + if (actions_logged & SECCOMP_LOG_ALLOW) + return -EINVAL; + seccomp_actions_logged = actions_logged; return 0; } +static int seccomp_actions_logged_handler(struct ctl_table *ro_table, int write, + void __user *buffer, size_t *lenp, + loff_t *ppos) +{ + if (write) + return write_actions_logged(ro_table, buffer, lenp, ppos); + else + return read_actions_logged(ro_table, buffer, lenp, ppos); +} + static struct ctl_path seccomp_sysctl_path[] = { { .procname = "kernel", }, { .procname = "seccomp", }, -- 2.7.4