Received: by 2002:a05:6a10:1287:0:0:0:0 with SMTP id d7csp3698688pxv; Mon, 26 Jul 2021 09:40:10 -0700 (PDT) X-Google-Smtp-Source: ABdhPJw02OiIyya/s1WIOwF3SEPZ5DgPUM/OKOjQZ3GHot6udRIE8FLktdtO4f8wjD6NjOFXrQBK X-Received: by 2002:a05:6e02:12e3:: with SMTP id l3mr9340319iln.6.1627317512753; Mon, 26 Jul 2021 09:38:32 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1627317512; cv=none; d=google.com; s=arc-20160816; b=kgiaquI7r6VR9LSA6JcyGCSS6dKG9p7nwxR97SlEQK25NM36/CgubKm25iuQ6sVc10 J6OG3d4CKLRERuQTJbSBtbyVlrnrof0IZTl+ng96koa2rXSGOLHZr7yxb8PkAw4zvo7+ jAI8k6EBfkfvq/tdG+xzG9F6ZS00u57pYBXo7v21Ov8TN9fwewGFvDJk865tB2U3yHZB XyfKJXJkQNdUdzF0k7VTR5HAq/4Kuk2AE8cii1iDi47ghHqJH0wFvV4My0PY31ULvQY0 FKSpgvzWoEx/VAoLI3qmZWmArrI4IpV/KOOdyeN9pRPidxcDJQ4wy6I3fspUnDDdhlNk imzA== 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 :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=XxAnBWUXidpFI3bMxiEdqEzG6OzBH+xc6M047ZlgTCw=; b=j7plQQ5gu1U7xuuW2E/qZFI0be+0bgD44UpFngPYwzJMAt5GXXOP6YcPKuPi7sAOn6 KV8dlkLlRxFXtfBZcpWfaMI5GJmev3n3srr0n3Ga4+nOXpSw9Ul+gbn4ZFK7c4tHVckD gZqlBKVQhbKGBAxU6Yd3PYkwAkDsLkn1wT6B9ZJiRL+lNgv0jp30HOGqyPN6Jcgg/gbl lvNO5T94CuwO3+cjh7VRnoi26wGOFq2SOWCeQfCP1Bxg5pGroKMwSi0katOkb2/HOA4u X2wyYRNEPiX8hZogdy28fm0m0Zajx4eVUJJXsKrHWjKWC/MmYlCaTHy0x5Y0nLmPBqHy fcrA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=LYIE3q2j; 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=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id i19si367198jab.103.2021.07.26.09.38.20; Mon, 26 Jul 2021 09:38:32 -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; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=LYIE3q2j; 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=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S240377AbhGZPzX (ORCPT + 99 others); Mon, 26 Jul 2021 11:55:23 -0400 Received: from mail.kernel.org ([198.145.29.99]:51956 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S237945AbhGZPez (ORCPT ); Mon, 26 Jul 2021 11:34:55 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id DCC8B6056B; Mon, 26 Jul 2021 16:15:22 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1627316123; bh=7fiAPE6ikF3fpaa06HyQurZAeK3WK4HpofjvgsCGEnA=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=LYIE3q2jlaUHjCuaSxcYpVNBlPudVSoFqlHf7iD3F8BcFDwhQc85EnqJ5/v232Div WVfT5Hbykc0NO0jMtA+3ogVyHSBwePOf7Ega6XZy3C0ysrMcAcrBMv52bTibJOTmzI gHjl3EDl/7RKevzimsGrT8XGAPUR0WgFPkORhVVY= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Christoph Hellwig , Ira Weiny , Chaitanya Kulkarni , Andrew Morton , Linus Torvalds Subject: [PATCH 5.13 198/223] mm: call flush_dcache_page() in memcpy_to_page() and memzero_page() Date: Mon, 26 Jul 2021 17:39:50 +0200 Message-Id: <20210726153852.672438821@linuxfoundation.org> X-Mailer: git-send-email 2.32.0 In-Reply-To: <20210726153846.245305071@linuxfoundation.org> References: <20210726153846.245305071@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Christoph Hellwig commit 8dad53a11f8d94dceb540a5f8f153484f42be84b upstream. memcpy_to_page and memzero_page can write to arbitrary pages, which could be in the page cache or in high memory, so call flush_kernel_dcache_pages to flush the dcache. This is a problem when using these helpers on dcache challeneged architectures. Right now there are just a few users, chances are no one used the PC floppy driver, the aha1542 driver for an ISA SCSI HBA, and a few advanced and optional btrfs and ext4 features on those platforms yet since the conversion. Link: https://lkml.kernel.org/r/20210713055231.137602-2-hch@lst.de Fixes: bb90d4bc7b6a ("mm/highmem: Lift memcpy_[to|from]_page to core") Fixes: 28961998f858 ("iov_iter: lift memzero_page() to highmem.h") Signed-off-by: Christoph Hellwig Reviewed-by: Ira Weiny Cc: Chaitanya Kulkarni Cc: Signed-off-by: Andrew Morton Signed-off-by: Linus Torvalds Signed-off-by: Greg Kroah-Hartman --- include/linux/highmem.h | 2 ++ 1 file changed, 2 insertions(+) --- a/include/linux/highmem.h +++ b/include/linux/highmem.h @@ -329,6 +329,7 @@ static inline void memcpy_to_page(struct VM_BUG_ON(offset + len > PAGE_SIZE); memcpy(to + offset, from, len); + flush_dcache_page(page); kunmap_local(to); } @@ -336,6 +337,7 @@ static inline void memzero_page(struct p { char *addr = kmap_atomic(page); memset(addr + offset, 0, len); + flush_dcache_page(page); kunmap_atomic(addr); }