Message ID | 2ed992d6604965fd9eea05fed4473ddf54540989.1679183626.git.lstoakes@gmail.com |
---|---|
State | New |
Headers |
Return-Path: <linux-kernel-owner@vger.kernel.org> Delivered-To: ouuuleilei@gmail.com Received: by 2002:a5d:604a:0:0:0:0:0 with SMTP id j10csp532113wrt; Sat, 18 Mar 2023 18:34:44 -0700 (PDT) X-Google-Smtp-Source: AK7set9rfdH0ER5j4kU+xOTNjEF2ZEv1TjsJCA1JV7iCLhu+Tx+5jwkwXUSXF0QKVREVdsfkTG4C X-Received: by 2002:a17:90a:313:b0:23d:35d9:d05b with SMTP id 19-20020a17090a031300b0023d35d9d05bmr13413294pje.14.1679189683800; Sat, 18 Mar 2023 18:34:43 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1679189683; cv=none; d=google.com; s=arc-20160816; b=bAncSH+e9SheO/eSytmz3fK8YI0n4qyh4A9p/JnRvT3aNs7FoLO7kwvO4cCHtt1Gjk /tcKsoFAe5Ttcd26x/cNmGvlQoU76rlLxspMNiz+8fIJWHjg5ucw9yVBvCGlLVs4/MMf 0ctixtwBB5mMdoDfw5D0TbPv4UxkfqTWrMJ8t8X4trIlOpydT7Tg+3sB96obQMpwI6kO n4C2ex7/oLsSlw15m9rih+KhhdwgPpYZmf0DlUVlPsZsG85XNFPrm+UPD40FqhovYRGl TtUmoaUQNbg0hTg4SSzVdw9+Jh1qeixSXmvMZ0MBNCDrlorLlcoUZx/ihJOWqq4iN5Tb /x7Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=csP2U+h4A4N+JyUsV24C6SnnqlSeb33JonwK9o1duFk=; b=0HQFFnbawrfmc08K5SkHjQnsHudgfXpODMk6MUe8v3j6YGd6ESPQIa9yivds0jLw6C zNSa/sqnzneoafJIssxJONJyrGfKuMoFRGLrISnQgnUWvlB6HrSktaqUll62PXrSfa7G 0umdEwppp3amWESM910MIH6mK7F7tqxq1C1GrqzQbaD+x+kHDp3X4oZQHXuRgDac0n2H /lMKFoS49BYQzXcxrXjTluN1+FuWdwP7I4vsR/OwDpg7Rz/IejLD/fyzaZiJHoy8ch8h ZMdMEKS+jzcznkF6jp3p9lda8qtWzyi/LeoVSmkSzy1vK34fUJ5pWrOw1NLESOHWhHKc BMyA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b=nC6RYf6j; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id fs3-20020a17090af28300b0023d53736026si6386775pjb.125.2023.03.18.18.34.31; Sat, 18 Mar 2023 18:34:43 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b=nC6RYf6j; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230247AbjCSAZl (ORCPT <rfc822;pusanteemu@gmail.com> + 99 others); Sat, 18 Mar 2023 20:25:41 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:47486 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230443AbjCSAYW (ORCPT <rfc822;linux-kernel@vger.kernel.org>); Sat, 18 Mar 2023 20:24:22 -0400 Received: from mail-wr1-x42f.google.com (mail-wr1-x42f.google.com [IPv6:2a00:1450:4864:20::42f]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 0F2E22A6E8; Sat, 18 Mar 2023 17:21:38 -0700 (PDT) Received: by mail-wr1-x42f.google.com with SMTP id y14so7381832wrq.4; Sat, 18 Mar 2023 17:21:37 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; t=1679185217; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=csP2U+h4A4N+JyUsV24C6SnnqlSeb33JonwK9o1duFk=; b=nC6RYf6jBdzIKQ4o3vm7PvlkCYMlOb1FdP26eTaA7XVeOCh6KBdfA7t8A9kV0DJyUu Zla8U4rG4p3JsUlcTbj1hALd7X+zuQQyHPo31R1hXSlO6RI1L+zQQ6nLiJl+1/Xd7U7U apPCOgsxAoHSLFM0qPvVpo7u61XC0kmIRa5pxuaYfocJcUN0AOST09bBvQuEcJGH8esh Ib/zsOkFPFJkM6s012r+iEmCzFsVMHBLJiz8a/qppPITwzE0psbE/fxPchSR/bE9d1mw OfIHu0q2z+2gyGNfQdqreV8GYmkXjgOOuUaUsHA43nqXVPlwr56UszPzKQAefMoPfCHJ 5Cqw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; t=1679185217; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=csP2U+h4A4N+JyUsV24C6SnnqlSeb33JonwK9o1duFk=; b=vmsTJjT1h1n0x8CuDFUASxp1SZXpyChGvQvj4UemXTxwc05NpHU+h0XM70NNuOe77q mzZSsaOYaRaNQEgIj1udTHyA6XPibJHNKjCbiVG+sda/dni62mBdy94HWJ0wlcyD2tFi dIzO6G2SsLVCbR4pvPLU3PKgNg8N4VxflmXuRofdHsO7GLmKgcdBPqikGv6uv99CmKpP YqEztcmAFh4g2QKFnYMyYTlQjAbCvUNumelo+Q7iT+b5bwDFDcjaEVNDmMrjFKOot2xf sz1RUYAhU+pfspUyecmtr/ce/0u909DEV7i++h4dnoR/CQmtsFMAUIRhjkvk4cQabP7i z74w== X-Gm-Message-State: AO0yUKUirSlZLywteyOnfhJdifQIT18hIzns1/GfuB05V6vyxcxbNXqD Zgiqyz+nFqAwYgK5QGyIfR8= X-Received: by 2002:a5d:54c1:0:b0:2d3:fba4:e61d with SMTP id x1-20020a5d54c1000000b002d3fba4e61dmr4877179wrv.12.1679185217216; Sat, 18 Mar 2023 17:20:17 -0700 (PDT) Received: from lucifer.home (host86-146-209-214.range86-146.btcentralplus.com. [86.146.209.214]) by smtp.googlemail.com with ESMTPSA id x14-20020adfdd8e000000b002cff0c57b98sm5399639wrl.18.2023.03.18.17.20.15 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sat, 18 Mar 2023 17:20:16 -0700 (PDT) From: Lorenzo Stoakes <lstoakes@gmail.com> To: linux-mm@kvack.org, linux-kernel@vger.kernel.org, linux-fsdevel@vger.kernel.org, Andrew Morton <akpm@linux-foundation.org> Cc: Baoquan He <bhe@redhat.com>, Uladzislau Rezki <urezki@gmail.com>, Matthew Wilcox <willy@infradead.org>, David Hildenbrand <david@redhat.com>, Liu Shixin <liushixin2@huawei.com>, Jiri Olsa <jolsa@kernel.org>, Lorenzo Stoakes <lstoakes@gmail.com> Subject: [PATCH 1/4] fs/proc/kcore: Avoid bounce buffer for ktext data Date: Sun, 19 Mar 2023 00:20:09 +0000 Message-Id: <2ed992d6604965fd9eea05fed4473ddf54540989.1679183626.git.lstoakes@gmail.com> X-Mailer: git-send-email 2.39.2 In-Reply-To: <cover.1679183626.git.lstoakes@gmail.com> References: <cover.1679183626.git.lstoakes@gmail.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,FREEMAIL_FROM, RCVD_IN_DNSWL_NONE,SPF_HELO_NONE,SPF_PASS autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: <linux-kernel.vger.kernel.org> X-Mailing-List: linux-kernel@vger.kernel.org X-getmail-retrieved-from-mailbox: =?utf-8?q?INBOX?= X-GMAIL-THRID: =?utf-8?q?1760758002137006670?= X-GMAIL-MSGID: =?utf-8?q?1760758002137006670?= |
Series | convert read_kcore(), vread() to use iterators | |
Commit Message
Lorenzo Stoakes
March 19, 2023, 12:20 a.m. UTC
Commit df04abfd181a ("fs/proc/kcore.c: Add bounce buffer for ktext data")
introduced the use of a bounce buffer to retrieve kernel text data for
/proc/kcore in order to avoid failures arising from hardened user copies
enabled by CONFIG_HARDENED_USERCOPY in check_kernel_text_object().
We can avoid doing this if instead of copy_to_user() we use _copy_to_user()
which bypasses the hardening check. This is more efficient than using a
bounce buffer and simplifies the code.
We do so as part an overall effort to eliminate bounce buffer usage in the
function with an eye to converting it an iterator read.
Signed-off-by: Lorenzo Stoakes <lstoakes@gmail.com>
---
fs/proc/kcore.c | 17 +++++------------
1 file changed, 5 insertions(+), 12 deletions(-)
diff --git a/fs/proc/kcore.c b/fs/proc/kcore.c index 71157ee35c1a..556f310d6aa4 100644 --- a/fs/proc/kcore.c +++ b/fs/proc/kcore.c @@ -541,19 +541,12 @@ read_kcore(struct file *file, char __user *buffer, size_t buflen, loff_t *fpos) case KCORE_VMEMMAP: case KCORE_TEXT: /* - * Using bounce buffer to bypass the - * hardened user copy kernel text checks. + * We use _copy_to_user() to bypass usermode hardening + * which would otherwise prevent this operation. */ - if (copy_from_kernel_nofault(buf, (void *)start, tsz)) { - if (clear_user(buffer, tsz)) { - ret = -EFAULT; - goto out; - } - } else { - if (copy_to_user(buffer, buf, tsz)) { - ret = -EFAULT; - goto out; - } + if (_copy_to_user(buffer, (char *)start, tsz)) { + ret = -EFAULT; + goto out; } break; default: