Received: by 2002:a05:7412:bc1a:b0:d7:7d3a:4fe2 with SMTP id ki26csp395787rdb; Sat, 19 Aug 2023 06:12:56 -0700 (PDT) X-Google-Smtp-Source: AGHT+IGrq7usYCVyVg0nAinAN/WxTjiK/y4IIevAkndXeWbyPh6ClDxjPIVKhQOPVTeeEP2bhQwE X-Received: by 2002:a05:6a21:6da5:b0:137:3eba:b81f with SMTP id wl37-20020a056a216da500b001373ebab81fmr2923177pzb.3.1692450776572; Sat, 19 Aug 2023 06:12:56 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1692450776; cv=none; d=google.com; s=arc-20160816; b=D7E0jL17epkF35mW9rJSdiFIk/8IIzXdWYvrp3SYOMl0Aaf4EnY3OwnmkC/DHIJTGJ vh9MxhOTrfZE90hWjKGXJRuU9U1gv8hQlQbEDwG/BQifgkFWs2KGnRJjF/xkEbXX0btO WwuElGIykIZcqdyGsMH57dX9FoaAFoMGsX9dNtUcprQ+yeUfWtRiGBI/ucx7yqfyLyhb i0HAaqyGEX9AQ5rjlwcMuZA1bsQJpdnpk+8/SJXqrMuDVIr+Vc0v7OalADZO7/donu/F JfXz1GNXJpeJ6Km5oNOUYMwecMGohzUeZg1yxS9QyvSFneZ3qokAjXGPh1uPk85tVCaK lAEw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to :organization:from:references:cc:to:content-language:subject :user-agent:mime-version:date:message-id:dkim-signature; bh=CUx5LEJZOPKDsMypuqMlxZ2NyXniu36dIsENemGDz2U=; fh=vEfKdIq6gkrvbcDs3S4HH4uisfLx4sOaEHUUNkZjJt0=; b=GAhHuAH6wOBvvvIaaIwsDICVOi/vTfAN/hKmvCe1cUhc1guIrjqkBfwUgq5t8n2EK2 4VCstI1IAzQP6RPFpIycj4YV7c2vPsoyQalHdGguZLowzXBAycELv3y2+jbUzZE6fgji jbuR3UaafF9nRXAA6702NBtlxNO6unoKoKpQS0W3Uy1HSPOZhrsDrZ/Cylwg9vLgQu2t AWq89bbFOZO0dyhrjaaBkOTn3FtW3wSGxdtqU8E01/3Bx+myBY88rzbVxAwdUjjnceDC HyA6NZRekMU3xwqRsEHLgFCoRNXu40qQDzPygjbUt7onsJmowg/j2iuIAMo7bvSmqmy1 PmOQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=KUY83w3G; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from lindbergh.monkeyblade.net (lindbergh.monkeyblade.net. [2620:137:e000::1:18]) by mx.google.com with ESMTPS id s18-20020a656912000000b0056536fc7901si3229467pgq.593.2023.08.19.06.12.56 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sat, 19 Aug 2023 06:12:56 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) client-ip=2620:137:e000::1:18; Authentication-Results: mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=KUY83w3G; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 8B1089BB3C; Sat, 19 Aug 2023 01:39:52 -0700 (PDT) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S235373AbjHOHMo (ORCPT + 99 others); Tue, 15 Aug 2023 03:12:44 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:40882 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S235372AbjHOHML (ORCPT ); Tue, 15 Aug 2023 03:12:11 -0400 Received: from us-smtp-delivery-124.mimecast.com (us-smtp-delivery-124.mimecast.com [170.10.129.124]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 843D01991 for ; Tue, 15 Aug 2023 00:11:22 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1692083481; 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=CUx5LEJZOPKDsMypuqMlxZ2NyXniu36dIsENemGDz2U=; b=KUY83w3GGF5VIXo0q6oJrjBfhfoLpmP9OKILtHR7DI6mlxF+bBQvu4iROtMZOYODmoG7FB vpeLGgzI4szYKuZLJOnixh1sTjgyHov5APqW5ADAvqbic/V9QwGVUzu7TmX6jXsPPBcbkY V2MQoBRDfnyH9wmMxpEYXYfGacaGo5I= Received: from mail-wm1-f69.google.com (mail-wm1-f69.google.com [209.85.128.69]) by relay.mimecast.com with ESMTP with STARTTLS (version=TLSv1.3, cipher=TLS_AES_256_GCM_SHA384) id us-mta-459-f069pFkCPA67KiNpIiQNSw-1; Tue, 15 Aug 2023 03:11:20 -0400 X-MC-Unique: f069pFkCPA67KiNpIiQNSw-1 Received: by mail-wm1-f69.google.com with SMTP id 5b1f17b1804b1-3fe4cca36b7so34131725e9.3 for ; Tue, 15 Aug 2023 00:11:20 -0700 (PDT) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20221208; t=1692083479; x=1692688279; h=content-transfer-encoding:in-reply-to:organization:from:references :cc:to:content-language:subject:user-agent:mime-version:date :message-id:x-gm-message-state:from:to:cc:subject:date:message-id :reply-to; bh=CUx5LEJZOPKDsMypuqMlxZ2NyXniu36dIsENemGDz2U=; b=SZBvWYvIKzOlnrYe/HTWIe9EQCqW6jxcCGInDLZPgEdpXxjVUp1WYCy98hLtFx6xzu PpQrFnzVbRTzrwYqL5uaDTIOcUnykcAs/6UkfT5E0u/kteaHUjC/RXMyYdR24q7/SXEK WuVXOdZ6ai847S5vyKojv0m9fIAGF1X4qltc4cP8wOqlBRt1Ggb+lRzO8eC9ULsgMc2C r/aCrHdQYI99TMiDgJx/Ybi/62Zq9Ls2fb8ivflE2AOyTHS0dIwg/ZrFTOEdF+1AjEYj jLdUKlyK3isFLs6BZxMsATbzH6wO1Juy7W0HZagoDaVOW9oU0y02dNPqG1IGZoab9mjW grIg== X-Gm-Message-State: AOJu0YwSQ0xlA7de0850zCcqb6qtv0/EE+bCm2KCxya11QXZSrLtbjhr a+TPlvvbEci9yaFY2muzu/iVJ4OW5hlXiuAntDp39e9h5DbHoiZfyvRdDDTgJy6bOVwIxYAiazm cT/X44FsRrmhkUDqAiM1+0SN4 X-Received: by 2002:a05:600c:2990:b0:3fe:485f:ed13 with SMTP id r16-20020a05600c299000b003fe485fed13mr9404367wmd.29.1692083478912; Tue, 15 Aug 2023 00:11:18 -0700 (PDT) X-Received: by 2002:a05:600c:2990:b0:3fe:485f:ed13 with SMTP id r16-20020a05600c299000b003fe485fed13mr9404349wmd.29.1692083478509; Tue, 15 Aug 2023 00:11:18 -0700 (PDT) Received: from ?IPV6:2003:cb:c701:3100:c642:ba83:8c37:b0e? (p200300cbc7013100c642ba838c370b0e.dip0.t-ipconnect.de. [2003:cb:c701:3100:c642:ba83:8c37:b0e]) by smtp.gmail.com with ESMTPSA id m8-20020a7bca48000000b003fa96fe2bd9sm19977946wml.22.2023.08.15.00.11.16 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Tue, 15 Aug 2023 00:11:17 -0700 (PDT) Message-ID: <76e6b2ad-4e1e-2ad3-95df-00b4d33ec9d2@redhat.com> Date: Tue, 15 Aug 2023 09:11:15 +0200 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:102.0) Gecko/20100101 Thunderbird/102.13.0 Subject: Re: [BUG] Re: [PATCH v3 10/13] mm/khugepaged: collapse_pte_mapped_thp() with mmap_read_lock() Content-Language: en-US To: Hugh Dickins , Jann Horn Cc: Andrew Morton , Mike Kravetz , Mike Rapoport , "Kirill A. Shutemov" , Matthew Wilcox , Suren Baghdasaryan , Qi Zheng , Yang Shi , Mel Gorman , Peter Xu , Peter Zijlstra , Will Deacon , Yu Zhao , Alistair Popple , Ralph Campbell , Ira Weiny , Steven Price , SeongJae Park , Lorenzo Stoakes , Huang Ying , Naoya Horiguchi , Christophe Leroy , Zack Rusin , Jason Gunthorpe , Axel Rasmussen , Anshuman Khandual , Pasha Tatashin , Miaohe Lin , Minchan Kim , Christoph Hellwig , Song Liu , Thomas Hellstrom , Russell King , "David S. Miller" , Michael Ellerman , "Aneesh Kumar K.V" , Heiko Carstens , Christian Borntraeger , Claudio Imbrenda , Alexander Gordeev , Gerald Schaefer , Vasily Gorbik , Vishal Moola , Vlastimil Babka , Zi Yan , Linux ARM , sparclinux@vger.kernel.org, linuxppc-dev , linux-s390 , kernel list , Linux-MM References: <7cd843a9-aa80-14f-5eb2-33427363c20@google.com> From: David Hildenbrand Organization: Red Hat In-Reply-To: Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-4.4 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,NICE_REPLY_A, RCVD_IN_DNSWL_BLOCKED,RCVD_IN_MSPIKE_H4,RCVD_IN_MSPIKE_WL, SPF_HELO_NONE,SPF_NONE autolearn=unavailable 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: X-Mailing-List: linux-kernel@vger.kernel.org On 15.08.23 08:34, Hugh Dickins wrote: > On Mon, 14 Aug 2023, Jann Horn wrote: >> On Wed, Jul 12, 2023 at 6:42 AM Hugh Dickins wrote: >>> Bring collapse_and_free_pmd() back into collapse_pte_mapped_thp(). >>> It does need mmap_read_lock(), but it does not need mmap_write_lock(), >>> nor vma_start_write() nor i_mmap lock nor anon_vma lock. All racing >>> paths are relying on pte_offset_map_lock() and pmd_lock(), so use those. >> >> We can still have a racing userfaultfd operation at the "/* step 4: >> remove page table */" point that installs a new PTE before the page >> table is removed. >> >> To reproduce, patch a delay into the kernel like this: >> >> >> diff --git a/mm/khugepaged.c b/mm/khugepaged.c >> index 9a6e0d507759..27cc8dfbf3a7 100644 >> --- a/mm/khugepaged.c >> +++ b/mm/khugepaged.c >> @@ -20,6 +20,7 @@ >> #include >> #include >> #include >> +#include >> >> #include >> #include >> @@ -1617,6 +1618,11 @@ int collapse_pte_mapped_thp(struct mm_struct >> *mm, unsigned long addr, >> } >> >> /* step 4: remove page table */ >> + if (strcmp(current->comm, "DELAYME") == 0) { >> + pr_warn("%s: BEGIN DELAY INJECTION\n", __func__); >> + mdelay(5000); >> + pr_warn("%s: END DELAY INJECTION\n", __func__); >> + } >> >> /* Huge page lock is still held, so page table must remain empty */ >> pml = pmd_lock(mm, pmd); >> >> >> And then run the attached reproducer against mm/mm-everything. You >> should get this in dmesg: >> >> [ 206.578096] BUG: Bad rss-counter state mm:000000000942ebea >> type:MM_ANONPAGES val:1 > > Thanks a lot, Jann. I haven't thought about it at all yet; and just > tried to reproduce, but haven't yet got the "BUG: Bad rss-counter": > just see "Invalid argument" on the UFFDIO_COPY ioctl. > Will investigate tomorrow. Maybe you're missing a fixup: https://lkml.kernel.org/r/20230810192128.1855570-1-axelrasmussen@google.com When the src address is not page aligned, UFFDIO_COPY in mm-unstable would erroneously fail. -- Cheers, David / dhildenb