Message ID | 20250210193801.781278-10-david@redhat.com (mailing list archive) |
---|---|
State | New |
Headers | show
Return-Path: <owner-linux-mm@kvack.org> X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from kanga.kvack.org (kanga.kvack.org [205.233.56.17]) by smtp.lore.kernel.org (Postfix) with ESMTP id B1A58C021A1 for <linux-mm@archiver.kernel.org>; Mon, 10 Feb 2025 19:38:45 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id 4515828000A; Mon, 10 Feb 2025 14:38:45 -0500 (EST) Received: by kanga.kvack.org (Postfix, from userid 40) id 4000D280001; Mon, 10 Feb 2025 14:38:45 -0500 (EST) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 253E728000A; Mon, 10 Feb 2025 14:38:45 -0500 (EST) X-Delivered-To: linux-mm@kvack.org Received: from relay.hostedemail.com (smtprelay0012.hostedemail.com [216.40.44.12]) by kanga.kvack.org (Postfix) with ESMTP id 053B7280001 for <linux-mm@kvack.org>; Mon, 10 Feb 2025 14:38:44 -0500 (EST) Received: from smtpin18.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay07.hostedemail.com (Postfix) with ESMTP id AEF9016055F for <linux-mm@kvack.org>; Mon, 10 Feb 2025 19:38:44 +0000 (UTC) X-FDA: 83105047368.18.39D2513 Received: from us-smtp-delivery-124.mimecast.com (us-smtp-delivery-124.mimecast.com [170.10.129.124]) by imf29.hostedemail.com (Postfix) with ESMTP id 7FEA812000A for <linux-mm@kvack.org>; Mon, 10 Feb 2025 19:38:42 +0000 (UTC) Authentication-Results: imf29.hostedemail.com; dkim=pass header.d=redhat.com header.s=mimecast20190719 header.b=WDw8D0Gg; spf=pass (imf29.hostedemail.com: domain of dhildenb@redhat.com designates 170.10.129.124 as permitted sender) smtp.mailfrom=dhildenb@redhat.com; dmarc=pass (policy=none) header.from=redhat.com ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=hostedemail.com; s=arc-20220608; t=1739216322; h=from:from:sender:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:mime-version: content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references:dkim-signature; bh=b7jLfJ9vH0eUU1vYEXZ3dUW5UEIvFQqjIYltl+lFPPU=; b=pyFA9buL1fJtw06h0N/OQnad7sK7SxMHwxfTcgjNktJ/swBsLaSuINjf7sRigRZR4Ro+Na OCurSTl5IVjnoGKmmAtRzFqt8MQZSPseosXS3Xf+BeImEHmZ7QMyx36fa7MrxJl9lmSFB0 Y6ehFPJBK7PyfhzGx/n0vyMgoG7ra7w= ARC-Authentication-Results: i=1; imf29.hostedemail.com; dkim=pass header.d=redhat.com header.s=mimecast20190719 header.b=WDw8D0Gg; spf=pass (imf29.hostedemail.com: domain of dhildenb@redhat.com designates 170.10.129.124 as permitted sender) smtp.mailfrom=dhildenb@redhat.com; dmarc=pass (policy=none) header.from=redhat.com ARC-Seal: i=1; s=arc-20220608; d=hostedemail.com; t=1739216322; a=rsa-sha256; cv=none; b=Fd4yGrn+s+IyK4EcejH3Gw+zc7anXlApe6xk4SBmkt51rI2E24Xpn6lQHs3Nssj0nupYkU 4oKUkuiNvSJl6gYCxbQwXOPZEjuoiGKXr8zvcgNVbffZzLkJbI6OiaPyHLLUuntrEIac2a JrzqaKZsUYsBYI1o5ksUs5wmNn733+M= DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1739216321; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=b7jLfJ9vH0eUU1vYEXZ3dUW5UEIvFQqjIYltl+lFPPU=; b=WDw8D0GgGNKMZT0mBqbsJGqDgZ1bopJ6Wn8XeBgE2JfTPy/bXAIs9x7Icx+dU9j2gwqsH7 jNsRRx84/y3XfBK/gbSYVm6ut4C2//TEmmPA6N0oEjLTBJ09j5fk5qlU3sV7olL4mmVpB9 mHzpSMXwHM0FyOzUlGzTbGCVrtAXu2I= Received: from mail-wm1-f70.google.com (mail-wm1-f70.google.com [209.85.128.70]) by relay.mimecast.com with ESMTP with STARTTLS (version=TLSv1.3, cipher=TLS_AES_256_GCM_SHA384) id us-mta-471-dafbIV8CNTmGrBoMKVC_Mw-1; Mon, 10 Feb 2025 14:38:39 -0500 X-MC-Unique: dafbIV8CNTmGrBoMKVC_Mw-1 X-Mimecast-MFC-AGG-ID: dafbIV8CNTmGrBoMKVC_Mw Received: by mail-wm1-f70.google.com with SMTP id 5b1f17b1804b1-4394c489babso2567015e9.1 for <linux-mm@kvack.org>; Mon, 10 Feb 2025 11:38:39 -0800 (PST) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1739216318; x=1739821118; 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=b7jLfJ9vH0eUU1vYEXZ3dUW5UEIvFQqjIYltl+lFPPU=; b=Is2r5g6W7fruZlQIAyq8RfeDxNllzUK0UkN1yC/XuD7MJhyPjvXdF5rgDhPh8gAUTn PVDxWxaxflmMtJsWKG3y8HR8d/mCE7gVDwU8zJQoBuhd1hhH/9NCLuIjlBzIZHgRHuS3 mvLilh7CgF16J+fTlCYWXWkRPLeDSK2CQpRlEPr9fLC8TsYzxKGdmL2T6smK2Gu7EEOb 2QSemQtDtqltCxj/Jw9IG0LEQafylTpnERL6001NxTjsdMSGvtBfSp4KdM9Wi0+EI2+x K/amt92aM6DnHBlrJKnG4BuaPgpRkEe5Dz3/cP3CJe/K1OZbG36KhS8xxmL81qTUX87A Ptbg== X-Forwarded-Encrypted: i=1; AJvYcCWUhSJSi2S7mDA/Tq9OkGUram7Rz73ezSn4g80WQdGQb1Ar/8nwFYmLRGTjuO1M7AQxxLNi33egIA==@kvack.org X-Gm-Message-State: AOJu0Yy8jDjoloTVKuRCKT3Kjb3VhlMxc+z1tMzQt5gtFo+FfQbKcRYz EdVbE1RLb6WNekEp7PBlWQi5fTrBOFCrC3FJkDojx/CNpzbJ2N5bkMgfB7s3y1R2dVGUszRjxuS wRXwkiR8r9Kh96RoW1m12221FQwiM0C8iChRoiNCphpShbNPf X-Gm-Gg: ASbGnctQdwnfLzW0iFTpKeyj/Z9JgO02mGO4rJ6QJrvNF2gOK8wwVnxielu9VncGMP0 denwKnMonDzXPJSja2FiQyPtkucXlK778gewih27LDgw3hmjD0HbLBfUJjstjgz1dXSuSy5O5Im X+AKfUwZxwxLJepGpqNF2B+E+jw0cXUVn1hxkiZXJI8SvbCgBREw1QiJQQKX4Zz3aa3DqQbf4NY y4RC4Zp6TkTH3qRnzXHABlEqNPz7EdGBnFFXktIJybWuFlEKc9IiKHmr7l2gyi2teoIUL6Kf0cd UoZmS3rWYvM2dJScH2OxwX/9+WUYyLIOoFDWvrCbcvMYeGAn3ECf/lf/rbguI0R4vA== X-Received: by 2002:a05:600c:4f90:b0:434:a7e7:a1ca with SMTP id 5b1f17b1804b1-439249b04f8mr116077435e9.20.1739216318623; Mon, 10 Feb 2025 11:38:38 -0800 (PST) X-Google-Smtp-Source: AGHT+IHdlczuWpIJN55C/ZdLw7mis7jMK/FKd714PEZJ/2b6DQtULEf1bpuI2yab2McnQRseLHdLgg== X-Received: by 2002:a05:600c:4f90:b0:434:a7e7:a1ca with SMTP id 5b1f17b1804b1-439249b04f8mr116077285e9.20.1739216318299; Mon, 10 Feb 2025 11:38:38 -0800 (PST) Received: from localhost (p200300cbc734b80012c465cd348aaee6.dip0.t-ipconnect.de. [2003:cb:c734:b800:12c4:65cd:348a:aee6]) by smtp.gmail.com with UTF8SMTPSA id 5b1f17b1804b1-4391da96502sm158809495e9.1.2025.02.10.11.38.36 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Mon, 10 Feb 2025 11:38:37 -0800 (PST) From: David Hildenbrand <david@redhat.com> To: linux-kernel@vger.kernel.org Cc: linux-doc@vger.kernel.org, dri-devel@lists.freedesktop.org, linux-mm@kvack.org, nouveau@lists.freedesktop.org, linux-trace-kernel@vger.kernel.org, linux-perf-users@vger.kernel.org, damon@lists.linux.dev, David Hildenbrand <david@redhat.com>, Andrew Morton <akpm@linux-foundation.org>, =?utf-8?b?SsOpcsO0bWUgR2xpc3Nl?= <jglisse@redhat.com>, Jonathan Corbet <corbet@lwn.net>, Alex Shi <alexs@kernel.org>, Yanteng Si <si.yanteng@linux.dev>, Karol Herbst <kherbst@redhat.com>, Lyude Paul <lyude@redhat.com>, Danilo Krummrich <dakr@kernel.org>, David Airlie <airlied@gmail.com>, Simona Vetter <simona@ffwll.ch>, Masami Hiramatsu <mhiramat@kernel.org>, Oleg Nesterov <oleg@redhat.com>, Peter Zijlstra <peterz@infradead.org>, SeongJae Park <sj@kernel.org>, "Liam R. Howlett" <Liam.Howlett@oracle.com>, Lorenzo Stoakes <lorenzo.stoakes@oracle.com>, Vlastimil Babka <vbabka@suse.cz>, Jann Horn <jannh@google.com>, Pasha Tatashin <pasha.tatashin@soleen.com>, Peter Xu <peterx@redhat.com>, Alistair Popple <apopple@nvidia.com>, Jason Gunthorpe <jgg@nvidia.com> Subject: [PATCH v2 09/17] mm/ksm: handle device-exclusive entries correctly in write_protect_page() Date: Mon, 10 Feb 2025 20:37:51 +0100 Message-ID: <20250210193801.781278-10-david@redhat.com> X-Mailer: git-send-email 2.48.1 In-Reply-To: <20250210193801.781278-1-david@redhat.com> References: <20250210193801.781278-1-david@redhat.com> MIME-Version: 1.0 X-Mimecast-Spam-Score: 0 X-Mimecast-MFC-PROC-ID: WBSISAlZ0uEqVlirnYg-_HsnzhwrdqKLXKA_M0FUUAc_1739216319 X-Mimecast-Originator: redhat.com Content-Transfer-Encoding: 8bit content-type: text/plain; charset="US-ASCII"; x-default=true X-Rspamd-Server: rspam04 X-Rspamd-Queue-Id: 7FEA812000A X-Stat-Signature: yrbyhjxrw7d1m6muqg91fij6yphwah85 X-Rspam-User: X-HE-Tag: 1739216322-720356 X-HE-Meta: U2FsdGVkX1/J7xSr23s17R9r+PDjGOheuO9aJHaJpVgKJqc2zEGVKBiQiQQgUIvknFl68rXZkAyEQRvvdBcZBEltJ3OxOBm8KyAd9EqJ+pSIrB2W31jdzl83mSHwu97n6K7gjkPWgjldLXS3qTc+GzyGB8laLGnm4b+phCJ3AEdKQH3dtFWHRpuK+z9+hketFwathmqnD14NOkxDBjd4MNOPIxxMcSYEZxZSoRApUeheUswuOV2wRywaTX5wsZ7V0fUEBgYpurOvAL67D+Xt2UU6dLliClBHv1QGQyzZLcp8JZ3XdNuLkf/s1gAusrORYSOPafnIpsFRvz59TpuYcstkehq8zFWN7OFyNG1wDmR1jtxBv6dBLYDzcGhCDUbEogf2JMQdJJSD/wGRlcWuZgN87AITV5cbD8VV1y4rkLQD3VxpICQCP9wi/gzQUKoXCYup0+Fbjp7c73KBpz6hCvgu/yxD8UF75FmZdaERqhoYz372NsrGj7yvMpv/8fAxQkWY2qYr8brREcRK/WS4kRnrNB+ku+Vs4zOF0Vh9Qhc3G6VuMsIkWVs5cs7GQFHPFo8a11xS7OwQXknh5Bq7OcE9ZElfh23+L2XkSFL++etPwl3j552QtqGYq53cRWRgE/hFEpXJ8Aahtp2VV55kMahLC2/NkOlVrzM8yUWcH50TZ+FxLC7BjDhZz+/V0SusgRRavGwZuy/PQBbE3IfHpWGEtXPAuCr8cEU3hRMOhtL0EaIpPHUnw+hBqZJBnEIbe82JzzndKuVVYeLxQ49wNpK5bEfkNKZKcRTq/gvZfnNBNPKU02HZIoFa0X9rTFT9AL2CyiFSvvy4WaY2QUKO0p4vb6DfdlvCI3fxFIHc2cJqyA6CEooEYHm5zT91HHF4QMLwRMoRlrfKRjENxu4qD3ZxOeLD0wYUI02aM9H6geFrL0R5OpeAHEFdXdxIzo/WZb4VB3HhOqsTKLnZrY7 GBNYGKi0 us/K3dT0hSSkvrY8wkG+U/UAQ5RuqC19EWWUrNk5ej7k2n1b5Z9xz2s3A7b8tnkxZx8epjIcbMqnI1nadZwj5jRaZFUyMffwmThlFKTztaHJ2drPlKzzRtyOKf+PSgWzRHzf/+rjix0x20svGCZpeGfLixN4GfLl5ICx2ypv4mIBLFkhhOFCB1pM7SRXrgdnV3W3EnF80M8Jq/TNlxePpTlIopUSCAP3iFeObiJ8VgdeqK/k2kx6An181rlW4PZ5ZkQWhQ5iEN62X0W753qHAT3Fum97UCyy0oCmQkZ56hsejvCdyH9pCL4WB+yxOyF88q+Ug/nxzXjpWUFoO7Xp9ypjKGph1QO9ykZNt+UQR50hdhXLH0+rFvYdMMIZnsP88PAoDZSWTX9lW9TU9rQYARpE20aVPH3EIe/ppwG3ybUBOLt1sEO54cEhoiwBGC7wk5qb0VlxlWSjKTsyFtSgWQ5qwAN+C8A9mJ5iUsWQXqXB+gSNb1peZ9mmFm52YiUSjnsFs6manQsA3VeoX3xOEDl+7ZQ== X-Bogosity: Ham, tests=bogofilter, spamicity=0.000004, version=1.2.4 Sender: owner-linux-mm@kvack.org Precedence: bulk X-Loop: owner-majordomo@kvack.org List-ID: <linux-mm.kvack.org> List-Subscribe: <mailto:majordomo@kvack.org> List-Unsubscribe: <mailto:majordomo@kvack.org> |
Series |
mm: fixes for device-exclusive entries (hmm)
|
expand
|
diff --git a/mm/ksm.c b/mm/ksm.c index 8be2b144fefd6..8583fb91ef136 100644 --- a/mm/ksm.c +++ b/mm/ksm.c @@ -1270,8 +1270,15 @@ static int write_protect_page(struct vm_area_struct *vma, struct folio *folio, if (WARN_ONCE(!pvmw.pte, "Unexpected PMD mapping?")) goto out_unlock; - anon_exclusive = PageAnonExclusive(&folio->page); entry = ptep_get(pvmw.pte); + /* + * Handle PFN swap PTEs, such as device-exclusive ones, that actually + * map pages: give up just like the next folio_walk would. + */ + if (unlikely(!pte_present(entry))) + goto out_unlock; + + anon_exclusive = PageAnonExclusive(&folio->page); if (pte_write(entry) || pte_dirty(entry) || anon_exclusive || mm_tlb_flush_pending(mm)) { swapped = folio_test_swapcache(folio);
Ever since commit b756a3b5e7ea ("mm: device exclusive memory access") we can return with a device-exclusive entry from page_vma_mapped_walk(). write_protect_page() is not prepared for that, so teach it about these PFN swap PTEs. Note that device-private entries are so far not applicable on that path, because GUP would never have returned such folios (conversion to device-private happens by page migration, not in-place conversion of the PTE). There is a race between performing the folio_walk (which fails on non-present PTEs) and locking the folio to look it up using page_vma_mapped_walk() again, so this is likely a fix (unless something else could prevent that race, but it doesn't look like). In the future it could be handled if ever required, for now just give up and ignore them like folio_walk would. Fixes: b756a3b5e7ea ("mm: device exclusive memory access") Signed-off-by: David Hildenbrand <david@redhat.com> --- mm/ksm.c | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-)