Message ID | 20250415095007.569836-1-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 85C95C369AB for <linux-mm@archiver.kernel.org>; Tue, 15 Apr 2025 09:50:16 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id ADC982800DE; Tue, 15 Apr 2025 05:50:14 -0400 (EDT) Received: by kanga.kvack.org (Postfix, from userid 40) id A658C2800C2; Tue, 15 Apr 2025 05:50:14 -0400 (EDT) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 8DF2C2800DE; Tue, 15 Apr 2025 05:50:14 -0400 (EDT) X-Delivered-To: linux-mm@kvack.org Received: from relay.hostedemail.com (smtprelay0015.hostedemail.com [216.40.44.15]) by kanga.kvack.org (Postfix) with ESMTP id 6BC2C2800C2 for <linux-mm@kvack.org>; Tue, 15 Apr 2025 05:50:14 -0400 (EDT) Received: from smtpin03.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay09.hostedemail.com (Postfix) with ESMTP id 5725F81137 for <linux-mm@kvack.org>; Tue, 15 Apr 2025 09:50:15 +0000 (UTC) X-FDA: 83335807590.03.3E99A1C Received: from us-smtp-delivery-124.mimecast.com (us-smtp-delivery-124.mimecast.com [170.10.129.124]) by imf26.hostedemail.com (Postfix) with ESMTP id 134ED14000C for <linux-mm@kvack.org>; Tue, 15 Apr 2025 09:50:12 +0000 (UTC) Authentication-Results: imf26.hostedemail.com; dkim=pass header.d=redhat.com header.s=mimecast20190719 header.b=VfRVJJ3d; dmarc=pass (policy=quarantine) header.from=redhat.com; spf=pass (imf26.hostedemail.com: domain of dhildenb@redhat.com designates 170.10.129.124 as permitted sender) smtp.mailfrom=dhildenb@redhat.com ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=hostedemail.com; s=arc-20220608; t=1744710613; 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: references:dkim-signature; bh=iwq1mTB+TbHGTyxESwiSfmoXeV9JrDkURlCGnWcYFAk=; b=6Ca2WSiaCTqNlITlK3M+mDXnrl2z2X/EXnp+gwC0eEwo9s0/nZg1GJQax8Ioz3+fIoxRcw /v/QQ+8+v7YOyLtzVCHUj5gpZqLsCnnyCK1rEBMN/YObErA1A026YSgDCIDJPoQ2Ih2MBU X8khO667gn/C4eQX3FHsorr/mpSJW5E= ARC-Seal: i=1; s=arc-20220608; d=hostedemail.com; t=1744710613; a=rsa-sha256; cv=none; b=CaoiUcA2iw3RQU8iZGJgy5yYPEc0N1YWyZE5+OMC4TGPlR9jEezmxMJpt6CimJChHJ9wxz Mu6or9I3dktgDBYlCNcggWscr8KeSarXnWZnUPtsswJXoEQYh8OrfiXlsGMvXA9li4sT+R xZnDTMbLIYrEdEOxJfh6bzTDgG8behw= ARC-Authentication-Results: i=1; imf26.hostedemail.com; dkim=pass header.d=redhat.com header.s=mimecast20190719 header.b=VfRVJJ3d; dmarc=pass (policy=quarantine) header.from=redhat.com; spf=pass (imf26.hostedemail.com: domain of dhildenb@redhat.com designates 170.10.129.124 as permitted sender) smtp.mailfrom=dhildenb@redhat.com DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1744710612; 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; bh=iwq1mTB+TbHGTyxESwiSfmoXeV9JrDkURlCGnWcYFAk=; b=VfRVJJ3d1Kuc/RozB3KMPWE5DjOAzEcVBQoNv4qNl0GecJmIALNcWOWgsssZdh46JE4fT9 /9rns4kLasPwKnSD1AQGiTKxw/Xvt4O9ZBmcPp+5PbpPSok3FbPHL/iT6xoYofdDxZfgv0 5o7BMB9eJm8k73JEnXI95iwPyKA/aKA= Received: from mail-wr1-f71.google.com (mail-wr1-f71.google.com [209.85.221.71]) by relay.mimecast.com with ESMTP with STARTTLS (version=TLSv1.3, cipher=TLS_AES_256_GCM_SHA384) id us-mta-207-9PeBbtwsPqyAaU1MyBePMw-1; Tue, 15 Apr 2025 05:50:10 -0400 X-MC-Unique: 9PeBbtwsPqyAaU1MyBePMw-1 X-Mimecast-MFC-AGG-ID: 9PeBbtwsPqyAaU1MyBePMw_1744710609 Received: by mail-wr1-f71.google.com with SMTP id ffacd0b85a97d-39abdadb0f0so2450193f8f.0 for <linux-mm@kvack.org>; Tue, 15 Apr 2025 02:50:10 -0700 (PDT) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1744710609; x=1745315409; h=content-transfer-encoding:mime-version:message-id:date:subject:cc :to:from:x-gm-message-state:from:to:cc:subject:date:message-id :reply-to; bh=iwq1mTB+TbHGTyxESwiSfmoXeV9JrDkURlCGnWcYFAk=; b=Qlb8JPLgjq7j8ZTzfih4RnTs9eAgAvtpQ0WQG0MtnlJGthCg/QIKIBOn5A9FRG7Krq nTNWYoX/jV7+xpzhI0qQtUASCrYxBvMubPtKeJIaNfvR1SD6UkBI5l8gCPtHgjCApNbY qEn1H4txtQXkHUxHwz8mMX62TA6Z26d6q56gbZg0NABjnL5nW5N/sfBVlvM+k932Yf0t VfYpBKUrjCnk997mGiIMInwln61kdBx/3orWfR5QApKOvDwilIsojctu3YN3aRNpsNRH D840kcWL/R5G7H4lOsoNq6P6w+GFe0uR26GSKgBzPyi7EgtGp/R45Ex/5lCkEXsFuN+r VTsw== X-Gm-Message-State: AOJu0Ywsk/Z2XivD5SVPGnBJYSQnNIlLA7w+PKuRH1wjGkF8tZ4cwiLm 6UQi1D5RNA++RDAihpW8svDKouIpiG4JUVrBwvh47ntcgmV0ZYDO9rBTqp4sw01AMUTeSpdSQS4 sIt3vFv2vUQfZFXOoDOCOoeJZqqkhMlT3s+IAMEwyv1Hty0Yc X-Gm-Gg: ASbGncv54ecFQhIkUlwwhyzs5lWunOhUayoIaunruj4mtikNqsU25aLRkuLYw3Ct2lR bHVSzN3KUSom19BO0lKPxJIcxBCWCG8HS1/JT8uA+T8rS2lYBWbs42OY5ih0CtXW55M2UuS7HbC tbbAVdwnNCJXqDEIIAblsRdTJPB+jXAE5PjYFByFzyMEwXMhmdWKP8cvsRxXxGnLXYXXpCrA1T4 thryqpw7qHDBBeBC0jIc5JAzG5Ww4GmaFwjH14gVno4AWpHzuKpVSzTjkA+jVchZ2YGntHcswzV JOqI4Za0Qc40cHq0YEzEp87q6D0umiTT7yo7kVkB9AKw2VDEZPlmH3lnnH2LQHFlYef6E3M= X-Received: by 2002:a05:6000:1a8e:b0:39c:12ce:67e with SMTP id ffacd0b85a97d-39eaaebe9b2mr12343817f8f.41.1744710609298; Tue, 15 Apr 2025 02:50:09 -0700 (PDT) X-Google-Smtp-Source: AGHT+IHw8ad78S6WE7q/ocC1X8mx345RwUrR7dg9JzzjrWE6ClRK+3xTkOCj6SSrMDhQnjXLb4HRNw== X-Received: by 2002:a05:6000:1a8e:b0:39c:12ce:67e with SMTP id ffacd0b85a97d-39eaaebe9b2mr12343795f8f.41.1744710608953; Tue, 15 Apr 2025 02:50:08 -0700 (PDT) Received: from localhost (p200300d82f022900f54fbad7c5f49404.dip0.t-ipconnect.de. [2003:d8:2f02:2900:f54f:bad7:c5f4:9404]) by smtp.gmail.com with UTF8SMTPSA id ffacd0b85a97d-39eaf43ce0asm13726944f8f.70.2025.04.15.02.50.07 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Tue, 15 Apr 2025 02:50:08 -0700 (PDT) From: David Hildenbrand <david@redhat.com> To: linux-kernel@vger.kernel.org Cc: linux-mm@kvack.org, David Hildenbrand <david@redhat.com>, syzbot+5e8feb543ca8e12e0ede@syzkaller.appspotmail.com, Andrew Morton <akpm@linux-foundation.org> Subject: [PATCH v1] mm/memory: move sanity checks in do_wp_page() after mapcount vs. refcount stabilization Date: Tue, 15 Apr 2025 11:50:07 +0200 Message-ID: <20250415095007.569836-1-david@redhat.com> X-Mailer: git-send-email 2.49.0 MIME-Version: 1.0 X-Mimecast-Spam-Score: 0 X-Mimecast-MFC-PROC-ID: GIeL2oGEF5uZ2y3Ujgjv_1_cNo5dMBn2q8dENM3i59U_1744710609 X-Mimecast-Originator: redhat.com Content-Transfer-Encoding: 8bit content-type: text/plain; charset="US-ASCII"; x-default=true X-Rspamd-Server: rspam07 X-Rspamd-Queue-Id: 134ED14000C X-Stat-Signature: 5c5kj99rjrnz1m9n4cmzgaf3ayiqjgst X-Rspam-User: X-HE-Tag: 1744710612-662707 X-HE-Meta: U2FsdGVkX18uCyQD5OVROTzHQNi+T0CgxHKHl0KRJprUlbU9hyn31VxyldirWoXcdE751KWyrcaX1TtOD7eE2+3zaHAkh4s3xRrf4fypruuHwYZ5w2EipdI6EIEiQ09BM6jmBECStzu6dw0l8yLlPQtcKsSKk80SPr0IMqVZzNVz8fsqU74D0g+DFQutIt32B/9ossLJMiwv6TgFBhC05Nmp7IySOtI8AUXKC6NLLucKZzOfPeOEMbjawCryZiaJj1jKrsxMD6b1RvLX4fyCZByHaQCd83HewiCteTNGOHm2s7gD98gv20F1vRWyd6y5k7SdPBbwl3Nl1C2bBkrgn3Fe1TqxgyyGT2ZwZObhfYpOVGa4ZoqtEDxOSThEEcAEGSKvWAokCFuar9j+3FiLYD7HbC2Z+kINQpInb9iq444lte5PncaUaRLw9r0vLDKJ3wt9iqr7/ay4a2TcT3Ywh3BlEj6M/BKkzERaDQniKmIWnB3sGVdU8/vPNA59kEOD9BCD9NoGZPNZ90uxwUlp8uBDofcLIo09KLHYQGh43dwcnE7RRex8IE+2od4RIF/hUC4LXaD+699EjUN/M066l/dI3V+L7nKBIbhQhrOLa2l3041k2ZRfMP79KJbQNiOhHHwL+J9uHFh+Wz1XWQVItG0okS7sR+5Buv3vKQahYmoiAqlV5cyKWeKGczF7IA/j/LRWapDqdlx8e8NpKNsqtX1Xj2aC4LTWzxFCBVowtsH4N/FIS2X73qGOAeGD119BPuIApK1UbCopb+ArB8xoLaq2SJsUQld1tl4EK1epM1xSjjEXXtMA1OLjKTq5Xd6G8f6L9qjbLCvSY+b2Ji7huee3MlaNtMNOxM48SOkIfT77jYdasdMLPExopYWc6o59hnqOXp35WBd+9gMukq3RM2k5oHz6s1mZpC2HeNHNMwcJAE+4VacIj5Wdxf0KUseuISal+Kw40lsSsjvngUI hDDzt+Lj 7ADRFXp1Gdl1SzWrEBAqoG54OiWTWXdUP8ABMnKRkf/53Yut/nltfO7bNA5BWj6cOPlusc4DLurBA8thgEnqIpwKlCby6fREHnn0nm3nI55BnrfiGYYWKbbxyggs+ei9fRcbQ/PwsOa4gh76yu1cwyVE2/C82oeihDnoKhCz7yXHW2WC52TPORfepgCkvf3O+sJvNBs9uB2H1f5WWfAkKoFs9fzEhyVMO1D8Th9JU+ypIz9G2nGTpMNy8bFbNCLj/O6Jw5Cs9FZ4fVkqYAzl22ISTb+kyFf8iuncgEm+KDc8TgqPDkomR+wx3xWFmUd926zsQaL+Y2FSHpums8vkdmqhuNQM6LYnCIfibxQsNLhwqsrY3trcE1lwAOatmp/Y+gmiCMzQqCrL+QgnOZzrN9yIQ4QymgXeIwnmGuanblSsaIfppPd1d/YUZvjR0zzqTl+TmzzO3wO5z3KpH+/rz6+xJme39YjKIeL9gFSak5yVM6vWhIW7OTGyQBwPPkn0zYOvulCOLzn6qpnGJmgrwOCNrbCVgYbOA0cFhjOVBRqvmkfbev9SBq9nmMZtlRDojqUUimEAX6Kc0pM51DwM17UFwhR971LGVI0na9hZkV8EDTurKj2wSI9CWrxn86UpJzVs7jQEsb3lYacrF4rw1z0U3Qqd9JikaBSLXmJjdUeRccCN45Gr2Xar5HuKE7Hagf+nTA/LGs451pBD8L/BBGyw2tq227ip7SWLv6WwUHZImGgFKlyC6UaqGDCKMfH71DluzqlsB+nL9MNwyIOxjZrW4Rg2zo/9X40Zx X-Bogosity: Ham, tests=bogofilter, spamicity=0.000000, 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 |
[v1] mm/memory: move sanity checks in do_wp_page() after mapcount vs. refcount stabilization
|
expand
|
diff --git a/mm/memory.c b/mm/memory.c index 2d8c265fc7d60..625886d40e091 100644 --- a/mm/memory.c +++ b/mm/memory.c @@ -3734,8 +3734,6 @@ static bool __wp_can_reuse_large_anon_folio(struct folio *folio, return false; VM_WARN_ON_ONCE(folio_test_ksm(folio)); - VM_WARN_ON_ONCE(folio_mapcount(folio) > folio_nr_pages(folio)); - VM_WARN_ON_ONCE(folio_entire_mapcount(folio)); if (unlikely(folio_test_swapcache(folio))) { /* @@ -3760,6 +3758,8 @@ static bool __wp_can_reuse_large_anon_folio(struct folio *folio, if (folio_large_mapcount(folio) != folio_ref_count(folio)) goto unlock; + VM_WARN_ON_ONCE_FOLIO(folio_large_mapcount(folio) > folio_nr_pages(folio), folio); + VM_WARN_ON_ONCE_FOLIO(folio_entire_mapcount(folio), folio); VM_WARN_ON_ONCE(folio_mm_id(folio, 0) != vma->vm_mm->mm_id && folio_mm_id(folio, 1) != vma->vm_mm->mm_id);
In __folio_remove_rmap() for RMAP_LEVEL_PMD/RMAP_LEVEL_PUD and with CONFIG_PAGE_MAPCOUNT we first decrement the folio mapcount (and recompute mapped shared vs. mapped exclusively) to then adjust the entire mapcount. This means that another process might stumble in do_wp_page() over a PTE-mapped PMD folio that is indicated as "exclusively mapped", but still has an entire mapcount (PMD mapping), because it is racing with the process that is unmapping the folio (PMD mapping). Note that do_wp_page() will back off once it detects the remaining folio reference from the process that is in the process of unmapping the folio. This will trigger the early VM_WARN_ON_ONCE(folio_entire_mapcount(folio)) check in do_wp_page(), that can easily be reproduced by looping a couple of times over allocating a PMD THP, forking a child where we immediately unmap it again, and writing in the parent concurrently to the THP. [ 252.738129][T16470] ------------[ cut here ]------------ [ 252.739267][T16470] WARNING: CPU: 3 PID: 16470 at mm/memory.c:3738 do_wp_page+0x2a75/0x2c00 [ 252.740968][T16470] Modules linked in: [ 252.741958][T16470] CPU: 3 UID: 0 PID: 16470 Comm: ... ... [ 252.765841][T16470] <TASK> [ 252.766419][T16470] ? srso_alias_return_thunk+0x5/0xfbef5 [ 252.767558][T16470] ? rcu_is_watching+0x12/0x60 [ 252.768525][T16470] ? srso_alias_return_thunk+0x5/0xfbef5 [ 252.769645][T16470] ? srso_alias_return_thunk+0x5/0xfbef5 [ 252.770778][T16470] ? lock_acquire+0x33/0x80 [ 252.771697][T16470] ? __handle_mm_fault+0x5e8/0x3e40 [ 252.772735][T16470] ? __handle_mm_fault+0x5e8/0x3e40 [ 252.773781][T16470] __handle_mm_fault+0x1869/0x3e40 [ 252.774839][T16470] handle_mm_fault+0x22a/0x640 [ 252.775808][T16470] do_user_addr_fault+0x618/0x1000 [ 252.776847][T16470] exc_page_fault+0x68/0xd0 [ 252.777775][T16470] asm_exc_page_fault+0x26/0x30 While we could adjust the sequence in __folio_remove_rmap(), let's rater move the mapcount sanity checks after the mapcount vs. refcount stabilization phase. With this fix, a simple reproducer is happy. While at it, convert the two VM_WARN_ON_ONCE() we are moving to VM_WARN_ON_ONCE_FOLIO(). Reported-by: syzbot+5e8feb543ca8e12e0ede@syzkaller.appspotmail.com Closes: https://lkml.kernel.org/r/67fab4fe.050a0220.2c5fcf.0011.GAE@google.com Fixes: 1da190f4d0a6 ("mm: Copy-on-Write (COW) reuse support for PTE-mapped THP") Cc: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: David Hildenbrand <david@redhat.com> --- mm/memory.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-)