Received: by 2002:ac0:aed5:0:0:0:0:0 with SMTP id t21csp102710imb; Thu, 28 Feb 2019 17:27:39 -0800 (PST) X-Google-Smtp-Source: APXvYqxqswfzTVPlv0qzBnSSy6DSYzuyn2xWFn3u0I5EhI5JGczRKWTBcL6TfbFLJSCcmt8uiGB3 X-Received: by 2002:a17:902:684:: with SMTP id 4mr2590421plh.3.1551403659344; Thu, 28 Feb 2019 17:27:39 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1551403659; cv=none; d=google.com; s=arc-20160816; b=k4JYO9o5kutSBzhfIw3KAyUaYNNZYKRoTZz4bDWInsRccdcXTm4SMI/doZ7Em5aji3 oGdcg6eejawJiFqBMuvO1/v0r7al0JW1OEPP2SVmB43Tpf456vU3LQZ1srOpJUd9fcja GtafiggHZicxoaHQcCuc0SUDwqyjzIb5c+Ghw9mQ/3z2i+quRIcWke9DSWYt21m03afH mCwFwofRsizIyzVTI1vWeHUz/7KF0/v3QPP8Ws7N7VxquLyt5NOx0EULlNAUFGSiq0Kb oHvng63cMUHSTZXWM6Tg0sWcB602LmLthB+iEUA1TCAwVCLe+XDa416qNVi88+saYPmT QfTA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:from:subject:references :mime-version:message-id:in-reply-to:date:dkim-signature; bh=mp70BzDzYljwrYd25Lt2UYdTDnlpZHVvwxSHppwzPMQ=; b=KbVZ/a8aJga6EqsIcFcLrCIKysvkVVElf1QHB54VwN1kSbg1w+tkaxysRwRpcNwyPv onXaZR0AW/ORTh1JiV7S0rEghKOfCCv4dQh0QEkzDenD8c2b0dm3QaRw0spgN1W9biE/ KFjZ1dXMMnQPfe/34jK09JVWDAtAHw8otqmnc0VWwebD97mPDU5Vpb0Hz8yzdhn+9MZi lkw/r4K8TcIV+I+rUT1GsL1aBHOVXagg9/q3Ur5qJsogQ7FTZK4c6e74Ft7IijGDGUYj Xg6hMseRn4hNaszqNNXqkzXu27oKIZDadUWROAoMThq3xsXTQtFcC2FCAUHfFqXQNh51 I+XQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b=d9mbo5KR; 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=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id r3si19660172pgh.392.2019.02.28.17.27.24; Thu, 28 Feb 2019 17:27:39 -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; dkim=pass header.i=@google.com header.s=20161025 header.b=d9mbo5KR; 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=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2387876AbfB1XMo (ORCPT + 99 others); Thu, 28 Feb 2019 18:12:44 -0500 Received: from mail-oi1-f201.google.com ([209.85.167.201]:50160 "EHLO mail-oi1-f201.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2387413AbfB1XMm (ORCPT ); Thu, 28 Feb 2019 18:12:42 -0500 Received: by mail-oi1-f201.google.com with SMTP id a6so9663114oib.16 for ; Thu, 28 Feb 2019 15:12:41 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20161025; h=date:in-reply-to:message-id:mime-version:references:subject:from:to :cc; bh=mp70BzDzYljwrYd25Lt2UYdTDnlpZHVvwxSHppwzPMQ=; b=d9mbo5KRuX/RDzSfaF9z9U/JVALls/m/pz/TIR77Q8r3FIN9dJSFVDfe7as12j9CYg qdZsexqPqnAnxNUev6Df6+SU06uOFjwvNupM5qThkzxUC15WeMpr/ddVBIPpUk/sshgT Yi5w8NjP8cW20UyrwtFhz2TyseSwRojDZ/w/dlGj8GGMfifKP/4bOXm+K2rOU8mgi9Cq APHC6H3pa3BlkFIFnpQhlTRcgtn6Jp9jwLbfbnead8KChCcHOpGUiD4PlmqMesuMwi2j FXGWgUQvqdOBu7336UXlYA4jKK7YzGfa7nW2nwCbZbMRZw9MYFvHqpRhaK7UJesHPJJz QcdA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:in-reply-to:message-id:mime-version :references:subject:from:to:cc; bh=mp70BzDzYljwrYd25Lt2UYdTDnlpZHVvwxSHppwzPMQ=; b=ruhMBnxv2K9d7tPBxdrE4c2UGpgjM8etwyhFbtSaOIBvae2Kj4UtgqxoY70PSX23QN GtYBuwiBP4scQE5owhkPxoA5SEDOhQe1loVq5nPaj+hIaSBL0fONFJyK5BuTQzaM9Tf7 X5C+4grJkwY01iadlX4dZlneIZM3LsSxtIFHnGk4PrBiENe9PvT0QbOdvgBNi3Mv0Kxa j2LNJBrBhnzhBFhMZwKgj8kj0AbnlgIyKYshWFvmwhrAlsapEYmuebz+Ftt2/j0ULiUK JrqTH9lGVunKppLR4enC5r3Z8mJLC/BZNDTCH7FMiMwzuVej37EfLsBssLN02P33BASY Ia1A== X-Gm-Message-State: AHQUAuYBPJWZo1Nqka6oMGjK5SYbzfUUu2OqT6H+/AaAzXKgFdXbIDMI 0Y5IqJ5Czj99lwAcrJ4CHJVOn6YuVZP/90UM9r6Z+A== X-Received: by 2002:aca:4b97:: with SMTP id y145mr1322685oia.19.1551395561327; Thu, 28 Feb 2019 15:12:41 -0800 (PST) Date: Thu, 28 Feb 2019 15:11:50 -0800 In-Reply-To: <20190228231203.212359-1-matthewgarrett@google.com> Message-Id: <20190228231203.212359-14-matthewgarrett@google.com> Mime-Version: 1.0 References: <20190228231203.212359-1-matthewgarrett@google.com> X-Mailer: git-send-email 2.21.0.352.gf09ad66450-goog Subject: [PATCH 14/27] ACPI: Limit access to custom_method when the kernel is locked down From: Matthew Garrett To: jmorris@namei.org Cc: linux-security-module@vger.kernel.org, linux-kernel@vger.kernel.org, dhowells@redhat.com Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Matthew Garrett custom_method effectively allows arbitrary access to system memory, making it possible for an attacker to circumvent restrictions on module loading. Disable it if the kernel is locked down. Signed-off-by: Matthew Garrett Signed-off-by: David Howells Reviewed-by: "Lee, Chun-Yi" cc: linux-acpi@vger.kernel.org --- drivers/acpi/custom_method.c | 3 +++ 1 file changed, 3 insertions(+) diff --git a/drivers/acpi/custom_method.c b/drivers/acpi/custom_method.c index 4451877f83b6..ac8a90dc7096 100644 --- a/drivers/acpi/custom_method.c +++ b/drivers/acpi/custom_method.c @@ -29,6 +29,9 @@ static ssize_t cm_write(struct file *file, const char __user * user_buf, struct acpi_table_header table; acpi_status status; + if (kernel_is_locked_down("ACPI custom methods")) + return -EPERM; + if (!(*ppos)) { /* parse the table header to get the table length */ if (count <= sizeof(struct acpi_table_header)) -- 2.21.0.352.gf09ad66450-goog